fix(channel): member delete acts as leave; add coverage and docs
All checks were successful
CI / test (push) Successful in 42s
All checks were successful
CI / test (push) Successful in 42s
This commit is contained in:
@@ -126,6 +126,42 @@ async def test_group_ban_blocks_rejoin(client, db_session):
|
||||
assert rejoin_response.status_code == 403
|
||||
|
||||
|
||||
async def test_channel_member_delete_chat_behaves_as_leave(client, db_session):
|
||||
owner = await _create_verified_user(client, db_session, "channel_owner@example.com", "channel_owner", "strongpass123")
|
||||
member = await _create_verified_user(client, db_session, "channel_member@example.com", "channel_member", "strongpass123")
|
||||
|
||||
me_member = await client.get("/api/v1/auth/me", headers={"Authorization": f"Bearer {member['access_token']}"})
|
||||
member_id = me_member.json()["id"]
|
||||
|
||||
create_channel = await client.post(
|
||||
"/api/v1/chats",
|
||||
headers={"Authorization": f"Bearer {owner['access_token']}"},
|
||||
json={"type": ChatType.CHANNEL.value, "title": "Test channel", "member_ids": [member_id]},
|
||||
)
|
||||
assert create_channel.status_code == 200
|
||||
chat_id = create_channel.json()["id"]
|
||||
|
||||
delete_by_member = await client.delete(
|
||||
f"/api/v1/chats/{chat_id}",
|
||||
headers={"Authorization": f"Bearer {member['access_token']}"},
|
||||
)
|
||||
assert delete_by_member.status_code == 204
|
||||
|
||||
member_chats = await client.get(
|
||||
"/api/v1/chats",
|
||||
headers={"Authorization": f"Bearer {member['access_token']}"},
|
||||
)
|
||||
assert member_chats.status_code == 200
|
||||
assert all(chat["id"] != chat_id for chat in member_chats.json())
|
||||
|
||||
owner_chats = await client.get(
|
||||
"/api/v1/chats",
|
||||
headers={"Authorization": f"Bearer {owner['access_token']}"},
|
||||
)
|
||||
assert owner_chats.status_code == 200
|
||||
assert any(chat["id"] == chat_id for chat in owner_chats.json())
|
||||
|
||||
|
||||
async def test_group_invite_privacy_contacts_only(client, db_session):
|
||||
inviter = await _create_verified_user(client, db_session, "invite_u1@example.com", "invite_u1", "strongpass123")
|
||||
target = await _create_verified_user(client, db_session, "invite_u2@example.com", "invite_u2", "strongpass123")
|
||||
|
||||
Reference in New Issue
Block a user