feat util: Add silly map-merge function that should be in the stdlib

This commit is contained in:
Vincent Ambo 2017-02-10 20:52:02 +01:00
parent c181decd9d
commit 7a930aad11
2 changed files with 99 additions and 0 deletions

74
util/util_test.go Normal file
View file

@ -0,0 +1,74 @@
package util
import (
"testing"
"reflect"
)
func TestMergeWithEmptyMap(t *testing.T) {
testMap := map[string]interface{}{
"foo": "bar",
}
empty := make(map[string]interface{})
res1 := Merge(&testMap, &empty)
res2 := Merge(&empty, &testMap)
if res1 != &testMap || res2 != &testMap {
t.Error("A new map was returned incorrectly.")
t.Fail()
}
}
func TestMergeWithNilMap(t *testing.T) {
testMap := map[string]interface{}{
"foo": "bar",
}
res1 := Merge(&testMap, nil)
res2 := Merge(nil, &testMap)
if res1 != &testMap || res2 != &testMap {
t.Error("A new map was returned incorrectly.")
t.Fail()
}
}
func TestMergeMaps(t *testing.T) {
map1 := map[string]interface{}{
"foo": "bar",
}
map2 := map[string]interface{}{
"bar": "baz",
}
result := Merge(&map1, &map2)
expected := map[string]interface{}{
"foo": "bar",
"bar": "baz",
}
if !reflect.DeepEqual(*result, expected) {
t.Error("Maps were merged incorrectly.")
t.Fail()
}
}
func TestMergeMapsPrecedence(t *testing.T) {
map1 := map[string]interface{}{
"foo": "incorrect",
}
map2 := map[string]interface{}{
"foo": "correct",
}
result := Merge(&map1, &map2)
if (*result)["foo"] != "correct" {
t.Error("Map merge precedence test failed.")
t.Fail()
}
}