mirror of
https://github.com/livekit/livekit.git
synced 2026-04-09 20:25:39 +00:00
* move callbacks out of messageRouter * OCD * more OCD * fix forwarder test * even more OCD * maximum OCD * package name collision, copy lock by value
58 lines
1.2 KiB
Go
58 lines
1.2 KiB
Go
package selector_test
|
|
|
|
import (
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/livekit/protocol/livekit"
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/livekit/livekit-server/pkg/routing/selector"
|
|
)
|
|
|
|
var (
|
|
nodeLoadLow = &livekit.Node{
|
|
State: livekit.NodeState_SERVING,
|
|
Stats: &livekit.NodeStats{
|
|
UpdatedAt: time.Now().Unix(),
|
|
NumCpus: 1,
|
|
LoadAvgLast1Min: 0.0,
|
|
},
|
|
}
|
|
|
|
nodeLoadHigh = &livekit.Node{
|
|
State: livekit.NodeState_SERVING,
|
|
Stats: &livekit.NodeStats{
|
|
UpdatedAt: time.Now().Unix(),
|
|
NumCpus: 1,
|
|
LoadAvgLast1Min: 2.0,
|
|
},
|
|
}
|
|
)
|
|
|
|
func TestSystemLoadSelector_SelectNode(t *testing.T) {
|
|
sel := selector.SystemLoadSelector{SysloadLimit: 1.0}
|
|
|
|
var nodes []*livekit.Node
|
|
_, err := sel.SelectNode(nodes)
|
|
require.Error(t, err, "should error no available nodes")
|
|
|
|
// Select a node with high load when no nodes with low load are available
|
|
nodes = []*livekit.Node{nodeLoadHigh}
|
|
if _, err := sel.SelectNode(nodes); err != nil {
|
|
t.Error(err)
|
|
}
|
|
|
|
// Select a node with low load when available
|
|
nodes = []*livekit.Node{nodeLoadLow, nodeLoadHigh}
|
|
for i := 0; i < 5; i++ {
|
|
node, err := sel.SelectNode(nodes)
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
if node != nodeLoadLow {
|
|
t.Error("selected the wrong node")
|
|
}
|
|
}
|
|
}
|