package roundrobin import ( "testing" "go.unistack.org/micro/v3/selector" ) func TestRoundRobin(t *testing.T) { selector.Tests(t, NewSelector()) r1 := "127.0.0.1:8000" r2 := "127.0.0.1:8001" r3 := "127.0.0.1:8002" sel := NewSelector() // By passing r1 and r2 first, it forces a set sequence of (r1 => r2 => r3 => r1) next, err := sel.Select([]string{r1}) if err != nil { t.Fatal(err) } r := next() if r1 != r { t.Fatal("Expected route to be r == r1") } next, err = sel.Select([]string{r2}) if err != nil { t.Fatal(err) } r = next() if r2 != r { t.Fatal("Expected route to be r2") } routes := []string{r1, r2, r3} next, err = sel.Select(routes) if err != nil { t.Fatal(err) } n1, n2, n3, n4 := next(), next(), next(), next() // start element is random but then it should loop through in order start := -1 for i := 0; i < 3; i++ { if n1 == routes[i] { start = i break } } if start == -1 { t.Fatalf("start == -1 %v %v", start, -1) } if routes[start] != n1 { t.Fatal("Unexpected route") } if routes[(start+1)%3] != n2 { t.Fatal("Unexpected route") } if routes[(start+2)%3] != n3 { t.Fatal("Unexpected route") } if routes[(start+3)%3] != n4 { t.Fatal("Unexpected route") } }