Codebase list golang-github-imdario-mergo / 70a7923e-9f3d-41cc-9299-cc0b2bdef009/upstream/0.3.13+git20220917.2.c42713b issue125_test.go
70a7923e-9f3d-41cc-9299-cc0b2bdef009/upstream/0.3.13+git20220917.2.c42713b

Tree @70a7923e-9f3d-41cc-9299-cc0b2bdef009/upstream/0.3.13+git20220917.2.c42713b (Download .tar.gz)

issue125_test.go @70a7923e-9f3d-41cc-9299-cc0b2bdef009/upstream/0.3.13+git20220917.2.c42713braw · history · blame

package mergo_test

import (
	"encoding/json"
	"testing"

	"github.com/imdario/mergo"
)

type settings struct {
	FirstSlice  []string `json:"FirstSlice"`
	SecondSlice []string `json:"SecondSlice"`
}

func TestIssue125MergeWithOverwrite(t *testing.T) {
	var (
		defaultSettings = settings{
			FirstSlice:  []string{},
			SecondSlice: []string{},
		}
		something settings
		data      = `{"FirstSlice":[], "SecondSlice": null}`
	)

	if err := json.Unmarshal([]byte(data), &something); err != nil {
		t.Errorf("Error while Unmarshalling maprequest: %s", err)
	}

	if err := mergo.Merge(&something, defaultSettings, mergo.WithOverrideEmptySlice); err != nil {
		t.Errorf("Error while merging: %s", err)
	}

	if something.FirstSlice == nil {
		t.Error("Invalid merging first slice")
	}

	if something.SecondSlice == nil {
		t.Error("Invalid merging second slice")
	}
}