diff --git a/loader/merge.go b/loader/merge.go index 019ebac7..3c24008d 100644 --- a/loader/merge.go +++ b/loader/merge.go @@ -38,7 +38,6 @@ var serviceSpecials = &specials{ reflect.TypeOf([]types.ServiceSecretConfig{}): mergeSlice(toServiceSecretConfigsMap, toServiceSecretConfigsSlice), reflect.TypeOf([]types.ServiceConfigObjConfig{}): mergeSlice(toServiceConfigObjConfigsMap, toSServiceConfigObjConfigsSlice), reflect.TypeOf(&types.UlimitsConfig{}): mergeUlimitsConfig, - reflect.TypeOf(&types.ServiceNetworkConfig{}): mergeServiceNetworkConfig, }, } @@ -339,20 +338,6 @@ func mergeUlimitsConfig(dst, src reflect.Value) error { return nil } -// nolint: unparam -func mergeServiceNetworkConfig(dst, src reflect.Value) error { - if src.Interface() != reflect.Zero(reflect.TypeOf(src.Interface())).Interface() { - dst.Elem().FieldByName("Aliases").Set(src.Elem().FieldByName("Aliases")) - if ipv4 := src.Elem().FieldByName("Ipv4Address").Interface().(string); ipv4 != "" { - dst.Elem().FieldByName("Ipv4Address").SetString(ipv4) - } - if ipv6 := src.Elem().FieldByName("Ipv6Address").Interface().(string); ipv6 != "" { - dst.Elem().FieldByName("Ipv6Address").SetString(ipv6) - } - } - return nil -} - func getLoggingDriver(v reflect.Value) string { return v.FieldByName("Driver").String() } diff --git a/loader/merge_test.go b/loader/merge_test.go index bbe32cd2..d0802803 100644 --- a/loader/merge_test.go +++ b/loader/merge_test.go @@ -816,7 +816,7 @@ func TestLoadMultipleServiceNetworks(t *testing.T) { }, expected: map[string]*types.ServiceNetworkConfig{ "net1": { - Aliases: []string{"alias2", "alias3"}, + Aliases: []string{"alias1", "alias2", "alias3"}, }, "net2": nil, "net3": {}, @@ -1150,13 +1150,8 @@ func TestInitOverride(t *testing.T) { } func TestMergeServiceNetworkConfig(t *testing.T) { - specials := &specials{ - m: map[reflect.Type]func(dst, src reflect.Value) error{ - reflect.TypeOf(&types.ServiceNetworkConfig{}): mergeServiceNetworkConfig, - }, - } base := map[string]*types.ServiceNetworkConfig{ - "override-aliases": { + "merge": { Aliases: []string{"100", "101"}, Ipv4Address: "127.0.0.1", Ipv6Address: "0:0:0:0:0:0:0:1", @@ -1168,7 +1163,7 @@ func TestMergeServiceNetworkConfig(t *testing.T) { }, } override := map[string]*types.ServiceNetworkConfig{ - "override-aliases": { + "merge": { Aliases: []string{"110", "111"}, Ipv4Address: "127.0.1.1", Ipv6Address: "0:0:0:0:0:0:1:1", @@ -1179,14 +1174,14 @@ func TestMergeServiceNetworkConfig(t *testing.T) { Ipv6Address: "0:0:0:0:0:0:3:1", }, } - err := mergo.Merge(&base, &override, mergo.WithOverride, mergo.WithTransformers(specials)) + err := mergo.Merge(&base, &override, mergo.WithAppendSlice, mergo.WithOverride) assert.NilError(t, err) assert.DeepEqual( t, base, map[string]*types.ServiceNetworkConfig{ - "override-aliases": { - Aliases: []string{"110", "111"}, + "merge": { + Aliases: []string{"100", "101", "110", "111"}, Ipv4Address: "127.0.1.1", Ipv6Address: "0:0:0:0:0:0:1:1", },