Test slices strings Exists* functions

pull/8674/head
Matt McCoy 2017-08-08 20:33:26 -04:00
parent 392fa03cf3
commit e43bec4a3a
1 changed files with 83 additions and 0 deletions

View File

@ -0,0 +1,83 @@
package slices
import "testing"
func TestExists(t *testing.T) {
tests := []struct {
set []string
find string
output bool
}{
{
set: []string{},
find: "foo",
output: false,
},
{
set: []string{"foo"},
find: "foo",
output: true,
},
{
set: []string{"bar", "foo"},
find: "foo",
output: true,
},
{
set: []string{"bar", "foo"},
find: "stuff",
output: false,
},
{
set: []string{"bar", "Foo"},
find: "foo",
output: false,
},
}
for i, tt := range tests {
actual := Exists(tt.set, tt.find)
if actual != tt.output {
t.Errorf("[%d] set: %v , find: %s , expected: %t , actual: %t", i, tt.set, tt.find, tt.output, actual)
}
}
}
func TestExistsIgnoreCase(t *testing.T) {
tests := []struct {
set []string
find string
output bool
}{
{
set: []string{},
find: "foo",
output: false,
},
{
set: []string{"foo"},
find: "foo",
output: true,
},
{
set: []string{"bar", "foo"},
find: "foo",
output: true,
},
{
set: []string{"bar", "foo"},
find: "stuff",
output: false,
},
{
set: []string{"bar", "Foo"},
find: "foo",
output: true,
},
}
for i, tt := range tests {
actual := ExistsIgnoreCase(tt.set, tt.find)
if actual != tt.output {
t.Errorf("[%d] set: %v , find: %s , expected: %t , actual: %t", i, tt.set, tt.find, tt.output, actual)
}
}
}