mirror of
https://github.com/octoleo/syncthing.git
synced 2025-01-11 02:36:17 +00:00
57 lines
1.5 KiB
Go
57 lines
1.5 KiB
Go
|
// Copyright (C) 2014 Jakob Borg and Contributors (see the CONTRIBUTORS file).
|
||
|
// All rights reserved. Use of this source code is governed by an MIT-style
|
||
|
// license that can be found in the LICENSE file.
|
||
|
|
||
|
package model
|
||
|
|
||
|
import (
|
||
|
"testing"
|
||
|
|
||
|
"github.com/syncthing/syncthing/internal/protocol"
|
||
|
)
|
||
|
|
||
|
func TestNodeActivity(t *testing.T) {
|
||
|
n0 := protocol.NodeID{1, 2, 3, 4}
|
||
|
n1 := protocol.NodeID{5, 6, 7, 8}
|
||
|
n2 := protocol.NodeID{9, 10, 11, 12}
|
||
|
nodes := []protocol.NodeID{n0, n1, n2}
|
||
|
na := newNodeActivity()
|
||
|
|
||
|
if lb := na.leastBusy(nodes); lb != n0 {
|
||
|
t.Errorf("Least busy node should be n0 (%v) not %v", n0, lb)
|
||
|
}
|
||
|
if lb := na.leastBusy(nodes); lb != n0 {
|
||
|
t.Errorf("Least busy node should still be n0 (%v) not %v", n0, lb)
|
||
|
}
|
||
|
|
||
|
na.using(na.leastBusy(nodes))
|
||
|
if lb := na.leastBusy(nodes); lb != n1 {
|
||
|
t.Errorf("Least busy node should be n1 (%v) not %v", n1, lb)
|
||
|
}
|
||
|
|
||
|
na.using(na.leastBusy(nodes))
|
||
|
if lb := na.leastBusy(nodes); lb != n2 {
|
||
|
t.Errorf("Least busy node should be n2 (%v) not %v", n2, lb)
|
||
|
}
|
||
|
|
||
|
na.using(na.leastBusy(nodes))
|
||
|
if lb := na.leastBusy(nodes); lb != n0 {
|
||
|
t.Errorf("Least busy node should be n0 (%v) not %v", n0, lb)
|
||
|
}
|
||
|
|
||
|
na.done(n1)
|
||
|
if lb := na.leastBusy(nodes); lb != n1 {
|
||
|
t.Errorf("Least busy node should be n1 (%v) not %v", n1, lb)
|
||
|
}
|
||
|
|
||
|
na.done(n2)
|
||
|
if lb := na.leastBusy(nodes); lb != n1 {
|
||
|
t.Errorf("Least busy node should still be n1 (%v) not %v", n1, lb)
|
||
|
}
|
||
|
|
||
|
na.done(n0)
|
||
|
if lb := na.leastBusy(nodes); lb != n0 {
|
||
|
t.Errorf("Least busy node should be n0 (%v) not %v", n0, lb)
|
||
|
}
|
||
|
}
|