Merge pull request #2014 from zed-industries/git-diff-reconnect

Update git diff base when synchronizing a guest's buffers
This commit is contained in:
Antonio Scandurra 2023-01-08 09:28:51 -07:00 committed by GitHub
commit ddbf251b5f
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 81 additions and 16 deletions

View file

@ -14,8 +14,11 @@ use language::{range_to_lsp, FakeLspAdapter, Language, LanguageConfig, PointUtf1
use lsp::FakeLanguageServer; use lsp::FakeLanguageServer;
use parking_lot::Mutex; use parking_lot::Mutex;
use project::{search::SearchQuery, Project}; use project::{search::SearchQuery, Project};
use rand::prelude::*; use rand::{
use std::{env, path::PathBuf, sync::Arc}; distributions::{Alphanumeric, DistString},
prelude::*,
};
use std::{env, ffi::OsStr, path::PathBuf, sync::Arc};
#[gpui::test(iterations = 100)] #[gpui::test(iterations = 100)]
async fn test_random_collaboration( async fn test_random_collaboration(
@ -382,9 +385,15 @@ async fn test_random_collaboration(
); );
} }
(None, None) => {} (None, None) => {}
(None, _) => panic!("host's file is None, guest's isn't "), (None, _) => panic!("host's file is None, guest's isn't"),
(_, None) => panic!("guest's file is None, hosts's isn't "), (_, None) => panic!("guest's file is None, hosts's isn't"),
} }
let host_diff_base =
host_buffer.read_with(host_cx, |b, _| b.diff_base().map(ToString::to_string));
let guest_diff_base = guest_buffer
.read_with(client_cx, |b, _| b.diff_base().map(ToString::to_string));
assert_eq!(guest_diff_base, host_diff_base);
} }
} }
} }
@ -543,9 +552,10 @@ async fn randomly_mutate_client(
50..=59 if !client.local_projects.is_empty() || !client.remote_projects.is_empty() => { 50..=59 if !client.local_projects.is_empty() || !client.remote_projects.is_empty() => {
randomly_mutate_worktrees(client, &rng, cx).await?; randomly_mutate_worktrees(client, &rng, cx).await?;
} }
60..=84 if !client.local_projects.is_empty() || !client.remote_projects.is_empty() => { 60..=74 if !client.local_projects.is_empty() || !client.remote_projects.is_empty() => {
randomly_query_and_mutate_buffers(client, &rng, cx).await?; randomly_query_and_mutate_buffers(client, &rng, cx).await?;
} }
75..=84 => randomly_mutate_git(client, &rng).await,
_ => randomly_mutate_fs(client, &rng).await, _ => randomly_mutate_fs(client, &rng).await,
} }
@ -605,6 +615,54 @@ async fn randomly_mutate_active_call(
Ok(()) Ok(())
} }
async fn randomly_mutate_git(client: &mut TestClient, rng: &Mutex<StdRng>) {
let directories = client.fs.directories().await;
let mut dir_path = directories.choose(&mut *rng.lock()).unwrap().clone();
if dir_path.file_name() == Some(OsStr::new(".git")) {
dir_path.pop();
}
let mut git_dir_path = dir_path.clone();
git_dir_path.push(".git");
if !directories.contains(&git_dir_path) {
log::info!(
"{}: creating git directory at {:?}",
client.username,
git_dir_path
);
client.fs.create_dir(&git_dir_path).await.unwrap();
}
let mut child_paths = client.fs.read_dir(&dir_path).await.unwrap();
let mut child_file_paths = Vec::new();
while let Some(child_path) = child_paths.next().await {
let child_path = child_path.unwrap();
if client.fs.is_file(&child_path).await {
child_file_paths.push(child_path);
}
}
let count = rng.lock().gen_range(0..=child_file_paths.len());
child_file_paths.shuffle(&mut *rng.lock());
child_file_paths.truncate(count);
let mut new_index = Vec::new();
for abs_child_file_path in &child_file_paths {
let child_file_path = abs_child_file_path.strip_prefix(&dir_path).unwrap();
let new_base = Alphanumeric.sample_string(&mut *rng.lock(), 16);
new_index.push((child_file_path, new_base));
}
log::info!(
"{}: updating Git index at {:?}: {:#?}",
client.username,
git_dir_path,
new_index
);
client
.fs
.set_index_for_repo(&git_dir_path, &new_index)
.await;
}
async fn randomly_mutate_fs(client: &mut TestClient, rng: &Mutex<StdRng>) { async fn randomly_mutate_fs(client: &mut TestClient, rng: &Mutex<StdRng>) {
let is_dir = rng.lock().gen::<bool>(); let is_dir = rng.lock().gen::<bool>();
let mut new_path = client let mut new_path = client

View file

@ -5189,20 +5189,27 @@ impl Project {
let operations = buffer.serialize_ops(Some(remote_version), cx); let operations = buffer.serialize_ops(Some(remote_version), cx);
let client = this.client.clone(); let client = this.client.clone();
let file = buffer.file().cloned(); if let Some(file) = buffer.file() {
client
.send(proto::UpdateBufferFile {
project_id,
buffer_id: buffer_id as u64,
file: Some(file.to_proto()),
})
.log_err();
}
client
.send(proto::UpdateDiffBase {
project_id,
buffer_id: buffer_id as u64,
diff_base: buffer.diff_base().map(Into::into),
})
.log_err();
cx.background() cx.background()
.spawn( .spawn(
async move { async move {
if let Some(file) = file {
client
.send(proto::UpdateBufferFile {
project_id,
buffer_id: buffer_id as u64,
file: Some(file.to_proto()),
})
.log_err();
}
let operations = operations.await; let operations = operations.await;
for chunk in split_operations(operations) { for chunk in split_operations(operations) {
client client