mirror of
https://github.com/zed-industries/zed.git
synced 2025-01-11 21:13:02 +00:00
Fix busy status when accepting a contact request
Previously, we would send an contact update when accepting a request using the same `busy` status for both the requester and the responder. This was obviously wrong and caused the requester to see their own busy status as the newly-added responder contact's status.
This commit is contained in:
parent
f1b35981c2
commit
fc7b01b74e
2 changed files with 85 additions and 11 deletions
|
@ -4188,18 +4188,21 @@ async fn test_contacts(
|
|||
cx_a: &mut TestAppContext,
|
||||
cx_b: &mut TestAppContext,
|
||||
cx_c: &mut TestAppContext,
|
||||
cx_d: &mut TestAppContext,
|
||||
) {
|
||||
cx_a.foreground().forbid_parking();
|
||||
let mut server = TestServer::start(cx_a.background()).await;
|
||||
let client_a = server.create_client(cx_a, "user_a").await;
|
||||
let client_b = server.create_client(cx_b, "user_b").await;
|
||||
let client_c = server.create_client(cx_c, "user_c").await;
|
||||
let client_d = server.create_client(cx_d, "user_d").await;
|
||||
server
|
||||
.make_contacts(&mut [(&client_a, cx_a), (&client_b, cx_b), (&client_c, cx_c)])
|
||||
.await;
|
||||
let active_call_a = cx_a.read(ActiveCall::global);
|
||||
let active_call_b = cx_b.read(ActiveCall::global);
|
||||
let active_call_c = cx_c.read(ActiveCall::global);
|
||||
let _active_call_d = cx_d.read(ActiveCall::global);
|
||||
|
||||
deterministic.run_until_parked();
|
||||
assert_eq!(
|
||||
|
@ -4223,6 +4226,7 @@ async fn test_contacts(
|
|||
("user_b".to_string(), "online", "free")
|
||||
]
|
||||
);
|
||||
assert_eq!(contacts(&client_d, cx_d), []);
|
||||
|
||||
server.disconnect_client(client_c.peer_id().unwrap());
|
||||
server.forbid_connections();
|
||||
|
@ -4242,6 +4246,7 @@ async fn test_contacts(
|
|||
]
|
||||
);
|
||||
assert_eq!(contacts(&client_c, cx_c), []);
|
||||
assert_eq!(contacts(&client_d, cx_d), []);
|
||||
|
||||
server.allow_connections();
|
||||
client_c
|
||||
|
@ -4271,6 +4276,7 @@ async fn test_contacts(
|
|||
("user_b".to_string(), "online", "free")
|
||||
]
|
||||
);
|
||||
assert_eq!(contacts(&client_d, cx_d), []);
|
||||
|
||||
active_call_a
|
||||
.update(cx_a, |call, cx| {
|
||||
|
@ -4300,6 +4306,39 @@ async fn test_contacts(
|
|||
("user_b".to_string(), "online", "busy")
|
||||
]
|
||||
);
|
||||
assert_eq!(contacts(&client_d, cx_d), []);
|
||||
|
||||
// Client B and client D become contacts while client B is being called.
|
||||
server
|
||||
.make_contacts(&mut [(&client_b, cx_b), (&client_d, cx_d)])
|
||||
.await;
|
||||
deterministic.run_until_parked();
|
||||
assert_eq!(
|
||||
contacts(&client_a, cx_a),
|
||||
[
|
||||
("user_b".to_string(), "online", "busy"),
|
||||
("user_c".to_string(), "online", "free")
|
||||
]
|
||||
);
|
||||
assert_eq!(
|
||||
contacts(&client_b, cx_b),
|
||||
[
|
||||
("user_a".to_string(), "online", "busy"),
|
||||
("user_c".to_string(), "online", "free"),
|
||||
("user_d".to_string(), "online", "free"),
|
||||
]
|
||||
);
|
||||
assert_eq!(
|
||||
contacts(&client_c, cx_c),
|
||||
[
|
||||
("user_a".to_string(), "online", "busy"),
|
||||
("user_b".to_string(), "online", "busy")
|
||||
]
|
||||
);
|
||||
assert_eq!(
|
||||
contacts(&client_d, cx_d),
|
||||
[("user_b".to_string(), "online", "busy")]
|
||||
);
|
||||
|
||||
active_call_b.update(cx_b, |call, _| call.decline_incoming().unwrap());
|
||||
deterministic.run_until_parked();
|
||||
|
@ -4314,7 +4353,8 @@ async fn test_contacts(
|
|||
contacts(&client_b, cx_b),
|
||||
[
|
||||
("user_a".to_string(), "online", "free"),
|
||||
("user_c".to_string(), "online", "free")
|
||||
("user_c".to_string(), "online", "free"),
|
||||
("user_d".to_string(), "online", "free")
|
||||
]
|
||||
);
|
||||
assert_eq!(
|
||||
|
@ -4324,6 +4364,10 @@ async fn test_contacts(
|
|||
("user_b".to_string(), "online", "free")
|
||||
]
|
||||
);
|
||||
assert_eq!(
|
||||
contacts(&client_d, cx_d),
|
||||
[("user_b".to_string(), "online", "free")]
|
||||
);
|
||||
|
||||
active_call_c
|
||||
.update(cx_c, |call, cx| {
|
||||
|
@ -4343,7 +4387,8 @@ async fn test_contacts(
|
|||
contacts(&client_b, cx_b),
|
||||
[
|
||||
("user_a".to_string(), "online", "busy"),
|
||||
("user_c".to_string(), "online", "busy")
|
||||
("user_c".to_string(), "online", "busy"),
|
||||
("user_d".to_string(), "online", "free")
|
||||
]
|
||||
);
|
||||
assert_eq!(
|
||||
|
@ -4353,6 +4398,10 @@ async fn test_contacts(
|
|||
("user_b".to_string(), "online", "free")
|
||||
]
|
||||
);
|
||||
assert_eq!(
|
||||
contacts(&client_d, cx_d),
|
||||
[("user_b".to_string(), "online", "free")]
|
||||
);
|
||||
|
||||
active_call_a
|
||||
.update(cx_a, |call, cx| call.accept_incoming(cx))
|
||||
|
@ -4370,7 +4419,8 @@ async fn test_contacts(
|
|||
contacts(&client_b, cx_b),
|
||||
[
|
||||
("user_a".to_string(), "online", "busy"),
|
||||
("user_c".to_string(), "online", "busy")
|
||||
("user_c".to_string(), "online", "busy"),
|
||||
("user_d".to_string(), "online", "free")
|
||||
]
|
||||
);
|
||||
assert_eq!(
|
||||
|
@ -4380,6 +4430,10 @@ async fn test_contacts(
|
|||
("user_b".to_string(), "online", "free")
|
||||
]
|
||||
);
|
||||
assert_eq!(
|
||||
contacts(&client_d, cx_d),
|
||||
[("user_b".to_string(), "online", "free")]
|
||||
);
|
||||
|
||||
active_call_a
|
||||
.update(cx_a, |call, cx| {
|
||||
|
@ -4399,7 +4453,8 @@ async fn test_contacts(
|
|||
contacts(&client_b, cx_b),
|
||||
[
|
||||
("user_a".to_string(), "online", "busy"),
|
||||
("user_c".to_string(), "online", "busy")
|
||||
("user_c".to_string(), "online", "busy"),
|
||||
("user_d".to_string(), "online", "free")
|
||||
]
|
||||
);
|
||||
assert_eq!(
|
||||
|
@ -4409,6 +4464,10 @@ async fn test_contacts(
|
|||
("user_b".to_string(), "online", "busy")
|
||||
]
|
||||
);
|
||||
assert_eq!(
|
||||
contacts(&client_d, cx_d),
|
||||
[("user_b".to_string(), "online", "busy")]
|
||||
);
|
||||
|
||||
active_call_a.update(cx_a, |call, cx| call.hang_up(cx).unwrap());
|
||||
deterministic.run_until_parked();
|
||||
|
@ -4423,7 +4482,8 @@ async fn test_contacts(
|
|||
contacts(&client_b, cx_b),
|
||||
[
|
||||
("user_a".to_string(), "online", "free"),
|
||||
("user_c".to_string(), "online", "free")
|
||||
("user_c".to_string(), "online", "free"),
|
||||
("user_d".to_string(), "online", "free")
|
||||
]
|
||||
);
|
||||
assert_eq!(
|
||||
|
@ -4433,6 +4493,10 @@ async fn test_contacts(
|
|||
("user_b".to_string(), "online", "free")
|
||||
]
|
||||
);
|
||||
assert_eq!(
|
||||
contacts(&client_d, cx_d),
|
||||
[("user_b".to_string(), "online", "free")]
|
||||
);
|
||||
|
||||
active_call_a
|
||||
.update(cx_a, |call, cx| {
|
||||
|
@ -4452,7 +4516,8 @@ async fn test_contacts(
|
|||
contacts(&client_b, cx_b),
|
||||
[
|
||||
("user_a".to_string(), "online", "busy"),
|
||||
("user_c".to_string(), "online", "free")
|
||||
("user_c".to_string(), "online", "free"),
|
||||
("user_d".to_string(), "online", "free")
|
||||
]
|
||||
);
|
||||
assert_eq!(
|
||||
|
@ -4462,6 +4527,10 @@ async fn test_contacts(
|
|||
("user_b".to_string(), "online", "busy")
|
||||
]
|
||||
);
|
||||
assert_eq!(
|
||||
contacts(&client_d, cx_d),
|
||||
[("user_b".to_string(), "online", "busy")]
|
||||
);
|
||||
|
||||
server.forbid_connections();
|
||||
server.disconnect_client(client_a.peer_id().unwrap());
|
||||
|
@ -4471,7 +4540,8 @@ async fn test_contacts(
|
|||
contacts(&client_b, cx_b),
|
||||
[
|
||||
("user_a".to_string(), "offline", "free"),
|
||||
("user_c".to_string(), "online", "free")
|
||||
("user_c".to_string(), "online", "free"),
|
||||
("user_d".to_string(), "online", "free")
|
||||
]
|
||||
);
|
||||
assert_eq!(
|
||||
|
@ -4481,8 +4551,11 @@ async fn test_contacts(
|
|||
("user_b".to_string(), "online", "free")
|
||||
]
|
||||
);
|
||||
assert_eq!(
|
||||
contacts(&client_d, cx_d),
|
||||
[("user_b".to_string(), "online", "free")]
|
||||
);
|
||||
|
||||
#[allow(clippy::type_complexity)]
|
||||
fn contacts(
|
||||
client: &TestClient,
|
||||
cx: &TestAppContext,
|
||||
|
|
|
@ -1616,7 +1616,8 @@ async fn respond_to_contact_request(
|
|||
|
||||
db.respond_to_contact_request(responder_id, requester_id, accept)
|
||||
.await?;
|
||||
let busy = db.is_user_busy(requester_id).await?;
|
||||
let requester_busy = db.is_user_busy(requester_id).await?;
|
||||
let responder_busy = db.is_user_busy(responder_id).await?;
|
||||
|
||||
let pool = session.connection_pool().await;
|
||||
// Update responder with new contact
|
||||
|
@ -1624,7 +1625,7 @@ async fn respond_to_contact_request(
|
|||
if accept {
|
||||
update
|
||||
.contacts
|
||||
.push(contact_for_user(requester_id, false, busy, &pool));
|
||||
.push(contact_for_user(requester_id, false, requester_busy, &pool));
|
||||
}
|
||||
update
|
||||
.remove_incoming_requests
|
||||
|
@ -1638,7 +1639,7 @@ async fn respond_to_contact_request(
|
|||
if accept {
|
||||
update
|
||||
.contacts
|
||||
.push(contact_for_user(responder_id, true, busy, &pool));
|
||||
.push(contact_for_user(responder_id, true, responder_busy, &pool));
|
||||
}
|
||||
update
|
||||
.remove_outgoing_requests
|
||||
|
|
Loading…
Reference in a new issue