mirror of
https://github.com/coredns/coredns.git
synced 2025-10-27 16:24:19 -04:00
Fix a crash in rewrite plugin when rule type is missing (#5459)
This commit is contained in:
@@ -104,6 +104,9 @@ func newRule(args ...string) (Rule, error) {
|
|||||||
expectNumArgs = len(args) - 1
|
expectNumArgs = len(args) - 1
|
||||||
startArg = 2
|
startArg = 2
|
||||||
case Stop:
|
case Stop:
|
||||||
|
if len(args) < 2 {
|
||||||
|
return nil, fmt.Errorf("stop rule must begin with a rule type")
|
||||||
|
}
|
||||||
ruleType = strings.ToLower(args[1])
|
ruleType = strings.ToLower(args[1])
|
||||||
expectNumArgs = len(args) - 1
|
expectNumArgs = len(args) - 1
|
||||||
startArg = 2
|
startArg = 2
|
||||||
|
|||||||
@@ -8,60 +8,45 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func TestParse(t *testing.T) {
|
func TestParse(t *testing.T) {
|
||||||
c := caddy.NewTestController("dns", `rewrite`)
|
|
||||||
_, err := rewriteParse(c)
|
|
||||||
if err == nil {
|
|
||||||
t.Errorf("Expected error but found nil for `rewrite`")
|
|
||||||
}
|
|
||||||
c = caddy.NewTestController("dns", `rewrite name`)
|
|
||||||
_, err = rewriteParse(c)
|
|
||||||
if err == nil {
|
|
||||||
t.Errorf("Expected error but found nil for `rewrite name`")
|
|
||||||
}
|
|
||||||
c = caddy.NewTestController("dns", `rewrite name a.com b.com`)
|
|
||||||
_, err = rewriteParse(c)
|
|
||||||
if err != nil {
|
|
||||||
t.Errorf("Expected success but found %s for `rewrite name a.com b.com`", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
c = caddy.NewTestController("dns",
|
tests := []struct {
|
||||||
`rewrite stop {
|
inputFileRules string
|
||||||
|
shouldErr bool
|
||||||
|
errContains string
|
||||||
|
}{
|
||||||
|
// parse errors
|
||||||
|
{`rewrite`, true, ""},
|
||||||
|
{`rewrite name`, true, ""},
|
||||||
|
{`rewrite name a.com b.com`, false, ""},
|
||||||
|
{`rewrite stop {
|
||||||
name regex foo bar
|
name regex foo bar
|
||||||
answer name bar foo
|
answer name bar foo
|
||||||
}`)
|
}`, false, ""},
|
||||||
_, err = rewriteParse(c)
|
{`rewrite stop name regex foo bar answer name bar foo`, false, ""},
|
||||||
if err != nil {
|
{`rewrite stop {
|
||||||
t.Errorf("Expected success but found %s for valid response rewrite", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
c = caddy.NewTestController("dns", `rewrite stop name regex foo bar answer name bar foo`)
|
|
||||||
_, err = rewriteParse(c)
|
|
||||||
if err != nil {
|
|
||||||
t.Errorf("Expected success but found %s for valid response rewrite", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
c = caddy.NewTestController("dns",
|
|
||||||
`rewrite stop {
|
|
||||||
name regex foo bar
|
name regex foo bar
|
||||||
answer name bar foo
|
answer name bar foo
|
||||||
name baz
|
name baz
|
||||||
}`)
|
}`, true, "2 arguments required"},
|
||||||
_, err = rewriteParse(c)
|
{`rewrite stop {
|
||||||
if err == nil {
|
|
||||||
t.Errorf("Expected error but got success for invalid response rewrite")
|
|
||||||
} else if !strings.Contains(err.Error(), "2 arguments required") {
|
|
||||||
t.Errorf("Got wrong error for invalid response rewrite: %v", err.Error())
|
|
||||||
}
|
|
||||||
|
|
||||||
c = caddy.NewTestController("dns",
|
|
||||||
`rewrite stop {
|
|
||||||
answer name bar foo
|
answer name bar foo
|
||||||
name regex foo bar
|
name regex foo bar
|
||||||
}`)
|
}`, true, "must begin with a name rule"},
|
||||||
_, err = rewriteParse(c)
|
{`rewrite stop`, true, ""},
|
||||||
if err == nil {
|
|
||||||
t.Errorf("Expected error but got success for invalid response rewrite")
|
|
||||||
} else if !strings.Contains(err.Error(), "must begin with a name rule") {
|
|
||||||
t.Errorf("Got wrong error for invalid response rewrite: %v", err.Error())
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for i, test := range tests {
|
||||||
|
c := caddy.NewTestController("dns", test.inputFileRules)
|
||||||
|
_, err := rewriteParse(c)
|
||||||
|
if err == nil && test.shouldErr {
|
||||||
|
t.Fatalf("Test %d expected errors, but got no error\n---\n%s", i, test.inputFileRules)
|
||||||
|
} else if err != nil && !test.shouldErr {
|
||||||
|
t.Fatalf("Test %d expected no errors, but got '%v'\n---\n%s", i, err, test.inputFileRules)
|
||||||
|
}
|
||||||
|
|
||||||
|
if err != nil && test.errContains != "" && !strings.Contains(err.Error(), test.errContains) {
|
||||||
|
t.Errorf("Test %d got wrong error for invalid response rewrite: '%v'\n---\n%s", i, err.Error(), test.inputFileRules)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user