✨ Add MultiGenerator
This commit is contained in:
parent
ce5f823d64
commit
5c4e66d144
2 changed files with 72 additions and 0 deletions
|
|
@ -1,6 +1,7 @@
|
|||
package nomino
|
||||
|
||||
import (
|
||||
"errors"
|
||||
"time"
|
||||
|
||||
"github.com/google/uuid"
|
||||
|
|
@ -18,6 +19,32 @@ func WithGenerator(g Generator) Option {
|
|||
}
|
||||
}
|
||||
|
||||
// ErrMissingGenerators is returned by a multi-generator if no generators are supplied.
|
||||
var ErrMissingGenerators = errors.New("no generators supplied")
|
||||
|
||||
func missingGen() (string, error) {
|
||||
return "", ErrMissingGenerators
|
||||
}
|
||||
|
||||
// MultiGeneratorInOrder allows the use of multiple generators. Each new invokation will use the next generator in turn.
|
||||
// If none are passed, the generator will always return ErrMissingGenerators.
|
||||
func MultiGeneratorInOrder(gens ...Generator) Generator {
|
||||
if len(gens) == 0 {
|
||||
return missingGen
|
||||
}
|
||||
|
||||
if len(gens) == 1 {
|
||||
return gens[0]
|
||||
}
|
||||
|
||||
var idx int
|
||||
return func() (string, error) {
|
||||
st, err := gens[idx]()
|
||||
idx = (idx + 1) % len(gens)
|
||||
return st, err
|
||||
}
|
||||
}
|
||||
|
||||
func uuidGen() (string, error) {
|
||||
u, err := uuid.NewRandom()
|
||||
if err != nil {
|
||||
|
|
|
|||
|
|
@ -18,6 +18,51 @@ func TestWithGenerator(t *testing.T) {
|
|||
assert.Equal(t, "abc", st)
|
||||
}
|
||||
|
||||
func TestMultiGeneratorInOrder(t *testing.T) {
|
||||
st1 := "abc"
|
||||
st2 := "def"
|
||||
er1 := errors.New("oops")
|
||||
g1 := func() (string, error) { return st1, nil }
|
||||
g2 := func() (string, error) { return st2, nil }
|
||||
g3 := func() (string, error) { return "", er1 }
|
||||
g := MultiGeneratorInOrder(g1, g2, g3)
|
||||
st, err := g()
|
||||
assert.NoError(t, err)
|
||||
assert.Equal(t, st1, st)
|
||||
st, err = g()
|
||||
assert.NoError(t, err)
|
||||
assert.Equal(t, st2, st)
|
||||
st, err = g()
|
||||
assert.Zero(t, st)
|
||||
assert.ErrorIs(t, err, er1)
|
||||
st, err = g()
|
||||
assert.NoError(t, err)
|
||||
assert.Equal(t, st1, st)
|
||||
}
|
||||
|
||||
func TestMultiGeneratorInOrderOne(t *testing.T) {
|
||||
st1 := "abc"
|
||||
g1 := func() (string, error) { return st1, nil }
|
||||
g := MultiGeneratorInOrder(g1)
|
||||
|
||||
st, err := g()
|
||||
assert.NoError(t, err)
|
||||
assert.Equal(t, st1, st)
|
||||
st, err = g()
|
||||
assert.NoError(t, err)
|
||||
assert.Equal(t, st1, st)
|
||||
}
|
||||
|
||||
func TestMultiGeneratorInOrderMissing(t *testing.T) {
|
||||
g := MultiGeneratorInOrder()
|
||||
st, err := g()
|
||||
assert.Zero(t, st)
|
||||
assert.ErrorIs(t, err, ErrMissingGenerators)
|
||||
st, err = g()
|
||||
assert.Zero(t, st)
|
||||
assert.ErrorIs(t, err, ErrMissingGenerators)
|
||||
}
|
||||
|
||||
func TestUUID(t *testing.T) {
|
||||
st, err := UUID()()
|
||||
assert.NoError(t, err)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue