aboutsummaryrefslogtreecommitdiff
path: root/plugin/geoip/setup_test.go
diff options
context:
space:
mode:
authorGravatar Sven Nebel <nebel.sven@gmail.com> 2021-07-14 08:25:30 +0100
committerGravatar GitHub <noreply@github.com> 2021-07-14 09:25:30 +0200
commit21f1207afee6915c14e1109834e3fc0dfed9f420 (patch)
tree19423b6bf9a4ed6b4b43576eb31547441bab07a3 /plugin/geoip/setup_test.go
parent936b483a3afdb532180dd6da6fa3c686c5ca9ee9 (diff)
downloadcoredns-21f1207afee6915c14e1109834e3fc0dfed9f420.tar.gz
coredns-21f1207afee6915c14e1109834e3fc0dfed9f420.tar.zst
coredns-21f1207afee6915c14e1109834e3fc0dfed9f420.zip
Create geoip plugin (#4688)
* Create geoip plugin Signed-off-by: Sven Nebel <nebel.sven@gmail.com> * Update plugin/geoip/README.md Co-authored-by: Miek Gieben <miek@miek.nl> Signed-off-by: Sven Nebel <nebel.sven@gmail.com> * Update plugin/geoip/README.md Co-authored-by: Miek Gieben <miek@miek.nl> Signed-off-by: Sven Nebel <nebel.sven@gmail.com> * Update plugin/geoip/README.md Co-authored-by: Miek Gieben <miek@miek.nl> Signed-off-by: Sven Nebel <nebel.sven@gmail.com> * Move DBFILE bullet below example Signed-off-by: Sven Nebel <nebel.sven@gmail.com> * Update plugin/geoip/README.md Co-authored-by: Miek Gieben <miek@miek.nl> Signed-off-by: Sven Nebel <nebel.sven@gmail.com> * Remove plugin name test case Signed-off-by: Sven Nebel <nebel.sven@gmail.com> * Remove languages option Signed-off-by: Sven Nebel <nebel.sven@gmail.com> * Update free database link Signed-off-by: Sven Nebel <nebel.sven@gmail.com> * Remove last language bits Signed-off-by: Sven Nebel <nebel.sven@gmail.com> * Use 127.0.0.1 as probing IP Signed-off-by: Sven Nebel <nebel.sven@gmail.com> * Update plugin/geoip/geoip.go Co-authored-by: Miek Gieben <miek@miek.nl> Signed-off-by: Sven Nebel <nebel.sven@gmail.com> * Update plugin/geoip/geoip.go Co-authored-by: Miek Gieben <miek@miek.nl> Signed-off-by: Sven Nebel <nebel.sven@gmail.com> * Use relative path for fixtures dir Signed-off-by: Sven Nebel <nebel.sven@gmail.com> * Set names with default string zero value Signed-off-by: Sven Nebel <nebel.sven@gmail.com> * Remove unused db types Signed-off-by: Sven Nebel <nebel.sven@gmail.com> * Remove non city databases in testdata Signed-off-by: Sven Nebel <nebel.sven@gmail.com> * Remove create databases main Signed-off-by: Sven Nebel <nebel.sven@gmail.com> * Fix metadata label format test case Signed-off-by: Sven Nebel <nebel.sven@gmail.com> * Fix import path block Signed-off-by: Sven Nebel <nebel.sven@gmail.com> * go fmt after changes Signed-off-by: Sven Nebel <nebel.sven@gmail.com> * Tidy up go.mod and go.sum Signed-off-by: Sven Nebel <nebel.sven@gmail.com> * Add plugin to CODEOWNERS Signed-off-by: Sven Nebel <nebel.sven@gmail.com> Co-authored-by: Miek Gieben <miek@miek.nl>
Diffstat (limited to 'plugin/geoip/setup_test.go')
-rw-r--r--plugin/geoip/setup_test.go109
1 files changed, 109 insertions, 0 deletions
diff --git a/plugin/geoip/setup_test.go b/plugin/geoip/setup_test.go
new file mode 100644
index 000000000..94d40adbc
--- /dev/null
+++ b/plugin/geoip/setup_test.go
@@ -0,0 +1,109 @@
+package geoip
+
+import (
+ "fmt"
+ "net"
+ "path/filepath"
+ "strings"
+ "testing"
+
+ "github.com/coredns/caddy"
+ "github.com/coredns/coredns/core/dnsserver"
+)
+
+var (
+ fixturesDir = "./testdata"
+ cityDBPath = filepath.Join(fixturesDir, "GeoLite2-City.mmdb")
+ unknownDBPath = filepath.Join(fixturesDir, "GeoLite2-UnknownDbType.mmdb")
+)
+
+func TestProbingIP(t *testing.T) {
+ if probingIP == nil {
+ t.Fatalf("Invalid probing IP: %q", probingIP)
+ }
+}
+
+func TestSetup(t *testing.T) {
+ c := caddy.NewTestController("dns", fmt.Sprintf("%s %s", pluginName, cityDBPath))
+ plugins := dnsserver.GetConfig(c).Plugin
+ if len(plugins) != 0 {
+ t.Fatalf("Expected zero plugins after setup, %d found", len(plugins))
+ }
+ if err := setup(c); err != nil {
+ t.Fatalf("Expected no errors, but got: %v", err)
+ }
+ plugins = dnsserver.GetConfig(c).Plugin
+ if len(plugins) != 1 {
+ t.Fatalf("Expected one plugin after setup, %d found", len(plugins))
+ }
+}
+
+func TestGeoIPParse(t *testing.T) {
+ c := caddy.NewTestController("dns", fmt.Sprintf("%s %s", pluginName, cityDBPath))
+ if err := setup(c); err != nil {
+ t.Fatalf("Expected no errors, but got: %v", err)
+ }
+
+ tests := []struct {
+ shouldErr bool
+ config string
+ expectedErr string
+ expectedDBType int
+ }{
+ // Valid
+ {false, fmt.Sprintf("%s %s\n", pluginName, cityDBPath), "", city},
+
+ // Invalid
+ {true, pluginName, "Wrong argument count", 0},
+ {true, fmt.Sprintf("%s %s {\n\tlanguages en fr es zh-CN\n}\n", pluginName, cityDBPath), "unexpected config block", 0},
+ {true, fmt.Sprintf("%s %s\n%s %s\n", pluginName, cityDBPath, pluginName, cityDBPath), "configuring multiple databases is not supported", 0},
+ {true, fmt.Sprintf("%s 1 2 3", pluginName), "Wrong argument count", 0},
+ {true, fmt.Sprintf("%s { }", pluginName), "Error during parsing", 0},
+ {true, fmt.Sprintf("%s /dbpath { city }", pluginName), "unexpected config block", 0},
+ {true, fmt.Sprintf("%s /invalidPath\n", pluginName), "failed to open database file: open /invalidPath: no such file or directory", 0},
+ {true, fmt.Sprintf("%s %s\n", pluginName, unknownDBPath), "reader does not support the \"UnknownDbType\" database type", 0},
+ }
+
+ for i, test := range tests {
+ c := caddy.NewTestController("dns", test.config)
+ geoIP, err := geoipParse(c)
+
+ if test.shouldErr && err == nil {
+ t.Errorf("Test %d: expected error but found none for input %s", i, test.config)
+ }
+
+ if err != nil {
+ if !test.shouldErr {
+ t.Errorf("Test %d: expected no error but found one for input %s, got: %v", i, test.config, 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.config)
+ }
+ continue
+ }
+
+ if geoIP.db.Reader == nil {
+ t.Errorf("Test %d: after parsing database reader should be initialized", i)
+ }
+
+ if geoIP.db.provides&test.expectedDBType == 0 {
+ t.Errorf("Test %d: expected db type %d not found, database file provides %d", i, test.expectedDBType, geoIP.db.provides)
+ }
+ }
+
+ // Set nil probingIP to test unexpected validate error()
+ defer func(ip net.IP) { probingIP = ip }(probingIP)
+ probingIP = nil
+
+ c = caddy.NewTestController("dns", fmt.Sprintf("%s %s\n", pluginName, cityDBPath))
+ _, err := geoipParse(c)
+ if err != nil {
+ expectedErr := "unexpected failure looking up database"
+ if !strings.Contains(err.Error(), expectedErr) {
+ t.Errorf("expected error to contain: %s", expectedErr)
+ }
+ } else {
+ t.Errorf("with a nil probingIP test is expected to fail")
+ }
+}