2022-12-22 10:56:20 +01:00
|
|
|
package tables_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"reflect"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/matrix-org/dendrite/federationapi/storage/postgres"
|
|
|
|
"github.com/matrix-org/dendrite/federationapi/storage/sqlite3"
|
|
|
|
"github.com/matrix-org/dendrite/federationapi/storage/tables"
|
|
|
|
"github.com/matrix-org/dendrite/internal/sqlutil"
|
|
|
|
"github.com/matrix-org/dendrite/setup/config"
|
|
|
|
"github.com/matrix-org/dendrite/test"
|
|
|
|
"github.com/matrix-org/gomatrixserverlib"
|
|
|
|
"github.com/matrix-org/util"
|
2022-12-22 11:31:54 +01:00
|
|
|
"github.com/stretchr/testify/assert"
|
2022-12-22 10:56:20 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func mustCreateOutboundpeeksTable(t *testing.T, dbType test.DBType) (tables.FederationOutboundPeeks, func()) {
|
|
|
|
connStr, close := test.PrepareDBConnectionString(t, dbType)
|
|
|
|
db, err := sqlutil.Open(&config.DatabaseOptions{
|
|
|
|
ConnectionString: config.DataSource(connStr),
|
|
|
|
}, sqlutil.NewExclusiveWriter())
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed to open database: %s", err)
|
|
|
|
}
|
|
|
|
var tab tables.FederationOutboundPeeks
|
|
|
|
switch dbType {
|
|
|
|
case test.DBTypePostgres:
|
|
|
|
tab, err = postgres.NewPostgresOutboundPeeksTable(db)
|
|
|
|
case test.DBTypeSQLite:
|
|
|
|
tab, err = sqlite3.NewSQLiteOutboundPeeksTable(db)
|
|
|
|
}
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed to create table: %s", err)
|
|
|
|
}
|
|
|
|
return tab, close
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestOutboundPeeksTable(t *testing.T) {
|
|
|
|
ctx := context.Background()
|
|
|
|
alice := test.NewUser(t)
|
|
|
|
room := test.NewRoom(t, alice)
|
|
|
|
_, serverName, _ := gomatrixserverlib.SplitID('@', alice.ID)
|
|
|
|
test.WithAllDatabases(t, func(t *testing.T, dbType test.DBType) {
|
|
|
|
tab, closeDB := mustCreateOutboundpeeksTable(t, dbType)
|
|
|
|
defer closeDB()
|
|
|
|
|
|
|
|
// Insert a peek
|
|
|
|
peekID := util.RandomString(8)
|
|
|
|
var renewalInterval int64 = 1000
|
|
|
|
if err := tab.InsertOutboundPeek(ctx, nil, serverName, room.ID, peekID, renewalInterval); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// select the newly inserted peek
|
|
|
|
outboundPeek1, err := tab.SelectOutboundPeek(ctx, nil, serverName, room.ID, peekID)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Assert fields are set as expected
|
|
|
|
if outboundPeek1.PeekID != peekID {
|
|
|
|
t.Fatalf("unexpected outbound peek ID: %s, want %s", outboundPeek1.PeekID, peekID)
|
|
|
|
}
|
|
|
|
if outboundPeek1.RoomID != room.ID {
|
|
|
|
t.Fatalf("unexpected outbound peek room ID: %s, want %s", outboundPeek1.RoomID, peekID)
|
|
|
|
}
|
|
|
|
if outboundPeek1.ServerName != serverName {
|
|
|
|
t.Fatalf("unexpected outbound peek servername: %s, want %s", outboundPeek1.ServerName, serverName)
|
|
|
|
}
|
|
|
|
if outboundPeek1.RenewalInterval != renewalInterval {
|
|
|
|
t.Fatalf("unexpected outbound peek renewal interval: %d, want %d", outboundPeek1.RenewalInterval, renewalInterval)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Renew the peek
|
|
|
|
if err = tab.RenewOutboundPeek(ctx, nil, serverName, room.ID, peekID, 2000); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// verify the values changed
|
|
|
|
outboundPeek2, err := tab.SelectOutboundPeek(ctx, nil, serverName, room.ID, peekID)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if reflect.DeepEqual(outboundPeek1, outboundPeek2) {
|
|
|
|
t.Fatal("expected a change peek, but they are the same")
|
|
|
|
}
|
|
|
|
if outboundPeek1.ServerName != outboundPeek2.ServerName {
|
|
|
|
t.Fatalf("unexpected servername change: %s -> %s", outboundPeek1.ServerName, outboundPeek2.ServerName)
|
|
|
|
}
|
|
|
|
if outboundPeek1.RoomID != outboundPeek2.RoomID {
|
|
|
|
t.Fatalf("unexpected roomID change: %s -> %s", outboundPeek1.RoomID, outboundPeek2.RoomID)
|
|
|
|
}
|
|
|
|
|
|
|
|
// delete the peek
|
|
|
|
if err = tab.DeleteOutboundPeek(ctx, nil, serverName, room.ID, peekID); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// There should be no peek anymore
|
|
|
|
peek, err := tab.SelectOutboundPeek(ctx, nil, serverName, room.ID, peekID)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if peek != nil {
|
|
|
|
t.Fatalf("got a peek which should be deleted: %+v", peek)
|
|
|
|
}
|
|
|
|
|
|
|
|
// insert some peeks
|
|
|
|
var peekIDs []string
|
|
|
|
for i := 0; i < 5; i++ {
|
|
|
|
peekID = util.RandomString(8)
|
|
|
|
if err = tab.InsertOutboundPeek(ctx, nil, serverName, room.ID, peekID, 1000); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
peekIDs = append(peekIDs, peekID)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Now select them
|
|
|
|
outboundPeeks, err := tab.SelectOutboundPeeks(ctx, nil, room.ID)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if len(outboundPeeks) != len(peekIDs) {
|
|
|
|
t.Fatalf("inserted %d peeks, selected %d", len(peekIDs), len(outboundPeeks))
|
|
|
|
}
|
2022-12-22 11:31:54 +01:00
|
|
|
gotPeekIDs := make([]string, 0, len(outboundPeeks))
|
|
|
|
for _, p := range outboundPeeks {
|
|
|
|
gotPeekIDs = append(gotPeekIDs, p.PeekID)
|
2022-12-22 10:56:20 +01:00
|
|
|
}
|
2022-12-22 11:31:54 +01:00
|
|
|
assert.ElementsMatch(t, gotPeekIDs, peekIDs)
|
2022-12-22 10:56:20 +01:00
|
|
|
|
|
|
|
// And delete them again
|
|
|
|
if err = tab.DeleteOutboundPeeks(ctx, nil, room.ID); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// they should be gone now
|
|
|
|
outboundPeeks, err = tab.SelectOutboundPeeks(ctx, nil, room.ID)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if len(outboundPeeks) > 0 {
|
|
|
|
t.Fatal("got outbound peeks which should be deleted")
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|