mirror of
https://github.com/matrix-org/dendrite.git
synced 2025-12-07 06:53:09 -06:00
Add test for de-duplication
This commit is contained in:
parent
046be9129e
commit
001f391da4
|
|
@ -181,21 +181,7 @@ func (u *DeviceListUpdater) Start() error {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
// Filter out dupe domains, as processServer is going to get all users anyway
|
newStaleLists := dedupeStaleLists(staleLists)
|
||||||
seenDomains := make(map[spec.ServerName]struct{})
|
|
||||||
newStaleLists := make([]string, 0, len(staleLists))
|
|
||||||
for _, userID := range staleLists {
|
|
||||||
_, domain, err := gomatrixserverlib.SplitID('@', userID)
|
|
||||||
if err != nil {
|
|
||||||
// non-fatal and should not block starting up
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
if _, ok := seenDomains[domain]; ok {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
newStaleLists = append(newStaleLists, userID)
|
|
||||||
seenDomains[domain] = struct{}{}
|
|
||||||
}
|
|
||||||
offset, step := time.Second*10, time.Second
|
offset, step := time.Second*10, time.Second
|
||||||
if max := len(newStaleLists); max > 120 {
|
if max := len(newStaleLists); max > 120 {
|
||||||
step = (time.Second * 120) / time.Duration(max)
|
step = (time.Second * 120) / time.Duration(max)
|
||||||
|
|
@ -599,3 +585,24 @@ func (u *DeviceListUpdater) updateDeviceList(res *fclient.RespUserDevices) error
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// dedupeStaleLists de-duplicates the stateList entries using the domain.
|
||||||
|
// This is used on startup, processServer is getting all users anyway, so
|
||||||
|
// there is no need to send every user to the workers.
|
||||||
|
func dedupeStaleLists(staleLists []string) []string {
|
||||||
|
seenDomains := make(map[spec.ServerName]struct{})
|
||||||
|
newStaleLists := make([]string, 0, len(staleLists))
|
||||||
|
for _, userID := range staleLists {
|
||||||
|
_, domain, err := gomatrixserverlib.SplitID('@', userID)
|
||||||
|
if err != nil {
|
||||||
|
// non-fatal and should not block starting up
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
if _, ok := seenDomains[domain]; ok {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
newStaleLists = append(newStaleLists, userID)
|
||||||
|
seenDomains[domain] = struct{}{}
|
||||||
|
}
|
||||||
|
return newStaleLists
|
||||||
|
}
|
||||||
|
|
|
||||||
|
|
@ -428,3 +428,43 @@ func TestDeviceListUpdater_CleanUp(t *testing.T) {
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func Test_dedupeStateList(t *testing.T) {
|
||||||
|
alice := "@alice:localhost"
|
||||||
|
bob := "@bob:localhost"
|
||||||
|
charlie := "@charlie:notlocalhost"
|
||||||
|
|
||||||
|
tests := []struct {
|
||||||
|
name string
|
||||||
|
staleLists []string
|
||||||
|
want []string
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
name: "empty stateLists",
|
||||||
|
staleLists: []string{},
|
||||||
|
want: []string{},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "single entry",
|
||||||
|
staleLists: []string{alice},
|
||||||
|
want: []string{alice},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "multiple entries without dupe servers",
|
||||||
|
staleLists: []string{alice, charlie},
|
||||||
|
want: []string{alice, charlie},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "multiple entries with dupe servers",
|
||||||
|
staleLists: []string{alice, bob, charlie},
|
||||||
|
want: []string{alice, charlie},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
for _, tt := range tests {
|
||||||
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
if got := dedupeStaleLists(tt.staleLists); !reflect.DeepEqual(got, tt.want) {
|
||||||
|
t.Errorf("dedupeStaleLists() = %v, want %v", got, tt.want)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue