mirror of
https://github.com/coredns/coredns.git
synced 2025-10-28 08:44:17 -04:00
dont panic when from-zone cannot be normalized (#5170)
Signed-off-by: Chris O'Haver <cohaver@infoblox.com>
This commit is contained in:
@@ -94,6 +94,9 @@ func parseStanza(c *caddy.Controller) (*Forward, error) {
|
|||||||
}
|
}
|
||||||
origFrom := f.from
|
origFrom := f.from
|
||||||
zones := plugin.Host(f.from).NormalizeExact()
|
zones := plugin.Host(f.from).NormalizeExact()
|
||||||
|
if len(zones) == 0 {
|
||||||
|
return f, fmt.Errorf("unable to normalize '%s'", f.from)
|
||||||
|
}
|
||||||
f.from = zones[0] // there can only be one here, won't work with non-octet reverse
|
f.from = zones[0] // there can only be one here, won't work with non-octet reverse
|
||||||
|
|
||||||
if len(zones) > 1 {
|
if len(zones) > 1 {
|
||||||
|
|||||||
@@ -38,6 +38,7 @@ func TestSetup(t *testing.T) {
|
|||||||
{`forward . ::1
|
{`forward . ::1
|
||||||
forward com ::2`, true, "", nil, 0, options{hcRecursionDesired: true}, "plugin"},
|
forward com ::2`, true, "", nil, 0, options{hcRecursionDesired: true}, "plugin"},
|
||||||
{"forward . https://127.0.0.1 \n", true, ".", nil, 2, options{hcRecursionDesired: true}, "'https' is not supported as a destination protocol in forward: https://127.0.0.1"},
|
{"forward . https://127.0.0.1 \n", true, ".", nil, 2, options{hcRecursionDesired: true}, "'https' is not supported as a destination protocol in forward: https://127.0.0.1"},
|
||||||
|
{"forward xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx 127.0.0.1 \n", true, ".", nil, 2, options{hcRecursionDesired: true}, "unable to normalize 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'"},
|
||||||
}
|
}
|
||||||
|
|
||||||
for i, test := range tests {
|
for i, test := range tests {
|
||||||
|
|||||||
Reference in New Issue
Block a user