Revert "Wait for previous UpdateFollowers message ack before sending new ones"

This reverts commit fe93263ad4.
This commit is contained in:
Antonio Scandurra 2022-11-17 16:57:32 +01:00
parent 8621c88a3c
commit e7e45be6e1
4 changed files with 57 additions and 106 deletions

View file

@ -4672,7 +4672,7 @@ async fn test_following(
cx_a: &mut TestAppContext, cx_a: &mut TestAppContext,
cx_b: &mut TestAppContext, cx_b: &mut TestAppContext,
) { ) {
deterministic.forbid_parking(); cx_a.foreground().forbid_parking();
cx_a.update(editor::init); cx_a.update(editor::init);
cx_b.update(editor::init); cx_b.update(editor::init);
@ -4791,14 +4791,11 @@ async fn test_following(
workspace_a.update(cx_a, |workspace, cx| { workspace_a.update(cx_a, |workspace, cx| {
workspace.activate_item(&editor_a1, cx) workspace.activate_item(&editor_a1, cx)
}); });
deterministic.run_until_parked(); workspace_b
assert_eq!( .condition(cx_b, |workspace, cx| {
workspace_b.read_with(cx_b, |workspace, cx| workspace workspace.active_item(cx).unwrap().id() == editor_b1.id()
.active_item(cx) })
.unwrap() .await;
.id()),
editor_b1.id()
);
// When client A navigates back and forth, client B does so as well. // When client A navigates back and forth, client B does so as well.
workspace_a workspace_a
@ -4806,74 +4803,49 @@ async fn test_following(
workspace::Pane::go_back(workspace, None, cx) workspace::Pane::go_back(workspace, None, cx)
}) })
.await; .await;
deterministic.run_until_parked(); workspace_b
assert_eq!( .condition(cx_b, |workspace, cx| {
workspace_b.read_with(cx_b, |workspace, cx| workspace workspace.active_item(cx).unwrap().id() == editor_b2.id()
.active_item(cx) })
.unwrap() .await;
.id()),
editor_b2.id()
);
workspace_a workspace_a
.update(cx_a, |workspace, cx| { .update(cx_a, |workspace, cx| {
workspace::Pane::go_forward(workspace, None, cx) workspace::Pane::go_forward(workspace, None, cx)
}) })
.await; .await;
workspace_a workspace_b
.update(cx_a, |workspace, cx| { .condition(cx_b, |workspace, cx| {
workspace::Pane::go_back(workspace, None, cx) workspace.active_item(cx).unwrap().id() == editor_b1.id()
}) })
.await; .await;
workspace_a
.update(cx_a, |workspace, cx| {
workspace::Pane::go_forward(workspace, None, cx)
})
.await;
deterministic.run_until_parked();
assert_eq!(
workspace_b.read_with(cx_b, |workspace, cx| workspace
.active_item(cx)
.unwrap()
.id()),
editor_b1.id()
);
// Changes to client A's editor are reflected on client B. // Changes to client A's editor are reflected on client B.
editor_a1.update(cx_a, |editor, cx| { editor_a1.update(cx_a, |editor, cx| {
editor.change_selections(None, cx, |s| s.select_ranges([1..1, 2..2])); editor.change_selections(None, cx, |s| s.select_ranges([1..1, 2..2]));
}); });
deterministic.run_until_parked(); editor_b1
assert_eq!( .condition(cx_b, |editor, cx| {
editor_b1.read_with(cx_b, |editor, cx| editor.selections.ranges(cx)), editor.selections.ranges(cx) == vec![1..1, 2..2]
vec![1..1, 2..2] })
); .await;
editor_a1.update(cx_a, |editor, cx| editor.set_text("TWO", cx)); editor_a1.update(cx_a, |editor, cx| editor.set_text("TWO", cx));
deterministic.run_until_parked(); editor_b1
assert_eq!( .condition(cx_b, |editor, cx| editor.text(cx) == "TWO")
editor_b1.read_with(cx_b, |editor, cx| editor.text(cx)), .await;
"TWO"
);
editor_a1.update(cx_a, |editor, cx| { editor_a1.update(cx_a, |editor, cx| {
editor.change_selections(None, cx, |s| s.select_ranges([3..3])); editor.change_selections(None, cx, |s| s.select_ranges([3..3]));
editor.set_scroll_position(vec2f(0., 100.), cx); editor.set_scroll_position(vec2f(0., 100.), cx);
}); });
deterministic.run_until_parked(); editor_b1
assert_eq!( .condition(cx_b, |editor, cx| {
editor_b1.read_with(cx_b, |editor, cx| editor.selections.ranges(cx)), editor.selections.ranges(cx) == vec![3..3]
vec![3..3] })
); .await;
// After unfollowing, client B stops receiving updates from client A. // After unfollowing, client B stops receiving updates from client A.
assert_eq!(
workspace_b.read_with(cx_b, |workspace, cx| workspace
.active_item(cx)
.unwrap()
.id()),
editor_b1.id()
);
workspace_b.update(cx_b, |workspace, cx| { workspace_b.update(cx_b, |workspace, cx| {
workspace.unfollow(&workspace.active_pane().clone(), cx) workspace.unfollow(&workspace.active_pane().clone(), cx)
}); });

