mirror of
https://github.com/matrix-org/dendrite.git
synced 2026-01-16 18:43:10 -06:00
Add test
This commit is contained in:
parent
c6deae2f44
commit
a08a488655
63
roomserver/internal/input/input_events_test.go
Normal file
63
roomserver/internal/input/input_events_test.go
Normal file
|
|
@ -0,0 +1,63 @@
|
||||||
|
package input
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/matrix-org/gomatrixserverlib"
|
||||||
|
|
||||||
|
"github.com/matrix-org/dendrite/test"
|
||||||
|
)
|
||||||
|
|
||||||
|
func Test_1(t *testing.T) {
|
||||||
|
alice := test.NewUser(t)
|
||||||
|
bob := test.NewUser(t)
|
||||||
|
|
||||||
|
// create two rooms, so we can craft "illegal" auth events
|
||||||
|
room1 := test.NewRoom(t, alice)
|
||||||
|
room2 := test.NewRoom(t, alice, test.RoomPreset(test.PresetPublicChat))
|
||||||
|
|
||||||
|
authEvens := make([]string, 0, 4)
|
||||||
|
authEvents := []*gomatrixserverlib.Event{}
|
||||||
|
|
||||||
|
// Add the legal auth events from room2
|
||||||
|
for _, x := range room2.Events() {
|
||||||
|
if x.Type() == gomatrixserverlib.MRoomCreate {
|
||||||
|
authEvens = append(authEvens, x.EventID())
|
||||||
|
authEvents = append(authEvents, x.Event)
|
||||||
|
}
|
||||||
|
if x.Type() == gomatrixserverlib.MRoomPowerLevels {
|
||||||
|
authEvens = append(authEvens, x.EventID())
|
||||||
|
authEvents = append(authEvents, x.Event)
|
||||||
|
}
|
||||||
|
if x.Type() == gomatrixserverlib.MRoomJoinRules {
|
||||||
|
authEvens = append(authEvens, x.EventID())
|
||||||
|
authEvents = append(authEvents, x.Event)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add the illegal auth event from room1
|
||||||
|
for _, x := range room1.Events() {
|
||||||
|
if x.Type() == gomatrixserverlib.MRoomMember {
|
||||||
|
authEvens = append(authEvens, x.EventID())
|
||||||
|
authEvents = append(authEvents, x.Event)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Craft the illegal join event
|
||||||
|
ev := room2.CreateEvent(t, bob, "m.room.member", map[string]interface{}{
|
||||||
|
"membership": "join",
|
||||||
|
}, test.WithStateKey(bob.ID), test.WithAuthIDs(authEvens))
|
||||||
|
|
||||||
|
// Add the auth events to the allower
|
||||||
|
allower := gomatrixserverlib.NewAuthEvents(nil)
|
||||||
|
for _, a := range authEvents {
|
||||||
|
if err := allower.AddEvent(a); err != nil {
|
||||||
|
t.Fatalf("allower.AddEvent failed: %v", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Finally check that the event is NOT allowed
|
||||||
|
if err := gomatrixserverlib.Allowed(ev.Event, &allower); err == nil {
|
||||||
|
t.Fatalf("event should not be allowed, but it was")
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Reference in a new issue