`upstream` is not needed as a setting; just set if unconditionally and remove all documentation and tests for it. At some point we want remove the hanlding for `upstream` as well and error out on seeing it. Signed-off-by: Miek Gieben <miek@miek.nl>
64 lines
1.4 KiB
Go
64 lines
1.4 KiB
Go
package route53
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/aws/aws-sdk-go/aws/credentials"
|
|
"github.com/aws/aws-sdk-go/service/route53/route53iface"
|
|
"github.com/mholt/caddy"
|
|
)
|
|
|
|
func TestSetupRoute53(t *testing.T) {
|
|
f := func(credential *credentials.Credentials) route53iface.Route53API {
|
|
return fakeRoute53{}
|
|
}
|
|
|
|
tests := []struct {
|
|
body string
|
|
expectedError bool
|
|
}{
|
|
{`route53`, false},
|
|
{`route53 :`, true},
|
|
{`route53 example.org:12345678`, false},
|
|
{`route53 example.org:12345678 {
|
|
aws_access_key
|
|
}`, true},
|
|
{`route53 example.org:12345678 { }`, false},
|
|
|
|
{`route53 example.org:12345678 { }`, false},
|
|
{`route53 example.org:12345678 { wat
|
|
}`, true},
|
|
{`route53 example.org:12345678 {
|
|
aws_access_key ACCESS_KEY_ID SEKRIT_ACCESS_KEY
|
|
}`, false},
|
|
|
|
{`route53 example.org:12345678 {
|
|
fallthrough
|
|
}`, false},
|
|
{`route53 example.org:12345678 {
|
|
credentials
|
|
}`, true},
|
|
|
|
{`route53 example.org:12345678 {
|
|
credentials default
|
|
}`, false},
|
|
{`route53 example.org:12345678 {
|
|
credentials default credentials
|
|
}`, false},
|
|
{`route53 example.org:12345678 {
|
|
credentials default credentials extra-arg
|
|
}`, true},
|
|
{`route53 example.org:12345678 example.org:12345678 {
|
|
}`, true},
|
|
|
|
{`route53 example.org {
|
|
}`, true},
|
|
}
|
|
|
|
for _, test := range tests {
|
|
c := caddy.NewTestController("dns", test.body)
|
|
if err := setup(c, f); (err == nil) == test.expectedError {
|
|
t.Errorf("Unexpected errors: %v", err)
|
|
}
|
|
}
|
|
}
|