2016-08-23 08:31:50 +08:00
|
|
|
package js
|
|
|
|
|
|
|
|
import (
|
2020-12-03 22:33:39 +08:00
|
|
|
"bytes"
|
2016-08-23 08:31:50 +08:00
|
|
|
"encoding/json"
|
2020-12-03 22:33:39 +08:00
|
|
|
"fmt"
|
2016-08-23 08:31:50 +08:00
|
|
|
"io/ioutil"
|
|
|
|
"os"
|
|
|
|
"path/filepath"
|
|
|
|
"testing"
|
2017-03-28 06:01:12 +08:00
|
|
|
"unicode"
|
2016-08-23 08:31:50 +08:00
|
|
|
|
2020-10-08 04:03:36 +08:00
|
|
|
testifyrequire "github.com/stretchr/testify/require"
|
2020-12-03 22:33:39 +08:00
|
|
|
|
|
|
|
"github.com/StackExchange/dnscontrol/v3/pkg/normalize"
|
|
|
|
"github.com/StackExchange/dnscontrol/v3/pkg/prettyzone"
|
|
|
|
"github.com/StackExchange/dnscontrol/v3/providers"
|
|
|
|
_ "github.com/StackExchange/dnscontrol/v3/providers/_all"
|
2016-08-23 08:31:50 +08:00
|
|
|
)
|
|
|
|
|
2016-12-17 04:10:27 +08:00
|
|
|
const (
|
2017-05-26 02:25:39 +08:00
|
|
|
testDir = "pkg/js/parse_tests"
|
|
|
|
errorDir = "pkg/js/error_tests"
|
2016-12-17 04:10:27 +08:00
|
|
|
)
|
2016-08-23 08:31:50 +08:00
|
|
|
|
2016-12-17 04:10:27 +08:00
|
|
|
func init() {
|
2017-05-26 02:25:39 +08:00
|
|
|
os.Chdir("../..") // go up a directory so we helpers.js is in a consistent place.
|
2016-12-17 04:10:27 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestParsedFiles(t *testing.T) {
|
2016-08-23 08:31:50 +08:00
|
|
|
files, err := ioutil.ReadDir(testDir)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
for _, f := range files {
|
2020-12-03 22:33:39 +08:00
|
|
|
name := f.Name()
|
|
|
|
|
2018-01-10 01:53:16 +08:00
|
|
|
// run all js files that start with a number. Skip others.
|
2020-12-03 22:33:39 +08:00
|
|
|
if filepath.Ext(name) != ".js" || !unicode.IsNumber(rune(name[0])) {
|
2016-08-23 08:31:50 +08:00
|
|
|
continue
|
|
|
|
}
|
2020-12-03 22:33:39 +08:00
|
|
|
t.Run(name, func(t *testing.T) {
|
|
|
|
var err error
|
|
|
|
|
|
|
|
// Compile the .js file:
|
|
|
|
conf, err := ExecuteJavascript(string(filepath.Join(testDir, name)), true, nil)
|
2017-04-20 03:13:28 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2021-02-01 20:33:41 +08:00
|
|
|
// for _, dc := range conf.Domains {
|
|
|
|
// normalize.UpdateNameSplitHorizon(dc)
|
|
|
|
// }
|
2020-12-03 22:33:39 +08:00
|
|
|
|
|
|
|
// Initialize any DNS providers mentioned.
|
|
|
|
for _, dProv := range conf.DNSProviders {
|
|
|
|
var pcfg = map[string]string{}
|
|
|
|
// Fake out any provider's validation tests.
|
|
|
|
switch dProv.Type {
|
|
|
|
case "CLOUDFLAREAPI":
|
|
|
|
pcfg["apitoken"] = "fake"
|
|
|
|
default:
|
|
|
|
}
|
|
|
|
_, err := providers.CreateDNSProvider(dProv.Type, pcfg, nil)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Test the JS compiled as expected (compare to the .json file)
|
2017-04-20 03:13:28 +08:00
|
|
|
actualJSON, err := json.MarshalIndent(conf, "", " ")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2020-12-03 22:33:39 +08:00
|
|
|
testName := name[:len(name)-3]
|
|
|
|
expectedFile := filepath.Join(testDir, testName+".json")
|
2020-10-08 04:03:36 +08:00
|
|
|
expectedJSON, err := ioutil.ReadFile(expectedFile)
|
2017-04-20 03:13:28 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2018-12-14 00:46:43 +08:00
|
|
|
es := string(expectedJSON)
|
|
|
|
as := string(actualJSON)
|
2020-12-03 22:33:39 +08:00
|
|
|
_, _ = es, as
|
2021-02-01 20:33:41 +08:00
|
|
|
// When debugging, leave behind the actual result:
|
|
|
|
//ioutil.WriteFile(expectedFile+".ACTUAL", []byte(es), 0644)
|
2020-12-03 22:33:39 +08:00
|
|
|
testifyrequire.JSONEqf(t, es, as, "EXPECTING %q = \n```\n%s\n```", expectedFile, as)
|
|
|
|
|
|
|
|
// For each domain, if there is a zone file, test against it:
|
|
|
|
|
|
|
|
errs := normalize.ValidateAndNormalizeConfig(conf)
|
|
|
|
if len(errs) != 0 {
|
|
|
|
t.Fatal(errs[0])
|
|
|
|
}
|
|
|
|
|
|
|
|
var dCount int
|
|
|
|
for _, dc := range conf.Domains {
|
|
|
|
zoneFile := filepath.Join(testDir, testName, dc.Name+".zone")
|
|
|
|
expectedZone, err := ioutil.ReadFile(zoneFile)
|
|
|
|
if err != nil {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
dCount++
|
|
|
|
|
|
|
|
// Generate the zonefile
|
|
|
|
var buf bytes.Buffer
|
|
|
|
err = prettyzone.WriteZoneFileRC(&buf, dc.Records, dc.Name, 300, nil)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
actualZone := buf.String()
|
|
|
|
|
|
|
|
es := string(expectedZone)
|
|
|
|
as := actualZone
|
|
|
|
if es != as {
|
|
|
|
// On failure, leave behind the .ACTUAL file.
|
|
|
|
ioutil.WriteFile(zoneFile+".ACTUAL", []byte(actualZone), 0644)
|
|
|
|
}
|
|
|
|
testifyrequire.Equal(t, es, as, "EXPECTING %q =\n```\n%s```", zoneFile, as)
|
|
|
|
}
|
|
|
|
if dCount > 0 && (len(conf.Domains) != dCount) {
|
|
|
|
t.Fatal(fmt.Errorf("only %d of %d domains in %q have zonefiles", dCount, len(conf.Domains), name))
|
|
|
|
}
|
|
|
|
|
2017-04-20 03:13:28 +08:00
|
|
|
})
|
2020-12-03 22:33:39 +08:00
|
|
|
|
2016-12-17 04:10:27 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestErrors(t *testing.T) {
|
2017-04-12 13:02:57 +08:00
|
|
|
tests := []struct{ desc, text string }{
|
|
|
|
{"old dsp style", `D("foo.com","reg","dsp")`},
|
|
|
|
{"MX no priority", `D("foo.com","reg",MX("@","test."))`},
|
|
|
|
{"MX reversed", `D("foo.com","reg",MX("@","test.", 5))`},
|
2017-05-20 02:15:57 +08:00
|
|
|
{"CF_REDIRECT With comma", `D("foo.com","reg",CF_REDIRECT("foo.com,","baaa"))`},
|
|
|
|
{"CF_TEMP_REDIRECT With comma", `D("foo.com","reg",CF_TEMP_REDIRECT("foo.com","baa,a"))`},
|
2017-06-06 01:58:02 +08:00
|
|
|
{"Bad cidr", `D(reverse("foo.com"), "reg")`},
|
2017-11-15 12:14:45 +08:00
|
|
|
{"Dup domains", `D("example.org", "reg"); D("example.org", "reg")`},
|
2018-03-22 23:52:52 +08:00
|
|
|
{"Bad NAMESERVER", `D("example.com","reg", NAMESERVER("@","ns1.foo.com."))`},
|
2016-12-17 04:10:27 +08:00
|
|
|
}
|
2017-04-12 13:02:57 +08:00
|
|
|
for _, tst := range tests {
|
|
|
|
t.Run(tst.desc, func(t *testing.T) {
|
2020-10-31 00:04:41 +08:00
|
|
|
if _, err := ExecuteJavascript(tst.text, true, nil); err == nil {
|
2017-04-12 13:02:57 +08:00
|
|
|
t.Fatal("Expected error but found none")
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
2016-08-23 08:31:50 +08:00
|
|
|
}
|
|
|
|
}
|