2022-02-11 18:40:14 +01:00
|
|
|
package input_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/matrix-org/dendrite/internal/caching"
|
2023-03-17 12:09:45 +01:00
|
|
|
"github.com/matrix-org/dendrite/internal/sqlutil"
|
2023-03-22 09:21:32 +01:00
|
|
|
"github.com/matrix-org/dendrite/roomserver"
|
2022-02-11 18:40:14 +01:00
|
|
|
"github.com/matrix-org/dendrite/roomserver/api"
|
|
|
|
"github.com/matrix-org/dendrite/roomserver/internal/input"
|
2023-03-22 09:21:32 +01:00
|
|
|
"github.com/matrix-org/dendrite/setup/jetstream"
|
|
|
|
"github.com/matrix-org/dendrite/test"
|
2022-05-17 14:23:35 +02:00
|
|
|
"github.com/matrix-org/dendrite/test/testrig"
|
2022-02-11 18:40:14 +01:00
|
|
|
"github.com/matrix-org/gomatrixserverlib"
|
|
|
|
)
|
|
|
|
|
2023-03-22 09:21:32 +01:00
|
|
|
func TestSingleTransactionOnInput(t *testing.T) {
|
|
|
|
test.WithAllDatabases(t, func(t *testing.T, dbType test.DBType) {
|
|
|
|
cfg, processCtx, close := testrig.CreateConfig(t, dbType)
|
|
|
|
defer close()
|
|
|
|
cm := sqlutil.NewConnectionManager(processCtx, cfg.Global.DatabaseOptions)
|
2022-04-08 11:12:30 +02:00
|
|
|
|
2023-03-22 09:21:32 +01:00
|
|
|
natsInstance := &jetstream.NATSInstance{}
|
|
|
|
js, jc := natsInstance.Prepare(processCtx, &cfg.Global.JetStream)
|
|
|
|
caches := caching.NewRistrettoCache(8*1024*1024, time.Hour, caching.DisableMetrics)
|
|
|
|
rsAPI := roomserver.NewInternalAPI(processCtx, cfg, cm, natsInstance, caches, caching.DisableMetrics)
|
|
|
|
rsAPI.SetFederationAPI(nil, nil)
|
2022-02-11 18:40:14 +01:00
|
|
|
|
2023-03-22 09:21:32 +01:00
|
|
|
deadline, _ := t.Deadline()
|
|
|
|
if max := time.Now().Add(time.Second * 3); deadline.Before(max) {
|
|
|
|
deadline = max
|
|
|
|
}
|
|
|
|
ctx, cancel := context.WithDeadline(processCtx.Context(), deadline)
|
|
|
|
defer cancel()
|
|
|
|
|
|
|
|
event, err := gomatrixserverlib.NewEventFromTrustedJSON(
|
|
|
|
[]byte(`{"auth_events":[],"content":{"creator":"@neilalexander:dendrite.matrix.org","room_version":"6"},"depth":1,"hashes":{"sha256":"jqOqdNEH5r0NiN3xJtj0u5XUVmRqq9YvGbki1wxxuuM"},"origin":"dendrite.matrix.org","origin_server_ts":1644595362726,"prev_events":[],"prev_state":[],"room_id":"!jSZZRknA6GkTBXNP:dendrite.matrix.org","sender":"@neilalexander:dendrite.matrix.org","signatures":{"dendrite.matrix.org":{"ed25519:6jB2aB":"bsQXO1wketf1OSe9xlndDIWe71W9KIundc6rBw4KEZdGPW7x4Tv4zDWWvbxDsG64sS2IPWfIm+J0OOozbrWIDw"}},"state_key":"","type":"m.room.create"}`),
|
|
|
|
false, gomatrixserverlib.RoomVersionV6,
|
|
|
|
)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
in := api.InputRoomEvent{
|
|
|
|
Kind: api.KindOutlier, // don't panic if we generate an output event
|
|
|
|
Event: event.Headered(gomatrixserverlib.RoomVersionV6),
|
|
|
|
}
|
2022-02-11 18:40:14 +01:00
|
|
|
|
2023-03-22 09:21:32 +01:00
|
|
|
inputter := &input.Inputer{
|
|
|
|
JetStream: js,
|
|
|
|
NATSClient: jc,
|
|
|
|
Cfg: &cfg.RoomServer,
|
|
|
|
}
|
|
|
|
res := &api.InputRoomEventsResponse{}
|
|
|
|
inputter.InputRoomEvents(
|
|
|
|
ctx,
|
|
|
|
&api.InputRoomEventsRequest{
|
|
|
|
InputRoomEvents: []api.InputRoomEvent{in},
|
|
|
|
Asynchronous: false,
|
|
|
|
},
|
|
|
|
res,
|
|
|
|
)
|
|
|
|
// If we fail here then it's because we've hit the test deadline,
|
|
|
|
// so we probably deadlocked
|
|
|
|
if err := res.Err(); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
})
|
2022-02-11 18:40:14 +01:00
|
|
|
}
|