mirror of
https://github.com/zed-industries/zed.git
synced 2025-01-12 05:15:00 +00:00
Fix workspace tests after changing Item trait
This commit is contained in:
parent
a0a50cb412
commit
06c31a0daa
3 changed files with 82 additions and 42 deletions
|
@ -784,6 +784,27 @@ pub(crate) mod test {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl TestProjectItem {
|
||||||
|
pub fn new(id: u64, path: &str, cx: &mut MutableAppContext) -> ModelHandle<Self> {
|
||||||
|
let entry_id = Some(ProjectEntryId::from_proto(id));
|
||||||
|
let project_path = Some(ProjectPath {
|
||||||
|
worktree_id: WorktreeId::from_usize(0),
|
||||||
|
path: Path::new(path).into(),
|
||||||
|
});
|
||||||
|
cx.add_model(|_| Self {
|
||||||
|
entry_id,
|
||||||
|
project_path,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn new_untitled(cx: &mut MutableAppContext) -> ModelHandle<Self> {
|
||||||
|
cx.add_model(|_| Self {
|
||||||
|
project_path: None,
|
||||||
|
entry_id: None,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl TestItem {
|
impl TestItem {
|
||||||
pub fn new() -> Self {
|
pub fn new() -> Self {
|
||||||
Self {
|
Self {
|
||||||
|
@ -829,22 +850,9 @@ pub(crate) mod test {
|
||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn with_project_items(
|
pub fn with_project_items(mut self, items: &[ModelHandle<TestProjectItem>]) -> Self {
|
||||||
mut self,
|
self.project_items.clear();
|
||||||
items: &[(u64, &str)],
|
self.project_items.extend(items.iter().cloned());
|
||||||
cx: &mut MutableAppContext,
|
|
||||||
) -> Self {
|
|
||||||
self.project_items
|
|
||||||
.extend(items.iter().copied().map(|(id, path)| {
|
|
||||||
let id = ProjectEntryId::from_proto(id);
|
|
||||||
cx.add_model(|_| TestProjectItem {
|
|
||||||
entry_id: Some(id),
|
|
||||||
project_path: Some(ProjectPath {
|
|
||||||
worktree_id: WorktreeId::from_usize(0),
|
|
||||||
path: Path::new(path).into(),
|
|
||||||
}),
|
|
||||||
})
|
|
||||||
}));
|
|
||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -938,8 +946,12 @@ pub(crate) mod test {
|
||||||
self.has_conflict
|
self.has_conflict
|
||||||
}
|
}
|
||||||
|
|
||||||
fn can_save(&self, _: &AppContext) -> bool {
|
fn can_save(&self, cx: &AppContext) -> bool {
|
||||||
!self.project_items.is_empty()
|
!self.project_items.is_empty()
|
||||||
|
&& self
|
||||||
|
.project_items
|
||||||
|
.iter()
|
||||||
|
.all(|item| item.read(cx).entry_id.is_some())
|
||||||
}
|
}
|
||||||
|
|
||||||
fn save(
|
fn save(
|
||||||
|
|
|
@ -804,7 +804,7 @@ impl Pane {
|
||||||
items_to_close.sort_by_key(|item| !item.is_singleton(cx));
|
items_to_close.sort_by_key(|item| !item.is_singleton(cx));
|
||||||
|
|
||||||
cx.spawn(|workspace, mut cx| async move {
|
cx.spawn(|workspace, mut cx| async move {
|
||||||
let mut saved_project_entry_ids = HashSet::default();
|
let mut saved_project_items_ids = HashSet::default();
|
||||||
for item in items_to_close.clone() {
|
for item in items_to_close.clone() {
|
||||||
// Find the item's current index and its set of project entries. Avoid
|
// Find the item's current index and its set of project entries. Avoid
|
||||||
// storing these in advance, in case they have changed since this task
|
// storing these in advance, in case they have changed since this task
|
||||||
|
@ -836,7 +836,7 @@ impl Pane {
|
||||||
});
|
});
|
||||||
let should_save = project_item_ids
|
let should_save = project_item_ids
|
||||||
.iter()
|
.iter()
|
||||||
.any(|id| saved_project_entry_ids.insert(*id));
|
.any(|id| saved_project_items_ids.insert(*id));
|
||||||
|
|
||||||
if should_save
|
if should_save
|
||||||
&& !Self::save_item(project.clone(), &pane, item_ix, &*item, true, &mut cx)
|
&& !Self::save_item(project.clone(), &pane, item_ix, &*item, true, &mut cx)
|
||||||
|
@ -1672,7 +1672,7 @@ mod tests {
|
||||||
use std::sync::Arc;
|
use std::sync::Arc;
|
||||||
|
|
||||||
use super::*;
|
use super::*;
|
||||||
use crate::item::test::TestItem;
|
use crate::item::test::{TestItem, TestProjectItem};
|
||||||
use gpui::{executor::Deterministic, TestAppContext};
|
use gpui::{executor::Deterministic, TestAppContext};
|
||||||
use project::FakeFs;
|
use project::FakeFs;
|
||||||
|
|
||||||
|
@ -1861,7 +1861,7 @@ mod tests {
|
||||||
let item = TestItem::new()
|
let item = TestItem::new()
|
||||||
.with_singleton(true)
|
.with_singleton(true)
|
||||||
.with_label("buffer 1")
|
.with_label("buffer 1")
|
||||||
.with_project_items(&[(1, "one.txt")], cx);
|
.with_project_items(&[TestProjectItem::new(1, "one.txt", cx)]);
|
||||||
|
|
||||||
Pane::add_item(
|
Pane::add_item(
|
||||||
workspace,
|
workspace,
|
||||||
|
@ -1880,7 +1880,7 @@ mod tests {
|
||||||
let item = TestItem::new()
|
let item = TestItem::new()
|
||||||
.with_singleton(true)
|
.with_singleton(true)
|
||||||
.with_label("buffer 1")
|
.with_label("buffer 1")
|
||||||
.with_project_items(&[(1, "1.txt")], cx);
|
.with_project_items(&[TestProjectItem::new(1, "1.txt", cx)]);
|
||||||
|
|
||||||
Pane::add_item(
|
Pane::add_item(
|
||||||
workspace,
|
workspace,
|
||||||
|
@ -1899,7 +1899,7 @@ mod tests {
|
||||||
let item = TestItem::new()
|
let item = TestItem::new()
|
||||||
.with_singleton(true)
|
.with_singleton(true)
|
||||||
.with_label("buffer 2")
|
.with_label("buffer 2")
|
||||||
.with_project_items(&[(2, "2.txt")], cx);
|
.with_project_items(&[TestProjectItem::new(2, "2.txt", cx)]);
|
||||||
|
|
||||||
Pane::add_item(
|
Pane::add_item(
|
||||||
workspace,
|
workspace,
|
||||||
|
@ -1918,7 +1918,7 @@ mod tests {
|
||||||
let item = TestItem::new()
|
let item = TestItem::new()
|
||||||
.with_singleton(false)
|
.with_singleton(false)
|
||||||
.with_label("multibuffer 1")
|
.with_label("multibuffer 1")
|
||||||
.with_project_items(&[(1, "1.txt")], cx);
|
.with_project_items(&[TestProjectItem::new(1, "1.txt", cx)]);
|
||||||
|
|
||||||
Pane::add_item(
|
Pane::add_item(
|
||||||
workspace,
|
workspace,
|
||||||
|
@ -1937,7 +1937,7 @@ mod tests {
|
||||||
let item = TestItem::new()
|
let item = TestItem::new()
|
||||||
.with_singleton(false)
|
.with_singleton(false)
|
||||||
.with_label("multibuffer 1b")
|
.with_label("multibuffer 1b")
|
||||||
.with_project_items(&[(1, "1.txt")], cx);
|
.with_project_items(&[TestProjectItem::new(1, "1.txt", cx)]);
|
||||||
|
|
||||||
Pane::add_item(
|
Pane::add_item(
|
||||||
workspace,
|
workspace,
|
||||||
|
|
|
@ -2727,7 +2727,7 @@ pub fn open_new(app_state: &Arc<AppState>, cx: &mut MutableAppContext) -> Task<(
|
||||||
mod tests {
|
mod tests {
|
||||||
use std::{cell::RefCell, rc::Rc};
|
use std::{cell::RefCell, rc::Rc};
|
||||||
|
|
||||||
use crate::item::test::{TestItem, TestItemEvent};
|
use crate::item::test::{TestItem, TestItemEvent, TestProjectItem};
|
||||||
|
|
||||||
use super::*;
|
use super::*;
|
||||||
use fs::FakeFs;
|
use fs::FakeFs;
|
||||||
|
@ -2835,10 +2835,10 @@ mod tests {
|
||||||
});
|
});
|
||||||
|
|
||||||
let item1 = cx.add_view(&workspace, |cx| {
|
let item1 = cx.add_view(&workspace, |cx| {
|
||||||
TestItem::new().with_project_items(&[(1, "one.txt")], cx)
|
TestItem::new().with_project_items(&[TestProjectItem::new(1, "one.txt", cx)])
|
||||||
});
|
});
|
||||||
let item2 = cx.add_view(&workspace, |cx| {
|
let item2 = cx.add_view(&workspace, |cx| {
|
||||||
TestItem::new().with_project_items(&[(2, "two.txt")], cx)
|
TestItem::new().with_project_items(&[TestProjectItem::new(2, "two.txt", cx)])
|
||||||
});
|
});
|
||||||
|
|
||||||
// Add an item to an empty pane
|
// Add an item to an empty pane
|
||||||
|
@ -2943,7 +2943,7 @@ mod tests {
|
||||||
let item3 = cx.add_view(&workspace, |cx| {
|
let item3 = cx.add_view(&workspace, |cx| {
|
||||||
TestItem::new()
|
TestItem::new()
|
||||||
.with_dirty(true)
|
.with_dirty(true)
|
||||||
.with_project_items(&[(1, "1.txt")], cx)
|
.with_project_items(&[TestProjectItem::new(1, "1.txt", cx)])
|
||||||
});
|
});
|
||||||
workspace.update(cx, |w, cx| {
|
workspace.update(cx, |w, cx| {
|
||||||
w.add_item(Box::new(item2.clone()), cx);
|
w.add_item(Box::new(item2.clone()), cx);
|
||||||
|
@ -2971,21 +2971,25 @@ mod tests {
|
||||||
let item1 = cx.add_view(&workspace, |cx| {
|
let item1 = cx.add_view(&workspace, |cx| {
|
||||||
TestItem::new()
|
TestItem::new()
|
||||||
.with_dirty(true)
|
.with_dirty(true)
|
||||||
.with_project_items(&[(1, "1.txt")], cx)
|
.with_project_items(&[TestProjectItem::new(1, "1.txt", cx)])
|
||||||
});
|
});
|
||||||
let item2 = cx.add_view(&workspace, |cx| {
|
let item2 = cx.add_view(&workspace, |cx| {
|
||||||
TestItem::new()
|
TestItem::new()
|
||||||
.with_dirty(true)
|
.with_dirty(true)
|
||||||
.with_conflict(true)
|
.with_conflict(true)
|
||||||
.with_project_items(&[(2, "2.txt")], cx)
|
.with_project_items(&[TestProjectItem::new(2, "2.txt", cx)])
|
||||||
});
|
});
|
||||||
let item3 = cx.add_view(&workspace, |cx| {
|
let item3 = cx.add_view(&workspace, |cx| {
|
||||||
TestItem::new()
|
TestItem::new()
|
||||||
.with_dirty(true)
|
.with_dirty(true)
|
||||||
.with_conflict(true)
|
.with_conflict(true)
|
||||||
.with_project_items(&[(3, "3.txt")], cx)
|
.with_project_items(&[TestProjectItem::new(3, "3.txt", cx)])
|
||||||
|
});
|
||||||
|
let item4 = cx.add_view(&workspace, |cx| {
|
||||||
|
TestItem::new()
|
||||||
|
.with_dirty(true)
|
||||||
|
.with_project_items(&[TestProjectItem::new_untitled(cx)])
|
||||||
});
|
});
|
||||||
let item4 = cx.add_view(&workspace, |_| TestItem::new().with_dirty(true));
|
|
||||||
let pane = workspace.update(cx, |workspace, cx| {
|
let pane = workspace.update(cx, |workspace, cx| {
|
||||||
workspace.add_item(Box::new(item1.clone()), cx);
|
workspace.add_item(Box::new(item1.clone()), cx);
|
||||||
workspace.add_item(Box::new(item2.clone()), cx);
|
workspace.add_item(Box::new(item2.clone()), cx);
|
||||||
|
@ -3007,15 +3011,20 @@ mod tests {
|
||||||
[item1_id, item3_id, item4_id].contains(&id)
|
[item1_id, item3_id, item4_id].contains(&id)
|
||||||
})
|
})
|
||||||
});
|
});
|
||||||
|
|
||||||
cx.foreground().run_until_parked();
|
cx.foreground().run_until_parked();
|
||||||
|
|
||||||
|
// There's a prompt to save item 1.
|
||||||
pane.read_with(cx, |pane, _| {
|
pane.read_with(cx, |pane, _| {
|
||||||
assert_eq!(pane.items_len(), 4);
|
assert_eq!(pane.items_len(), 4);
|
||||||
assert_eq!(pane.active_item().unwrap().id(), item1.id());
|
assert_eq!(pane.active_item().unwrap().id(), item1.id());
|
||||||
});
|
});
|
||||||
|
assert!(cx.has_pending_prompt(window_id));
|
||||||
|
|
||||||
|
// Confirm saving item 1.
|
||||||
cx.simulate_prompt_answer(window_id, 0);
|
cx.simulate_prompt_answer(window_id, 0);
|
||||||
cx.foreground().run_until_parked();
|
cx.foreground().run_until_parked();
|
||||||
|
|
||||||
|
// Item 1 is saved. There's a prompt to save item 3.
|
||||||
pane.read_with(cx, |pane, cx| {
|
pane.read_with(cx, |pane, cx| {
|
||||||
assert_eq!(item1.read(cx).save_count, 1);
|
assert_eq!(item1.read(cx).save_count, 1);
|
||||||
assert_eq!(item1.read(cx).save_as_count, 0);
|
assert_eq!(item1.read(cx).save_as_count, 0);
|
||||||
|
@ -3023,9 +3032,13 @@ mod tests {
|
||||||
assert_eq!(pane.items_len(), 3);
|
assert_eq!(pane.items_len(), 3);
|
||||||
assert_eq!(pane.active_item().unwrap().id(), item3.id());
|
assert_eq!(pane.active_item().unwrap().id(), item3.id());
|
||||||
});
|
});
|
||||||
|
assert!(cx.has_pending_prompt(window_id));
|
||||||
|
|
||||||
|
// Cancel saving item 3.
|
||||||
cx.simulate_prompt_answer(window_id, 1);
|
cx.simulate_prompt_answer(window_id, 1);
|
||||||
cx.foreground().run_until_parked();
|
cx.foreground().run_until_parked();
|
||||||
|
|
||||||
|
// Item 3 is reloaded. There's a prompt to save item 4.
|
||||||
pane.read_with(cx, |pane, cx| {
|
pane.read_with(cx, |pane, cx| {
|
||||||
assert_eq!(item3.read(cx).save_count, 0);
|
assert_eq!(item3.read(cx).save_count, 0);
|
||||||
assert_eq!(item3.read(cx).save_as_count, 0);
|
assert_eq!(item3.read(cx).save_as_count, 0);
|
||||||
|
@ -3033,11 +3046,17 @@ mod tests {
|
||||||
assert_eq!(pane.items_len(), 2);
|
assert_eq!(pane.items_len(), 2);
|
||||||
assert_eq!(pane.active_item().unwrap().id(), item4.id());
|
assert_eq!(pane.active_item().unwrap().id(), item4.id());
|
||||||
});
|
});
|
||||||
|
assert!(cx.has_pending_prompt(window_id));
|
||||||
|
|
||||||
|
// Confirm saving item 4.
|
||||||
cx.simulate_prompt_answer(window_id, 0);
|
cx.simulate_prompt_answer(window_id, 0);
|
||||||
cx.foreground().run_until_parked();
|
cx.foreground().run_until_parked();
|
||||||
|
|
||||||
|
// There's a prompt for a path for item 4.
|
||||||
cx.simulate_new_path_selection(|_| Some(Default::default()));
|
cx.simulate_new_path_selection(|_| Some(Default::default()));
|
||||||
close_items.await.unwrap();
|
close_items.await.unwrap();
|
||||||
|
|
||||||
|
// The requested items are closed.
|
||||||
pane.read_with(cx, |pane, cx| {
|
pane.read_with(cx, |pane, cx| {
|
||||||
assert_eq!(item4.read(cx).save_count, 0);
|
assert_eq!(item4.read(cx).save_count, 0);
|
||||||
assert_eq!(item4.read(cx).save_as_count, 1);
|
assert_eq!(item4.read(cx).save_as_count, 1);
|
||||||
|
@ -3063,10 +3082,13 @@ mod tests {
|
||||||
let single_entry_items = (0..=4)
|
let single_entry_items = (0..=4)
|
||||||
.map(|project_entry_id| {
|
.map(|project_entry_id| {
|
||||||
cx.add_view(&workspace, |cx| {
|
cx.add_view(&workspace, |cx| {
|
||||||
TestItem::new().with_dirty(true).with_project_items(
|
TestItem::new()
|
||||||
&[(project_entry_id, &format!("{project_entry_id}.txt"))],
|
.with_dirty(true)
|
||||||
cx,
|
.with_project_items(&[TestProjectItem::new(
|
||||||
)
|
project_entry_id,
|
||||||
|
&format!("{project_entry_id}.txt"),
|
||||||
|
cx,
|
||||||
|
)])
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
.collect::<Vec<_>>();
|
.collect::<Vec<_>>();
|
||||||
|
@ -3074,13 +3096,19 @@ mod tests {
|
||||||
TestItem::new()
|
TestItem::new()
|
||||||
.with_dirty(true)
|
.with_dirty(true)
|
||||||
.with_singleton(false)
|
.with_singleton(false)
|
||||||
.with_project_items(&[(2, "2.txt"), (3, "3.txt")], cx)
|
.with_project_items(&[
|
||||||
|
single_entry_items[2].read(cx).project_items[0].clone(),
|
||||||
|
single_entry_items[3].read(cx).project_items[0].clone(),
|
||||||
|
])
|
||||||
});
|
});
|
||||||
let item_3_4 = cx.add_view(&workspace, |cx| {
|
let item_3_4 = cx.add_view(&workspace, |cx| {
|
||||||
TestItem::new()
|
TestItem::new()
|
||||||
.with_dirty(true)
|
.with_dirty(true)
|
||||||
.with_singleton(false)
|
.with_singleton(false)
|
||||||
.with_project_items(&[(3, "3.txt"), (4, "4.txt")], cx)
|
.with_project_items(&[
|
||||||
|
single_entry_items[3].read(cx).project_items[0].clone(),
|
||||||
|
single_entry_items[4].read(cx).project_items[0].clone(),
|
||||||
|
])
|
||||||
});
|
});
|
||||||
|
|
||||||
// Create two panes that contain the following project entries:
|
// Create two panes that contain the following project entries:
|
||||||
|
@ -3159,7 +3187,7 @@ mod tests {
|
||||||
});
|
});
|
||||||
|
|
||||||
let item = cx.add_view(&workspace, |cx| {
|
let item = cx.add_view(&workspace, |cx| {
|
||||||
TestItem::new().with_project_items(&[(1, "1.txt")], cx)
|
TestItem::new().with_project_items(&[TestProjectItem::new(1, "1.txt", cx)])
|
||||||
});
|
});
|
||||||
let item_id = item.id();
|
let item_id = item.id();
|
||||||
workspace.update(cx, |workspace, cx| {
|
workspace.update(cx, |workspace, cx| {
|
||||||
|
@ -3278,7 +3306,7 @@ mod tests {
|
||||||
});
|
});
|
||||||
|
|
||||||
let item = cx.add_view(&workspace, |cx| {
|
let item = cx.add_view(&workspace, |cx| {
|
||||||
TestItem::new().with_project_items(&[(1, "1.txt")], cx)
|
TestItem::new().with_project_items(&[TestProjectItem::new(1, "1.txt", cx)])
|
||||||
});
|
});
|
||||||
let pane = workspace.read_with(cx, |workspace, _| workspace.active_pane().clone());
|
let pane = workspace.read_with(cx, |workspace, _| workspace.active_pane().clone());
|
||||||
let toolbar = pane.read_with(cx, |pane, _| pane.toolbar().clone());
|
let toolbar = pane.read_with(cx, |pane, _| pane.toolbar().clone());
|
||||||
|
|
Loading…
Reference in a new issue