aboutsummaryrefslogtreecommitdiff
path: root/plugin/forward/setup_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'plugin/forward/setup_test.go')
-rw-r--r--plugin/forward/setup_test.go40
1 files changed, 39 insertions, 1 deletions
diff --git a/plugin/forward/setup_test.go b/plugin/forward/setup_test.go
index ae0c991d9..c2c2f6759 100644
--- a/plugin/forward/setup_test.go
+++ b/plugin/forward/setup_test.go
@@ -168,7 +168,45 @@ nameserver 10.10.255.253`), 0666); err != nil {
}
}
for _, p := range f.proxies {
- p.health.Check(p) // this should almost always err, we don't care it shoulnd't crash
+ p.health.Check(p) // this should almost always err, we don't care it shouldn't crash
+ }
+ }
+}
+
+func TestSetupMaxConcurrent(t *testing.T) {
+ tests := []struct {
+ input string
+ shouldErr bool
+ expectedVal int64
+ expectedErr string
+ }{
+ // positive
+ {"forward . 127.0.0.1 {\nmax_concurrent 1000\n}\n", false, 1000, ""},
+ // negative
+ {"forward . 127.0.0.1 {\nmax_concurrent many\n}\n", true, 0, "invalid"},
+ {"forward . 127.0.0.1 {\nmax_concurrent -4\n}\n", true, 0, "negative"},
+ }
+
+ for i, test := range tests {
+ c := caddy.NewTestController("dns", test.input)
+ f, err := parseForward(c)
+
+ if test.shouldErr && err == nil {
+ t.Errorf("Test %d: expected error but found %s for input %s", i, err, test.input)
+ }
+
+ if err != nil {
+ if !test.shouldErr {
+ t.Errorf("Test %d: expected no error but found one for input %s, got: %v", i, test.input, err)
+ }
+
+ if !strings.Contains(err.Error(), test.expectedErr) {
+ t.Errorf("Test %d: expected error to contain: %v, found error: %v, input: %s", i, test.expectedErr, err, test.input)
+ }
+ }
+
+ if !test.shouldErr && f.maxConcurrent != test.expectedVal {
+ t.Errorf("Test %d: expected: %d, got: %d", i, test.expectedVal, f.maxConcurrent)
}
}
}