aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGravatar Brad Beam <bradbeam@users.noreply.github.com> 2017-12-13 10:18:08 -0600
committerGravatar John Belamaric <jbelamaric@infoblox.com> 2017-12-13 11:18:08 -0500
commit556a289d9a2ec04583b26c89712000aac578ae89 (patch)
treef62d4d7655f69c06cc1e64a52a0ba6cb293a02d9
parenta469a17cdfccfb435f819ebdf7ff7b43b207c8b4 (diff)
downloadcoredns-556a289d9a2ec04583b26c89712000aac578ae89.tar.gz
coredns-556a289d9a2ec04583b26c89712000aac578ae89.tar.zst
coredns-556a289d9a2ec04583b26c89712000aac578ae89.zip
Moving TransferParse from file to its own package (#1286)
* Moving TransferParse from file to its own package * Adding tests for parse
-rw-r--r--plugin/auto/setup.go4
-rw-r--r--plugin/file/setup.go43
-rw-r--r--plugin/pkg/parse/parse.go47
-rw-r--r--plugin/pkg/parse/parse_test.go92
-rw-r--r--plugin/secondary/setup.go3
5 files changed, 145 insertions, 44 deletions
diff --git a/plugin/auto/setup.go b/plugin/auto/setup.go
index 75966f8a0..7f673f915 100644
--- a/plugin/auto/setup.go
+++ b/plugin/auto/setup.go
@@ -10,9 +10,9 @@ import (
"github.com/coredns/coredns/core/dnsserver"
"github.com/coredns/coredns/plugin"
- "github.com/coredns/coredns/plugin/file"
"github.com/coredns/coredns/plugin/metrics"
"github.com/coredns/coredns/plugin/pkg/dnsutil"
+ "github.com/coredns/coredns/plugin/pkg/parse"
"github.com/coredns/coredns/plugin/proxy"
"github.com/mholt/caddy"
@@ -158,7 +158,7 @@ func autoParse(c *caddy.Controller) (Auto, error) {
a.loader.proxy = proxy.NewLookup(ups)
default:
- t, _, e := file.TransferParse(c, false)
+ t, _, e := parse.Transfer(c, false)
if e != nil {
return a, e
}
diff --git a/plugin/file/setup.go b/plugin/file/setup.go
index bf0523c54..3c25b4f7d 100644
--- a/plugin/file/setup.go
+++ b/plugin/file/setup.go
@@ -1,13 +1,13 @@
package file
import (
- "fmt"
"os"
"path"
"github.com/coredns/coredns/core/dnsserver"
"github.com/coredns/coredns/plugin"
"github.com/coredns/coredns/plugin/pkg/dnsutil"
+ "github.com/coredns/coredns/plugin/pkg/parse"
"github.com/coredns/coredns/plugin/proxy"
"github.com/mholt/caddy"
@@ -97,7 +97,7 @@ func fileParse(c *caddy.Controller) (Zones, error) {
for c.NextBlock() {
switch c.Val() {
case "transfer":
- t, _, e = TransferParse(c, false)
+ t, _, e = parse.Transfer(c, false)
if e != nil {
return Zones{}, e
}
@@ -130,42 +130,3 @@ func fileParse(c *caddy.Controller) (Zones, error) {
}
return Zones{Z: z, Names: names}, nil
}
-
-// TransferParse parses transfer statements: 'transfer to [address...]'.
-func TransferParse(c *caddy.Controller, secondary bool) (tos, froms []string, err error) {
- if !c.NextArg() {
- return nil, nil, c.ArgErr()
- }
- value := c.Val()
- switch value {
- case "to":
- tos = c.RemainingArgs()
- for i := range tos {
- if tos[i] != "*" {
- normalized, err := dnsutil.ParseHostPort(tos[i], "53")
- if err != nil {
- return nil, nil, err
- }
- tos[i] = normalized
- }
- }
-
- case "from":
- if !secondary {
- return nil, nil, fmt.Errorf("can't use `transfer from` when not being a secondary")
- }
- froms = c.RemainingArgs()
- for i := range froms {
- if froms[i] != "*" {
- normalized, err := dnsutil.ParseHostPort(froms[i], "53")
- if err != nil {
- return nil, nil, err
- }
- froms[i] = normalized
- } else {
- return nil, nil, fmt.Errorf("can't use '*' in transfer from")
- }
- }
- }
- return
-}
diff --git a/plugin/pkg/parse/parse.go b/plugin/pkg/parse/parse.go
new file mode 100644
index 000000000..cf4f96c09
--- /dev/null
+++ b/plugin/pkg/parse/parse.go
@@ -0,0 +1,47 @@
+package parse
+
+import (
+ "fmt"
+
+ "github.com/coredns/coredns/plugin/pkg/dnsutil"
+ "github.com/mholt/caddy"
+)
+
+// Transfer parses transfer statements: 'transfer [to|from] [address...]'.
+func Transfer(c *caddy.Controller, secondary bool) (tos, froms []string, err error) {
+ if !c.NextArg() {
+ return nil, nil, c.ArgErr()
+ }
+ value := c.Val()
+ switch value {
+ case "to":
+ tos = c.RemainingArgs()
+ for i := range tos {
+ if tos[i] != "*" {
+ normalized, err := dnsutil.ParseHostPort(tos[i], "53")
+ if err != nil {
+ return nil, nil, err
+ }
+ tos[i] = normalized
+ }
+ }
+
+ case "from":
+ if !secondary {
+ return nil, nil, fmt.Errorf("can't use `transfer from` when not being a secondary")
+ }
+ froms = c.RemainingArgs()
+ for i := range froms {
+ if froms[i] != "*" {
+ normalized, err := dnsutil.ParseHostPort(froms[i], "53")
+ if err != nil {
+ return nil, nil, err
+ }
+ froms[i] = normalized
+ } else {
+ return nil, nil, fmt.Errorf("can't use '*' in transfer from")
+ }
+ }
+ }
+ return
+}
diff --git a/plugin/pkg/parse/parse_test.go b/plugin/pkg/parse/parse_test.go
new file mode 100644
index 000000000..b1aa3730f
--- /dev/null
+++ b/plugin/pkg/parse/parse_test.go
@@ -0,0 +1,92 @@
+package parse
+
+import (
+ "testing"
+
+ "github.com/mholt/caddy"
+)
+
+func TestTransfer(t *testing.T) {
+ tests := []struct {
+ inputFileRules string
+ shouldErr bool
+ secondary bool
+ expectedTo []string
+ expectedFrom []string
+ }{
+ // OK transfer to
+ {
+ `to 127.0.0.1`,
+ false, false, []string{"127.0.0.1:53"}, []string{},
+ },
+ // OK transfer tos
+ {
+ `to 127.0.0.1 127.0.0.2`,
+ false, false, []string{"127.0.0.1:53", "127.0.0.2:53"}, []string{},
+ },
+ // OK transfer from
+ {
+ `from 127.0.0.1`,
+ false, true, []string{}, []string{"127.0.0.1:53"},
+ },
+ // OK transfer froms
+ {
+ `from 127.0.0.1 127.0.0.2`,
+ false, true, []string{}, []string{"127.0.0.1:53", "127.0.0.2:53"},
+ },
+ // OK transfer tos/froms
+ {
+ `to 127.0.0.1 127.0.0.2
+ from 127.0.0.1 127.0.0.2`,
+ false, true, []string{"127.0.0.1:53", "127.0.0.2:53"}, []string{"127.0.0.1:53", "127.0.0.2:53"},
+ },
+ // Bad transfer from, secondary false
+ {
+ `from 127.0.0.1`,
+ true, false, []string{}, []string{},
+ },
+ // Bad transfer from garbage
+ {
+ `from !@#$%^&*()`,
+ true, true, []string{}, []string{},
+ },
+ // Bad transfer from no args
+ {
+ `from`,
+ true, false, []string{}, []string{},
+ },
+ // Bad transfer from *
+ {
+ `from *`,
+ true, true, []string{}, []string{},
+ },
+ }
+
+ for i, test := range tests {
+ c := caddy.NewTestController("dns", test.inputFileRules)
+ tos, froms, err := Transfer(c, test.secondary)
+
+ if err == nil && test.shouldErr {
+ t.Fatalf("Test %d expected errors, but got no error %+v %+v", i, err, test)
+ } else if err != nil && !test.shouldErr {
+ t.Fatalf("Test %d expected no errors, but got '%v'", i, err)
+ }
+
+ if test.expectedTo != nil {
+ for j, got := range tos {
+ if got != test.expectedTo[j] {
+ t.Fatalf("Test %d expected %v, got %v", i, test.expectedTo[j], got)
+ }
+ }
+ }
+ if test.expectedFrom != nil {
+ for j, got := range froms {
+ if got != test.expectedFrom[j] {
+ t.Fatalf("Test %d expected %v, got %v", i, test.expectedFrom[j], got)
+ }
+ }
+ }
+
+ }
+
+}
diff --git a/plugin/secondary/setup.go b/plugin/secondary/setup.go
index e2819197d..1e9a3f5fd 100644
--- a/plugin/secondary/setup.go
+++ b/plugin/secondary/setup.go
@@ -5,6 +5,7 @@ import (
"github.com/coredns/coredns/plugin"
"github.com/coredns/coredns/plugin/file"
"github.com/coredns/coredns/plugin/pkg/dnsutil"
+ "github.com/coredns/coredns/plugin/pkg/parse"
"github.com/coredns/coredns/plugin/proxy"
"github.com/mholt/caddy"
@@ -74,7 +75,7 @@ func secondaryParse(c *caddy.Controller) (file.Zones, error) {
switch c.Val() {
case "transfer":
- t, f, e = file.TransferParse(c, true)
+ t, f, e = parse.Transfer(c, true)
if e != nil {
return file.Zones{}, e
}