bugfix user defined prefix can not setup correctly
parent
6d32202353
commit
e57765b5af
3
setup.go
3
setup.go
|
@ -60,7 +60,8 @@ func dns64Parse(c *caddy.Controller) (proxy.Proxy, *net.IPNet, error) {
|
||||||
if !c.NextArg() {
|
if !c.NextArg() {
|
||||||
return prxy, pref, c.ArgErr()
|
return prxy, pref, c.ArgErr()
|
||||||
}
|
}
|
||||||
_, pref, err := net.ParseCIDR(c.Val())
|
var err error
|
||||||
|
_, pref, err = net.ParseCIDR(c.Val())
|
||||||
|
|
||||||
// test for valid prefix
|
// test for valid prefix
|
||||||
n, total := pref.Mask.Size()
|
n, total := pref.Mask.Size()
|
||||||
|
|
|
@ -10,58 +10,68 @@ func TestSetupDns64(t *testing.T) {
|
||||||
tests := []struct {
|
tests := []struct {
|
||||||
inputUpstreams string
|
inputUpstreams string
|
||||||
shouldErr bool
|
shouldErr bool
|
||||||
|
prefix string
|
||||||
}{
|
}{
|
||||||
{
|
{
|
||||||
`dns64`,
|
`dns64`,
|
||||||
false,
|
false,
|
||||||
|
"64:ff9b::/96",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
`dns64 {
|
`dns64 {
|
||||||
upstream 8.8.8.8
|
upstream 8.8.8.8
|
||||||
}`,
|
}`,
|
||||||
false,
|
false,
|
||||||
|
"64:ff9b::/96",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
`dns64 {
|
`dns64 {
|
||||||
prefix 64:ff9b::/96
|
prefix 64:ff9b::/96
|
||||||
}`,
|
}`,
|
||||||
false,
|
false,
|
||||||
|
"64:ff9b::/96",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
`dns64 {
|
`dns64 {
|
||||||
prefix 64:ff9b::/32
|
prefix 64:ff9b::/32
|
||||||
}`,
|
}`,
|
||||||
false,
|
false,
|
||||||
|
"64:ff9b::/32",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
`dns64 {
|
`dns64 {
|
||||||
prefix 64:ff9b::/52
|
prefix 64:ff9b::/52
|
||||||
}`,
|
}`,
|
||||||
true,
|
true,
|
||||||
|
"64:ff9b::/52",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
`dns64 {
|
`dns64 {
|
||||||
prefix 64:ff9b::/104
|
prefix 64:ff9b::/104
|
||||||
}`,
|
}`,
|
||||||
true,
|
true,
|
||||||
|
"64:ff9b::/104",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
`dns64 {
|
`dns64 {
|
||||||
prefix 8.8.8.8/24
|
prefix 8.8.8.8/24
|
||||||
}`,
|
}`,
|
||||||
true,
|
true,
|
||||||
|
"8.8.9.9/24",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
`dns64 {
|
`dns64 {
|
||||||
upstream 8.8.8.8 8.8.4.4
|
upstream 8.8.8.8 8.8.4.4
|
||||||
}`,
|
}`,
|
||||||
false,
|
false,
|
||||||
|
"64:ff9b::/96",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
`dns64 {
|
`dns64 {
|
||||||
upstream some_not_useable_domain
|
upstream some_not_useable_domain
|
||||||
}`,
|
}`,
|
||||||
true,
|
true,
|
||||||
|
"64:ff9b::/96",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
`dns64 {
|
`dns64 {
|
||||||
|
@ -69,6 +79,23 @@ func TestSetupDns64(t *testing.T) {
|
||||||
upstream 8.8.8.8
|
upstream 8.8.8.8
|
||||||
}`,
|
}`,
|
||||||
false,
|
false,
|
||||||
|
"64:ff9b::/96",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
`dns64 {
|
||||||
|
prefix 2002:ac12:b083::/96
|
||||||
|
upstream 8.8.8.8
|
||||||
|
}`,
|
||||||
|
false,
|
||||||
|
"2002:ac12:b083::/96",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
`dns64 {
|
||||||
|
prefix 2002:c0a8:a88a::/48
|
||||||
|
upstream 8.8.8.8
|
||||||
|
}`,
|
||||||
|
false,
|
||||||
|
"2002:c0a8:a88a::/48",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
`dns64 foobar {
|
`dns64 foobar {
|
||||||
|
@ -76,24 +103,32 @@ func TestSetupDns64(t *testing.T) {
|
||||||
upstream 8.8.8.8
|
upstream 8.8.8.8
|
||||||
}`,
|
}`,
|
||||||
true,
|
true,
|
||||||
|
"64:ff9b::/96",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
`dns64 foobar`,
|
`dns64 foobar`,
|
||||||
true,
|
true,
|
||||||
|
"64:ff9b::/96",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
`dns64 {
|
`dns64 {
|
||||||
foobar
|
foobar
|
||||||
}`,
|
}`,
|
||||||
true,
|
true,
|
||||||
|
"64:ff9b::/96",
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
for i, test := range tests {
|
for i, test := range tests {
|
||||||
c := caddy.NewTestController("dns", test.inputUpstreams)
|
c := caddy.NewTestController("dns", test.inputUpstreams)
|
||||||
_, _, err := dns64Parse(c)
|
_, pref, err := dns64Parse(c)
|
||||||
if (err != nil) != test.shouldErr {
|
if (err != nil) != test.shouldErr {
|
||||||
t.Errorf("Test %d expected %v error, got %v for %s", i+1, test.shouldErr, err, test.inputUpstreams)
|
t.Errorf("Test %d expected %v error, got %v for %s", i+1, test.shouldErr, err, test.inputUpstreams)
|
||||||
}
|
}
|
||||||
|
if err == nil {
|
||||||
|
if pref.String() != test.prefix {
|
||||||
|
t.Errorf("Test %d expected prefix %s, got %v", i+1, test.prefix, pref.String())
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue