Skip to content

Commit

Permalink
Add a test for 'The room key is cycled when rotation_period_msgs is met'
Browse files Browse the repository at this point in the history
  • Loading branch information
andybalaam committed Mar 1, 2024
1 parent 6b71f80 commit 3c49b2a
Show file tree
Hide file tree
Showing 2 changed files with 69 additions and 2 deletions.
4 changes: 2 additions & 2 deletions TEST_HITLIST.md
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,7 @@ Network connectivity tests are extremely time sensitive as retries are often usi
- [x] If a client cannot upload OTKs, it retries.
- [x] If a client cannot claim OTKs, it retries.
- [x] If a server cannot send device list updates over federation, it retries. https://github.com/matrix-org/complement/pull/695
- [x] If a client cannot query device keys for a user, it retries.
- [x] If a client cannot query device keys for a user, it retries. (TestFailedDeviceKeyDownloadRetries)
- [ ] If a server cannot query device keys on another server, it retries.
- [x] If a client cannot send a to-device msg, it retries.
- [x] If a server cannot send a to-device msg to another server, it retries. https://github.com/matrix-org/complement/pull/694
Expand All @@ -98,7 +98,7 @@ This refers to cases where the client has some state and wishes to synchronise i
- [ ] The room key is cycled when one of a user's devices is blacklisted.
- [ ] The room key is cycled when history visibility changes to something more restrictive TODO: define precisely.
- [ ] The room key is cycled when the encryption algorithm changes.
- [ ] The room key is cycled when `rotation_period_msgs` is met (default: 100).
- [x] The room key is cycled when `rotation_period_msgs` is met (default: 100). (TestRoomKeyIsCycledAfterEnoughMessages)
- [ ] The room key is cycled when `rotation_period_ms` is exceeded (default: 1 week).
- [x] The room key is not cycled when one of a user's devices logs in.
- [x] The room key is not cycled when the client restarts.
Expand Down
67 changes: 67 additions & 0 deletions tests/room_keys_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -91,6 +91,73 @@ func TestRoomKeyIsCycledOnDeviceLogout(t *testing.T) {
})
}

// The room key is cycled when `rotation_period_msgs` is met (default: 100).
//
// This test ensures we change the m.room_key when we have sent enough messages,
// where "enough" means the value set in the `m.room.encryption` event under the
// `rotation_period_msgs` property.
//
// If the key were not changed, someone who stole the key would have access to
// future messages.
func TestRoomKeyIsCycledAfterEnoughMessages(t *testing.T) {
ClientTypeMatrix(t, func(t *testing.T, clientTypeA, clientTypeB api.ClientType) {
// Given a room containing Alice and Bob
tc := CreateTestContext(t, clientTypeA, clientTypeB)
roomID := tc.CreateNewEncryptedRoom(
t,
tc.Alice,
"trusted_private_chat",
[]string{tc.Bob.UserID},
map[string]interface{}{
"algorithm": "m.megolm.v1.aes-sha2",
"rotation_period_msgs": 5,
},
)
tc.Bob.MustJoinRoom(t, roomID, []string{clientTypeA.HS})

tc.WithAliceAndBobSyncing(t, func(alice, bob api.Client) {
// And some messages were sent, but not enough to trigger resending
for i := 0; i < 4; i++ {
wantMsgBody := "Before we hit the threshold"
waiter := bob.WaitUntilEventInRoom(t, roomID, api.CheckEventHasBody(wantMsgBody))
alice.SendMessage(t, roomID, wantMsgBody)
waiter.Wait(t, 5*time.Second)
}

// Sniff calls to /sendToDevice to ensure we see the new room key being sent.
ch := make(chan deploy.CallbackData, 10)
callbackURL, close := sniffToDeviceEvent(t, tc.Deployment, ch)
defer close()
tc.Deployment.WithMITMOptions(t, map[string]interface{}{
"callback": map[string]interface{}{
"callback_url": callbackURL,
"filter": "~u .*\\/sendToDevice.*",
},
}, func() {
wantMsgBody := "This one hits the threshold"
// When we send two messages (one to hit the threshold and one
// to pass it)
waiter := bob.WaitUntilEventInRoom(t, roomID, api.CheckEventHasBody(wantMsgBody))
alice.SendMessage(t, roomID, wantMsgBody)
waiter.Wait(t, 5*time.Second)

wantMsgBody = "After the threshold"
waiter = bob.WaitUntilEventInRoom(t, roomID, api.CheckEventHasBody(wantMsgBody))
alice.SendMessage(t, roomID, wantMsgBody)
waiter.Wait(t, 5*time.Second)
})

// Then we did send out new keys
select {
case <-ch:
// Success - keys were sent
default:
ct.Fatalf(t, "did not see /sendToDevice after sending rotation_period_msgs messages")
}
})
})
}

func TestRoomKeyIsCycledOnMemberLeaving(t *testing.T) {
ClientTypeMatrix(t, func(t *testing.T, clientTypeA, clientTypeB api.ClientType) {
tc := CreateTestContext(t, clientTypeA, clientTypeB, clientTypeB)
Expand Down

0 comments on commit 3c49b2a

Please sign in to comment.