mirror of
https://github.com/matrix-org/sliding-sync.git
synced 2025-03-10 13:37:11 +00:00
Mark log matchers as helpers
This commit is contained in:
parent
867cf68a20
commit
e7e78a6754
@ -3,6 +3,7 @@ package m
|
||||
import (
|
||||
"bytes"
|
||||
"encoding/json"
|
||||
"errors"
|
||||
"fmt"
|
||||
"reflect"
|
||||
"sort"
|
||||
@ -154,6 +155,24 @@ func MatchRoomInviteState(events []json.RawMessage) RoomMatcher {
|
||||
}
|
||||
}
|
||||
|
||||
func MatchRoomHasInviteState() RoomMatcher {
|
||||
return func(r sync3.Room) error {
|
||||
if len(r.InviteState) == 0 {
|
||||
return fmt.Errorf("missing or empty invite state, expected at least one piece of invite state")
|
||||
}
|
||||
return nil
|
||||
}
|
||||
}
|
||||
|
||||
func MatchRoomLacksInviteState() RoomMatcher {
|
||||
return func(r sync3.Room) error {
|
||||
if len(r.InviteState) > 0 {
|
||||
return fmt.Errorf("invite state present, but expected no invite state")
|
||||
}
|
||||
return nil
|
||||
}
|
||||
}
|
||||
|
||||
// Similar to MatchRoomTimeline but takes the last n events of `events` and only checks with the last
|
||||
// n events of the timeline.
|
||||
func MatchRoomTimelineMostRecent(n int, events []json.RawMessage) RoomMatcher {
|
||||
@ -672,6 +691,7 @@ func MatchNoRoomAccountData(roomIDs []string) RespMatcher {
|
||||
// the given sync response to the test log. This is useful when debugging a test.
|
||||
func LogResponse(t *testing.T) RespMatcher {
|
||||
return func(res *sync3.Response) error {
|
||||
t.Helper()
|
||||
dump, _ := json.MarshalIndent(res, "", " ")
|
||||
t.Logf("Response was: %s", dump)
|
||||
return nil
|
||||
@ -681,6 +701,7 @@ func LogResponse(t *testing.T) RespMatcher {
|
||||
// LogRooms is like LogResponse, but only logs the rooms section of the response.
|
||||
func LogRooms(t *testing.T) RespMatcher {
|
||||
return func(res *sync3.Response) error {
|
||||
t.Helper()
|
||||
dump, _ := json.MarshalIndent(res.Rooms, "", " ")
|
||||
t.Logf("Response rooms were: %s", dump)
|
||||
return nil
|
||||
|
Loading…
x
Reference in New Issue
Block a user