View file

@ -192,7 +192,7 @@ impl Server {
.add_request_handler(Server::respond_to_contact_request) .add_request_handler(Server::respond_to_contact_request)
.add_request_handler(Server::follow) .add_request_handler(Server::follow)
.add_message_handler(Server::unfollow) .add_message_handler(Server::unfollow)
.add_request_handler(Server::update_followers) .add_message_handler(Server::update_followers)
.add_message_handler(Server::update_diff_base) .add_message_handler(Server::update_diff_base)
.add_request_handler(Server::get_private_user_info); .add_request_handler(Server::get_private_user_info);
@ -1437,7 +1437,6 @@ impl Server {
async fn update_followers( async fn update_followers(
self: Arc<Self>, self: Arc<Self>,
request: Message<proto::UpdateFollowers>, request: Message<proto::UpdateFollowers>,
response: Response<proto::UpdateFollowers>,
) -> Result<()> { ) -> Result<()> {
let project_id = ProjectId::from_proto(request.payload.project_id); let project_id = ProjectId::from_proto(request.payload.project_id);
let project_connection_ids = self let project_connection_ids = self
@ -1465,7 +1464,6 @@ impl Server {
)?; )?;
} }
} }
response.send(proto::Ack {})?;
Ok(()) Ok(())
} }

View file

