aboutsummaryrefslogtreecommitdiff
path: root/syncapi/storage/tables
diff options
context:
space:
mode:
authorTill <2353100+S7evinK@users.noreply.github.com>2022-04-13 13:16:02 +0200
committerGitHub <noreply@github.com>2022-04-13 13:16:02 +0200
commit29f216878994dccc68e34c90e5a0240c7698589f (patch)
treed0155a838c6c234285d952197133bc23dbbbb92e /syncapi/storage/tables
parentea92f80c128bcff0fd4e02df40b272f7d90a97da (diff)
Make `/messages` filterable (#2347)
* Make /messages filterable Fix bug when determining if an event contains an URL * Add newly passing test * Fix test
Diffstat (limited to 'syncapi/storage/tables')
-rw-r--r--syncapi/storage/tables/interface.go2
-rw-r--r--syncapi/storage/tables/output_room_events_test.go25
2 files changed, 25 insertions, 2 deletions
diff --git a/syncapi/storage/tables/interface.go b/syncapi/storage/tables/interface.go
index a7df7024..993e2022 100644
--- a/syncapi/storage/tables/interface.go
+++ b/syncapi/storage/tables/interface.go
@@ -59,7 +59,7 @@ type Events interface {
SelectRecentEvents(ctx context.Context, txn *sql.Tx, roomID string, r types.Range, eventFilter *gomatrixserverlib.RoomEventFilter, chronologicalOrder bool, onlySyncEvents bool) ([]types.StreamEvent, bool, error)
// SelectEarlyEvents returns the earliest events in the given room.
SelectEarlyEvents(ctx context.Context, txn *sql.Tx, roomID string, r types.Range, eventFilter *gomatrixserverlib.RoomEventFilter) ([]types.StreamEvent, error)
- SelectEvents(ctx context.Context, txn *sql.Tx, eventIDs []string, preserveOrder bool) ([]types.StreamEvent, error)
+ SelectEvents(ctx context.Context, txn *sql.Tx, eventIDs []string, filter *gomatrixserverlib.RoomEventFilter, preserveOrder bool) ([]types.StreamEvent, error)
UpdateEventJSON(ctx context.Context, event *gomatrixserverlib.HeaderedEvent) error
// DeleteEventsForRoom removes all event information for a room. This should only be done when removing the room entirely.
DeleteEventsForRoom(ctx context.Context, txn *sql.Tx, roomID string) (err error)
diff --git a/syncapi/storage/tables/output_room_events_test.go b/syncapi/storage/tables/output_room_events_test.go
index 7a81ffcd..a143e5ec 100644
--- a/syncapi/storage/tables/output_room_events_test.go
+++ b/syncapi/storage/tables/output_room_events_test.go
@@ -13,6 +13,7 @@ import (
"github.com/matrix-org/dendrite/syncapi/storage/sqlite3"
"github.com/matrix-org/dendrite/syncapi/storage/tables"
"github.com/matrix-org/dendrite/test"
+ "github.com/matrix-org/gomatrixserverlib"
)
func newOutputRoomEventsTable(t *testing.T, dbType test.DBType) (tables.Events, *sql.DB, func()) {
@@ -61,7 +62,7 @@ func TestOutputRoomEventsTable(t *testing.T) {
wantEventIDs := []string{
events[2].EventID(), events[0].EventID(), events[3].EventID(), events[1].EventID(),
}
- gotEvents, err := tab.SelectEvents(ctx, txn, wantEventIDs, true)
+ gotEvents, err := tab.SelectEvents(ctx, txn, wantEventIDs, nil, true)
if err != nil {
return fmt.Errorf("failed to SelectEvents: %s", err)
}
@@ -73,6 +74,28 @@ func TestOutputRoomEventsTable(t *testing.T) {
return fmt.Errorf("SelectEvents\ngot %v\n want %v", gotEventIDs, wantEventIDs)
}
+ // Test that contains_url is correctly populated
+ urlEv := room.CreateEvent(t, alice, "m.text", map[string]interface{}{
+ "body": "test.txt",
+ "url": "mxc://test.txt",
+ })
+ if _, err = tab.InsertEvent(ctx, txn, urlEv, nil, nil, nil, false); err != nil {
+ return fmt.Errorf("failed to InsertEvent: %s", err)
+ }
+ wantEventID := []string{urlEv.EventID()}
+ t := true
+ gotEvents, err = tab.SelectEvents(ctx, txn, wantEventID, &gomatrixserverlib.RoomEventFilter{Limit: 1, ContainsURL: &t}, true)
+ if err != nil {
+ return fmt.Errorf("failed to SelectEvents: %s", err)
+ }
+ gotEventIDs = make([]string, len(gotEvents))
+ for i := range gotEvents {
+ gotEventIDs[i] = gotEvents[i].EventID()
+ }
+ if !reflect.DeepEqual(gotEventIDs, wantEventID) {
+ return fmt.Errorf("SelectEvents\ngot %v\n want %v", gotEventIDs, wantEventID)
+ }
+
return nil
})
if err != nil {