2016-11-26 21:23:22 +07:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"flag"
|
2016-11-28 00:41:54 +07:00
|
|
|
"fmt"
|
2017-08-02 23:25:27 +07:00
|
|
|
log "github.com/sirupsen/logrus"
|
|
|
|
logrustest "github.com/sirupsen/logrus/hooks/test"
|
2016-11-28 21:25:42 +07:00
|
|
|
"io/ioutil"
|
2016-11-26 21:23:22 +07:00
|
|
|
"os"
|
2018-10-31 05:54:51 +07:00
|
|
|
"sync"
|
2016-11-26 21:23:22 +07:00
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
2016-11-28 21:25:42 +07:00
|
|
|
var loghook = new(logrustest.Hook)
|
|
|
|
|
2016-11-28 00:41:54 +07:00
|
|
|
var (
|
|
|
|
postgres = flag.Bool("postgres", false, "run integration tests against PostgreSQL")
|
|
|
|
)
|
|
|
|
|
2016-11-28 20:39:52 +07:00
|
|
|
var records = []string{
|
|
|
|
"auth.example.org. A 192.168.1.100",
|
|
|
|
"ns1.auth.example.org. A 192.168.1.101",
|
|
|
|
"!''b', unparseable ",
|
|
|
|
"ns2.auth.example.org. A 192.168.1.102",
|
|
|
|
}
|
|
|
|
|
2016-11-26 21:23:22 +07:00
|
|
|
func TestMain(m *testing.M) {
|
2016-11-28 21:25:42 +07:00
|
|
|
setupTestLogger()
|
2016-11-28 00:41:54 +07:00
|
|
|
setupConfig()
|
2017-11-14 05:42:30 +07:00
|
|
|
RR.Parse(Config.General)
|
2016-11-26 21:23:22 +07:00
|
|
|
flag.Parse()
|
2016-11-28 00:41:54 +07:00
|
|
|
|
2016-11-28 04:21:46 +07:00
|
|
|
newDb := new(acmedb)
|
2016-11-28 00:41:54 +07:00
|
|
|
if *postgres {
|
2017-11-14 05:42:30 +07:00
|
|
|
Config.Database.Engine = "postgres"
|
2016-11-28 04:21:46 +07:00
|
|
|
err := newDb.Init("postgres", "postgres://acmedns:acmedns@localhost/acmedns")
|
2016-11-28 00:41:54 +07:00
|
|
|
if err != nil {
|
|
|
|
fmt.Println("PostgreSQL integration tests expect database \"acmedns\" running in localhost, with username and password set to \"acmedns\"")
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
|
|
|
} else {
|
2017-11-14 05:42:30 +07:00
|
|
|
Config.Database.Engine = "sqlite3"
|
2016-11-28 04:21:46 +07:00
|
|
|
_ = newDb.Init("sqlite3", ":memory:")
|
2016-11-28 00:41:54 +07:00
|
|
|
}
|
2016-11-28 04:21:46 +07:00
|
|
|
DB = newDb
|
2018-10-31 05:54:51 +07:00
|
|
|
server := setupDNSServer()
|
|
|
|
// Make sure that we're not creating a race condition in tests
|
|
|
|
var wg sync.WaitGroup
|
|
|
|
wg.Add(1)
|
|
|
|
server.NotifyStartedFunc = func() {
|
|
|
|
wg.Done()
|
|
|
|
}
|
|
|
|
go startDNS(server, make(chan error, 1))
|
|
|
|
wg.Wait()
|
2016-11-26 21:23:22 +07:00
|
|
|
exitval := m.Run()
|
|
|
|
server.Shutdown()
|
2016-11-28 04:21:46 +07:00
|
|
|
DB.Close()
|
2016-11-26 21:23:22 +07:00
|
|
|
os.Exit(exitval)
|
|
|
|
}
|
2016-11-28 00:41:54 +07:00
|
|
|
|
|
|
|
func setupConfig() {
|
|
|
|
var dbcfg = dbsettings{
|
|
|
|
Engine: "sqlite3",
|
|
|
|
Connection: ":memory:",
|
|
|
|
}
|
|
|
|
|
|
|
|
var generalcfg = general{
|
2016-11-28 20:39:52 +07:00
|
|
|
Domain: "auth.example.org",
|
2018-10-31 05:54:51 +07:00
|
|
|
Listen: "127.0.0.1:15353",
|
|
|
|
Proto: "udp",
|
2016-11-28 20:39:52 +07:00
|
|
|
Nsname: "ns1.auth.example.org",
|
|
|
|
Nsadmin: "admin.example.org",
|
|
|
|
StaticRecords: records,
|
|
|
|
Debug: false,
|
2016-11-28 00:41:54 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
var httpapicfg = httpapi{
|
|
|
|
Domain: "",
|
|
|
|
Port: "8080",
|
|
|
|
TLS: "none",
|
|
|
|
CorsOrigins: []string{"*"},
|
2016-12-02 22:04:16 +07:00
|
|
|
UseHeader: false,
|
|
|
|
HeaderName: "X-Forwarded-For",
|
2016-11-28 00:41:54 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
var dnscfg = DNSConfig{
|
|
|
|
Database: dbcfg,
|
|
|
|
General: generalcfg,
|
|
|
|
API: httpapicfg,
|
|
|
|
}
|
|
|
|
|
2017-11-14 05:42:30 +07:00
|
|
|
Config = dnscfg
|
2016-11-28 00:41:54 +07:00
|
|
|
}
|
2016-11-28 21:25:42 +07:00
|
|
|
|
|
|
|
func setupTestLogger() {
|
|
|
|
log.SetOutput(ioutil.Discard)
|
|
|
|
log.AddHook(loghook)
|
|
|
|
}
|
2016-11-29 03:46:24 +07:00
|
|
|
|
|
|
|
func loggerHasEntryWithMessage(message string) bool {
|
|
|
|
for _, v := range loghook.Entries {
|
|
|
|
if v.Message == message {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|