add more tests

master
kevin 4 years ago
parent d12e25a886
commit 68e46cf6b3

@ -72,12 +72,9 @@ func TestContainer(t *testing.T) {
{
act: actionDel,
key: "first",
val: "a",
},
},
expect: []string{
"b",
},
expect: []string{"b"},
},
{
name: "add two, delete two",
@ -95,21 +92,83 @@ func TestContainer(t *testing.T) {
{
act: actionDel,
key: "first",
},
{
act: actionDel,
key: "second",
},
},
expect: []string{},
},
{
name: "add three, dup values, delete two",
do: []action{
{
act: actionAdd,
key: "first",
val: "a",
},
{
act: actionAdd,
key: "second",
val: "b",
},
{
act: actionAdd,
key: "third",
val: "a",
},
{
act: actionDel,
key: "first",
},
{
act: actionDel,
key: "second",
},
},
expect: []string{"a"},
},
{
name: "add three, dup values, delete two, delete not added",
do: []action{
{
act: actionAdd,
key: "first",
val: "a",
},
{
act: actionAdd,
key: "second",
val: "b",
},
{
act: actionAdd,
key: "third",
val: "a",
},
{
act: actionDel,
key: "first",
},
expect: []string{},
{
act: actionDel,
key: "second",
},
{
act: actionDel,
key: "forth",
},
},
expect: []string{"a"},
},
}
exclusives := []bool{true, false}
for _, test := range tests {
for _, exclusive := range exclusives {
t.Run(test.name, func(t *testing.T) {
c := newContainer(false)
c := newContainer(exclusive)
for _, order := range test.do {
if order.act == actionAdd {
c.OnAdd(internal.KV{
@ -129,4 +188,5 @@ func TestContainer(t *testing.T) {
assert.ElementsMatch(t, test.expect, c.getValues())
})
}
}
}

Loading…
Cancel
Save