Skip to content

Commit

Permalink
Support multiple values for extra_hosts
Browse files Browse the repository at this point in the history
Signed-off-by: Nicolas De Loof <nicolas.deloof@gmail.com>
  • Loading branch information
ndeloof committed Sep 2, 2024
1 parent e2590ce commit 0fd3e31
Show file tree
Hide file tree
Showing 6 changed files with 78 additions and 14 deletions.
32 changes: 32 additions & 0 deletions loader/loader_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -3377,3 +3377,35 @@ services:
},
})
}

func TestLoadExtraHostsRepeated(t *testing.T) {
p, err := loadYAML(`
name: load-extra-hosts
services:
test:
extra_hosts:
- "myhost=0.0.0.1,0.0.0.2"
`)
assert.NilError(t, err)
hosts := p.Services["test"].ExtraHosts
assert.DeepEqual(t, hosts, types.HostsList{
"myhost": []string{"0.0.0.1", "0.0.0.2"},
})
}

func TestLoadExtraHostsLongSyntax(t *testing.T) {
p, err := loadYAML(`
name: load-extra-hosts
services:
test:
extra_hosts:
myhost:
- "0.0.0.1"
- "0.0.0.2"
`)
assert.NilError(t, err)
hosts := p.Services["test"].ExtraHosts
assert.DeepEqual(t, hosts, types.HostsList{
"myhost": []string{"0.0.0.1", "0.0.0.2"},
})
}
1 change: 1 addition & 0 deletions override/merge_build_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -82,6 +82,7 @@ services:
- "registry/username/myrepos:my-other-tag"
extra_hosts:
- "somehost=162.242.195.82"
- "otherhost=50.31.209.229"
- "otherhost=50.31.209.230"
- "myhostv6=::1"
`)
Expand Down
14 changes: 6 additions & 8 deletions override/uncity.go
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,6 @@ func init() {
unique["services.*.annotations"] = keyValueIndexer
unique["services.*.build.args"] = keyValueIndexer
unique["services.*.build.additional_contexts"] = keyValueIndexer
unique["services.*.build.extra_hosts"] = keyValueIndexer
unique["services.*.build.platform"] = keyValueIndexer
unique["services.*.build.tags"] = keyValueIndexer
unique["services.*.build.labels"] = keyValueIndexer
Expand All @@ -51,7 +50,6 @@ func init() {
unique["services.*.environment"] = keyValueIndexer
unique["services.*.env_file"] = envFileIndexer
unique["services.*.expose"] = exposeIndexer
unique["services.*.extra_hosts"] = keyValueIndexer
unique["services.*.labels"] = keyValueIndexer
unique["services.*.links"] = keyValueIndexer
unique["services.*.networks.*.aliases"] = keyValueIndexer
Expand Down Expand Up @@ -109,16 +107,16 @@ func enforceUnicity(value any, p tree.Path) (any, error) {
return value, nil
}

func keyValueIndexer(y any, p tree.Path) (string, error) {
switch value := y.(type) {
func keyValueIndexer(v any, p tree.Path) (string, error) {
switch value := v.(type) {
case string:
key, _, found := strings.Cut(value, "=")
if !found {
return value, nil
if found {
return key, nil
}
return key, nil
return value, nil
default:
return "", fmt.Errorf("%s: unexpected type %T", p, y)
return "", fmt.Errorf("%s: unexpected type %T", p, v)
}
}

Expand Down
19 changes: 17 additions & 2 deletions schema/compose-spec.json
Original file line number Diff line number Diff line change
Expand Up @@ -115,7 +115,7 @@
"pull": {"type": ["boolean", "string"]},
"target": {"type": "string"},
"shm_size": {"type": ["integer", "string"]},
"extra_hosts": {"$ref": "#/definitions/list_or_dict"},
"extra_hosts": {"$ref": "#/definitions/extra_hosts"},
"isolation": {"type": "string"},
"privileged": {"type": ["boolean", "string"]},
"secrets": {"$ref": "#/definitions/service_config_or_secret"},
Expand Down Expand Up @@ -267,7 +267,7 @@
]
},
"external_links": {"type": "array", "items": {"type": "string"}, "uniqueItems": true},
"extra_hosts": {"$ref": "#/definitions/list_or_dict"},
"extra_hosts": {"$ref": "#/definitions/extra_hosts"},
"group_add": {
"type": "array",
"items": {
Expand Down Expand Up @@ -872,6 +872,21 @@
]
},

"extra_hosts": {
"oneOf": [
{
"type": "object",
"patternProperties": {
".+": {
"type": ["string", "array"]
}
},
"additionalProperties": false
},
{"type": "array", "items": {"type": "string"}, "uniqueItems": true}
]
},

"blkio_limit": {
"type": "object",
"properties": {
Expand Down
19 changes: 15 additions & 4 deletions types/hostList.go
Original file line number Diff line number Diff line change
Expand Up @@ -36,9 +36,9 @@ func NewHostsList(hosts []string) (HostsList, error) {
if ok {
// Mapping found with this separator, stop here.
if ips, ok := list[host]; ok {
list[host] = append(ips, ip)
list[host] = append(ips, strings.Split(ip, ",")...)
} else {
list[host] = []string{ip}
list[host] = strings.Split(ip, ",")
}
found = true
break
Expand Down Expand Up @@ -89,7 +89,18 @@ func (h *HostsList) DecodeMapstructure(value interface{}) error {
if e == nil {
e = ""
}
list[i] = []string{fmt.Sprint(e)}
switch t := e.(type) {
case string:
list[i] = []string{t}
case []any:
hosts := make([]string, len(t))
for j, h := range t {
hosts[j] = fmt.Sprint(h)
}
list[i] = hosts
default:
return fmt.Errorf("unexpected value type %T for extra_hosts entry", value)
}
}
err := list.cleanup()
if err != nil {
Expand All @@ -109,7 +120,7 @@ func (h *HostsList) DecodeMapstructure(value interface{}) error {
*h = list
return nil
default:
return fmt.Errorf("unexpected value type %T for mapping", value)
return fmt.Errorf("unexpected value type %T for extra_hosts", value)
}
}

Expand Down
7 changes: 7 additions & 0 deletions types/hostList_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -107,6 +107,13 @@ func testHostsList(t *testing.T, sep string) {
},
expectedOut: "foo:127.0.0.2 foo:ff02::1",
},
{
doc: "list of values",
input: []string{
"foo=127.0.0.2,127.0.0.3",
},
expectedOut: "foo:127.0.0.2 foo:127.0.0.3",
},
}

for _, tc := range testCases {
Expand Down

0 comments on commit 0fd3e31

Please sign in to comment.