Add MultiGeneratorRandomOrder

This commit is contained in:
Dan Jones 2025-03-15 21:00:54 -05:00
commit 7c016df30f
3 changed files with 101 additions and 23 deletions

View file

@ -16,26 +16,34 @@ func TestWithGenerator(t *testing.T) {
assert.Equal(t, "abc", st)
}
const (
out1 string = "abc"
out2 string = "def"
)
var (
outs = []string{out1, out2}
err1 = errors.New("oops")
gen1 Generator = func(*Config) (string, error) { return out1, nil }
gen2 Generator = func(*Config) (string, error) { return out2, nil }
gen3 Generator = func(*Config) (string, error) { return "", err1 }
gens = []Generator{gen1, gen2, gen3}
)
func TestMultiGeneratorInOrder(t *testing.T) {
st1 := "abc"
st2 := "def"
er1 := errors.New("oops")
g1 := func(*Config) (string, error) { return st1, nil }
g2 := func(*Config) (string, error) { return st2, nil }
g3 := func(*Config) (string, error) { return "", er1 }
g := MultiGeneratorInOrder(g1, g2, g3)
g := MultiGeneratorInOrder(gens...)
st, err := g(nil)
assert.NoError(t, err)
assert.Equal(t, st1, st)
assert.Equal(t, out1, st)
st, err = g(nil)
assert.NoError(t, err)
assert.Equal(t, st2, st)
assert.Equal(t, out2, st)
st, err = g(nil)
assert.Zero(t, st)
assert.ErrorIs(t, err, er1)
assert.ErrorIs(t, err, err1)
st, err = g(nil)
assert.NoError(t, err)
assert.Equal(t, st1, st)
assert.Equal(t, out1, st)
}
func TestMultiGeneratorInOrderOne(t *testing.T) {
@ -60,3 +68,39 @@ func TestMultiGeneratorInOrderMissing(t *testing.T) {
assert.Zero(t, st)
assert.ErrorIs(t, err, ErrMissingGenerators)
}
func TestMultiGeneratorRandomOrder(t *testing.T) {
g := MultiGeneratorRandomOrder(gens...)
for i := 0; i < 4; i++ {
st, err := g(nil)
if err != nil {
assert.Zero(t, st)
assert.ErrorIs(t, err, err1)
} else {
assert.Contains(t, outs, st)
}
}
}
func TestMultiGeneratorRandomOrderOne(t *testing.T) {
st1 := "abc"
g1 := func(*Config) (string, error) { return st1, nil }
g := MultiGeneratorRandomOrder(g1)
st, err := g(nil)
assert.NoError(t, err)
assert.Equal(t, st1, st)
st, err = g(nil)
assert.NoError(t, err)
assert.Equal(t, st1, st)
}
func TestMultiGeneratorRandomOrderMissing(t *testing.T) {
g := MultiGeneratorRandomOrder()
st, err := g(nil)
assert.Zero(t, st)
assert.ErrorIs(t, err, ErrMissingGenerators)
st, err = g(nil)
assert.Zero(t, st)
assert.ErrorIs(t, err, ErrMissingGenerators)
}