@ -229,7 +229,6 @@ request_messages!(
(Test, Test), (Test, Test),
(UpdateBuffer, Ack), (UpdateBuffer, Ack),
(UpdateDiagnosticSummary, Ack), (UpdateDiagnosticSummary, Ack),
(UpdateFollowers, Ack),
(UpdateParticipantLocation, Ack), (UpdateParticipantLocation, Ack),
(UpdateProject, Ack), (UpdateProject, Ack),
(UpdateWorktree, Ack), (UpdateWorktree, Ack),

View file

@ -18,10 +18,7 @@ use collections::{hash_map, HashMap, HashSet};
use dock::{DefaultItemFactory, Dock, ToggleDockButton}; use dock::{DefaultItemFactory, Dock, ToggleDockButton};
use drag_and_drop::DragAndDrop; use drag_and_drop::DragAndDrop;
use fs::{self, Fs}; use fs::{self, Fs};
use futures::{ use futures::{channel::oneshot, FutureExt, StreamExt};
channel::{mpsc, oneshot},
FutureExt, StreamExt,
};
use gpui::{ use gpui::{
actions, actions,
elements::*, elements::*,
@ -714,13 +711,14 @@ impl<T: Item> ItemHandle for ViewHandle<T> {
if let Some(followed_item) = self.to_followable_item_handle(cx) { if let Some(followed_item) = self.to_followable_item_handle(cx) {
if let Some(message) = followed_item.to_state_proto(cx) { if let Some(message) = followed_item.to_state_proto(cx) {
workspace.update_followers(proto::update_followers::Variant::CreateView( workspace.update_followers(
proto::View { proto::update_followers::Variant::CreateView(proto::View {
id: followed_item.id() as u64, id: followed_item.id() as u64,
variant: Some(message), variant: Some(message),
leader_id: workspace.leader_for_pane(&pane).map(|id| id.0), leader_id: workspace.leader_for_pane(&pane).map(|id| id.0),
}, }),
)); cx,
);
} }
} }
@ -764,7 +762,7 @@ impl<T: Item> ItemHandle for ViewHandle<T> {
cx.after_window_update({ cx.after_window_update({
let pending_update = pending_update.clone(); let pending_update = pending_update.clone();
let pending_update_scheduled = pending_update_scheduled.clone(); let pending_update_scheduled = pending_update_scheduled.clone();
move |this, _| { move |this, cx| {
pending_update_scheduled.store(false, SeqCst); pending_update_scheduled.store(false, SeqCst);
this.update_followers( this.update_followers(
proto::update_followers::Variant::UpdateView( proto::update_followers::Variant::UpdateView(
@ -774,6 +772,7 @@ impl<T: Item> ItemHandle for ViewHandle<T> {
leader_id: leader_id.map(|id| id.0), leader_id: leader_id.map(|id| id.0),
}, },
), ),
cx,
); );
} }
}); });
@ -1082,11 +1081,9 @@ pub struct Workspace {
leader_state: LeaderState, leader_state: LeaderState,
follower_states_by_leader: FollowerStatesByLeader, follower_states_by_leader: FollowerStatesByLeader,
last_leaders_by_pane: HashMap<WeakViewHandle<Pane>, PeerId>, last_leaders_by_pane: HashMap<WeakViewHandle<Pane>, PeerId>,
follower_updates: mpsc::UnboundedSender<proto::update_followers::Variant>,
window_edited: bool, window_edited: bool,
active_call: Option<(ModelHandle<ActiveCall>, Vec<gpui::Subscription>)>, active_call: Option<(ModelHandle<ActiveCall>, Vec<gpui::Subscription>)>,
_observe_current_user: Task<()>, _observe_current_user: Task<()>,
_update_followers: Task<Option<()>>,
} }
#[derive(Default)] #[derive(Default)]
@ -1169,34 +1166,6 @@ impl Workspace {
} }
}); });
let (follower_updates_tx, mut follower_updates_rx) = mpsc::unbounded();
let _update_followers = cx.spawn_weak(|this, cx| async move {
while let Some(update) = follower_updates_rx.next().await {
let this = this.upgrade(&cx)?;
let update_followers = this.read_with(&cx, |this, cx| {
if let Some(project_id) = this.project.read(cx).remote_id() {
if this.leader_state.followers.is_empty() {
None
} else {
Some(this.client.request(proto::UpdateFollowers {
project_id,
follower_ids:
this.leader_state.followers.iter().map(|f| f.0).collect(),
variant: Some(update),
}))
}
} else {
None
}
});
if let Some(update_followers) = update_followers {
update_followers.await.log_err();
}
}
None
});
let handle = cx.handle(); let handle = cx.handle();
let weak_handle = cx.weak_handle(); let weak_handle = cx.weak_handle();
@ -1255,12 +1224,10 @@ impl Workspace {
project, project,
leader_state: Default::default(), leader_state: Default::default(),
follower_states_by_leader: Default::default(), follower_states_by_leader: Default::default(),
follower_updates: follower_updates_tx,
last_leaders_by_pane: Default::default(), last_leaders_by_pane: Default::default(),
window_edited: false, window_edited: false,
active_call, active_call,
_observe_current_user, _observe_current_user,
_update_followers,
}; };
this.project_remote_id_changed(this.project.read(cx).remote_id(), cx); this.project_remote_id_changed(this.project.read(cx).remote_id(), cx);
cx.defer(|this, cx| this.update_window_title(cx)); cx.defer(|this, cx| this.update_window_title(cx));
@ -2000,12 +1967,13 @@ impl Workspace {
cx.notify(); cx.notify();
} }
self.update_followers(proto::update_followers::Variant::UpdateActiveView( self.update_followers(
proto::UpdateActiveView { proto::update_followers::Variant::UpdateActiveView(proto::UpdateActiveView {
id: self.active_item(cx).map(|item| item.id() as u64), id: self.active_item(cx).map(|item| item.id() as u64),
leader_id: self.leader_for_pane(&pane).map(|id| id.0), leader_id: self.leader_for_pane(&pane).map(|id| id.0),
}, }),
)); cx,
);
} }
fn handle_pane_event( fn handle_pane_event(
@ -2626,8 +2594,22 @@ impl Workspace {
Ok(()) Ok(())
} }
fn update_followers(&self, update: proto::update_followers::Variant) { fn update_followers(
let _ = self.follower_updates.unbounded_send(update); &self,
update: proto::update_followers::Variant,
cx: &AppContext,
) -> Option<()> {
let project_id = self.project.read(cx).remote_id()?;
if !self.leader_state.followers.is_empty() {
self.client
.send(proto::UpdateFollowers {
project_id,
follower_ids: self.leader_state.followers.iter().map(|f| f.0).collect(),
variant: Some(update),
})
.log_err();
}
None
} }
pub fn leader_for_pane(&self, pane: &ViewHandle<Pane>) -> Option<PeerId> { pub fn leader_for_pane(&self, pane: &ViewHandle<Pane>) -> Option<PeerId> {