2020-06-30 14:54:38 +01:00
|
|
|
package roundrobin
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
2020-07-27 13:22:00 +01:00
|
|
|
"github.com/micro/go-micro/v3/selector"
|
2020-06-30 14:54:38 +01:00
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestRoundRobin(t *testing.T) {
|
|
|
|
selector.Tests(t, NewSelector())
|
|
|
|
|
2020-08-17 22:44:45 +01:00
|
|
|
r1 := "127.0.0.1:8000"
|
|
|
|
r2 := "127.0.0.1:8001"
|
|
|
|
r3 := "127.0.0.1:8002"
|
2020-06-30 14:54:38 +01:00
|
|
|
|
|
|
|
sel := NewSelector()
|
|
|
|
|
|
|
|
// By passing r1 and r2 first, it forces a set sequence of (r1 => r2 => r3 => r1)
|
|
|
|
|
2020-08-17 22:44:45 +01:00
|
|
|
next, err := sel.Select([]string{r1})
|
|
|
|
r := next()
|
2020-06-30 14:54:38 +01:00
|
|
|
assert.Nil(t, err, "Error should be nil")
|
2020-08-17 22:44:45 +01:00
|
|
|
assert.Equal(t, r1, r, "Expected route to be r1")
|
2020-06-30 14:54:38 +01:00
|
|
|
|
2020-08-17 22:44:45 +01:00
|
|
|
next, err = sel.Select([]string{r2})
|
|
|
|
r = next()
|
2020-06-30 14:54:38 +01:00
|
|
|
assert.Nil(t, err, "Error should be nil")
|
2020-08-17 22:44:45 +01:00
|
|
|
assert.Equal(t, r2, r, "Expected route to be r2")
|
2020-06-30 14:54:38 +01:00
|
|
|
|
|
|
|
// Because r1 and r2 have been recently called, r3 should be chosen
|
|
|
|
|
2020-08-17 22:44:45 +01:00
|
|
|
next, err = sel.Select([]string{r1, r2, r3})
|
|
|
|
n1, n2, n3 := next(), next(), next()
|
2020-06-30 14:54:38 +01:00
|
|
|
assert.Nil(t, err, "Error should be nil")
|
2020-08-17 22:44:45 +01:00
|
|
|
assert.Equal(t, r1, n1, "Expected route to be r3")
|
|
|
|
assert.Equal(t, r2, n2, "Expected route to be r3")
|
|
|
|
assert.Equal(t, r3, n3, "Expected route to be r3")
|
2020-06-30 14:54:38 +01:00
|
|
|
|
|
|
|
}
|