aboutsummaryrefslogtreecommitdiff
path: root/roomserver/storage/tables/rooms_table_test.go
diff options
context:
space:
mode:
authorTill <2353100+S7evinK@users.noreply.github.com>2022-05-16 19:33:16 +0200
committerGitHub <noreply@github.com>2022-05-16 19:33:16 +0200
commit05607d6b8734738bd5c32288e3d0ef8e827d11d0 (patch)
treeaa8bd7f8ad005b1a2218eebbd7ebeff7b823ae01 /roomserver/storage/tables/rooms_table_test.go
parent6af35385ba06f75610396b91452cbf381c1f5443 (diff)
Add roomserver tests (3/4) (#2447)
* Add Room Aliases tests * Add Rooms table test * Move StateKeyTuplerSorter to the types package * Add StateBlock tests Some optimizations * Add State Snapshot tests Some optimization * Return []int64 and convert to pq.Int64Array for postgres * Move []types.EventNID back to rows.Next() * Update tests, rename SelectRoomIDs
Diffstat (limited to 'roomserver/storage/tables/rooms_table_test.go')
-rw-r--r--roomserver/storage/tables/rooms_table_test.go128
1 files changed, 128 insertions, 0 deletions
diff --git a/roomserver/storage/tables/rooms_table_test.go b/roomserver/storage/tables/rooms_table_test.go
new file mode 100644
index 00000000..9872fb80
--- /dev/null
+++ b/roomserver/storage/tables/rooms_table_test.go
@@ -0,0 +1,128 @@
+package tables_test
+
+import (
+ "context"
+ "testing"
+
+ "github.com/matrix-org/dendrite/internal/sqlutil"
+ "github.com/matrix-org/dendrite/roomserver/storage/postgres"
+ "github.com/matrix-org/dendrite/roomserver/storage/sqlite3"
+ "github.com/matrix-org/dendrite/roomserver/storage/tables"
+ "github.com/matrix-org/dendrite/roomserver/types"
+ "github.com/matrix-org/dendrite/setup/config"
+ "github.com/matrix-org/dendrite/test"
+ "github.com/matrix-org/util"
+ "github.com/stretchr/testify/assert"
+)
+
+func mustCreateRoomsTable(t *testing.T, dbType test.DBType) (tab tables.Rooms, close func()) {
+ t.Helper()
+ connStr, close := test.PrepareDBConnectionString(t, dbType)
+ db, err := sqlutil.Open(&config.DatabaseOptions{
+ ConnectionString: config.DataSource(connStr),
+ }, sqlutil.NewExclusiveWriter())
+ assert.NoError(t, err)
+ switch dbType {
+ case test.DBTypePostgres:
+ err = postgres.CreateRoomsTable(db)
+ assert.NoError(t, err)
+ tab, err = postgres.PrepareRoomsTable(db)
+ case test.DBTypeSQLite:
+ err = sqlite3.CreateRoomsTable(db)
+ assert.NoError(t, err)
+ tab, err = sqlite3.PrepareRoomsTable(db)
+ }
+ assert.NoError(t, err)
+
+ return tab, close
+}
+
+func TestRoomsTable(t *testing.T) {
+ alice := test.NewUser()
+ room := test.NewRoom(t, alice)
+ ctx := context.Background()
+ test.WithAllDatabases(t, func(t *testing.T, dbType test.DBType) {
+ tab, close := mustCreateRoomsTable(t, dbType)
+ defer close()
+
+ wantRoomNID, err := tab.InsertRoomNID(ctx, nil, room.ID, room.Version)
+ assert.NoError(t, err)
+
+ // Create dummy room
+ _, err = tab.InsertRoomNID(ctx, nil, util.RandomString(16), room.Version)
+ assert.NoError(t, err)
+
+ gotRoomNID, err := tab.SelectRoomNID(ctx, nil, room.ID)
+ assert.NoError(t, err)
+ assert.Equal(t, wantRoomNID, gotRoomNID)
+
+ // Ensure non existent roomNID errors
+ roomNID, err := tab.SelectRoomNID(ctx, nil, "!doesnotexist:localhost")
+ assert.Error(t, err)
+ assert.Equal(t, types.RoomNID(0), roomNID)
+
+ roomInfo, err := tab.SelectRoomInfo(ctx, nil, room.ID)
+ assert.NoError(t, err)
+ assert.Equal(t, &types.RoomInfo{
+ RoomNID: wantRoomNID,
+ RoomVersion: room.Version,
+ StateSnapshotNID: 0,
+ IsStub: true, // there are no latestEventNIDs
+ }, roomInfo)
+
+ roomInfo, err = tab.SelectRoomInfo(ctx, nil, "!doesnotexist:localhost")
+ assert.NoError(t, err)
+ assert.Nil(t, roomInfo)
+
+ // There are no rooms with latestEventNIDs yet
+ roomIDs, err := tab.SelectRoomIDsWithEvents(ctx, nil)
+ assert.NoError(t, err)
+ assert.Equal(t, 0, len(roomIDs))
+
+ roomVersions, err := tab.SelectRoomVersionsForRoomNIDs(ctx, nil, []types.RoomNID{wantRoomNID, 1337})
+ assert.NoError(t, err)
+ assert.Equal(t, roomVersions[wantRoomNID], room.Version)
+ // Room does not exist
+ _, ok := roomVersions[1337]
+ assert.False(t, ok)
+
+ roomIDs, err = tab.BulkSelectRoomIDs(ctx, nil, []types.RoomNID{wantRoomNID, 1337})
+ assert.NoError(t, err)
+ assert.Equal(t, []string{room.ID}, roomIDs)
+
+ roomNIDs, err := tab.BulkSelectRoomNIDs(ctx, nil, []string{room.ID, "!doesnotexist:localhost"})
+ assert.NoError(t, err)
+ assert.Equal(t, []types.RoomNID{wantRoomNID}, roomNIDs)
+
+ wantEventNIDs := []types.EventNID{1, 2, 3}
+ lastEventSentNID := types.EventNID(3)
+ stateSnapshotNID := types.StateSnapshotNID(1)
+ // make the room "usable"
+ err = tab.UpdateLatestEventNIDs(ctx, nil, wantRoomNID, wantEventNIDs, lastEventSentNID, stateSnapshotNID)
+ assert.NoError(t, err)
+
+ roomInfo, err = tab.SelectRoomInfo(ctx, nil, room.ID)
+ assert.NoError(t, err)
+ assert.Equal(t, &types.RoomInfo{
+ RoomNID: wantRoomNID,
+ RoomVersion: room.Version,
+ StateSnapshotNID: 1,
+ IsStub: false,
+ }, roomInfo)
+
+ eventNIDs, snapshotNID, err := tab.SelectLatestEventNIDs(ctx, nil, wantRoomNID)
+ assert.NoError(t, err)
+ assert.Equal(t, wantEventNIDs, eventNIDs)
+ assert.Equal(t, types.StateSnapshotNID(1), snapshotNID)
+
+ // Again, doesn't exist
+ _, _, err = tab.SelectLatestEventNIDs(ctx, nil, 1337)
+ assert.Error(t, err)
+
+ eventNIDs, eventNID, snapshotNID, err := tab.SelectLatestEventsNIDsForUpdate(ctx, nil, wantRoomNID)
+ assert.NoError(t, err)
+ assert.Equal(t, wantEventNIDs, eventNIDs)
+ assert.Equal(t, types.EventNID(3), eventNID)
+ assert.Equal(t, types.StateSnapshotNID(1), snapshotNID)
+ })
+}