middleware/chaos: fix version (#669)
* middleware/chaos: fix version Move the version setting into a init function so it is done early. Then tweak the setup code for chaos a bit to correctly pick this version up. Add an integration test to pick this up in the toplevel test/ directory. Fixes #667 * Update tests
This commit is contained in:
parent
7e6f5c77aa
commit
024f56682d
4 changed files with 57 additions and 14 deletions
|
@ -50,6 +50,9 @@ func init() {
|
||||||
|
|
||||||
caddy.RegisterCaddyfileLoader("flag", caddy.LoaderFunc(confLoader))
|
caddy.RegisterCaddyfileLoader("flag", caddy.LoaderFunc(confLoader))
|
||||||
caddy.SetDefaultCaddyfileLoader("default", caddy.LoaderFunc(defaultLoader))
|
caddy.SetDefaultCaddyfileLoader("default", caddy.LoaderFunc(defaultLoader))
|
||||||
|
|
||||||
|
caddy.AppName = coreName
|
||||||
|
caddy.AppVersion = coreVersion
|
||||||
}
|
}
|
||||||
|
|
||||||
// Run is CoreDNS's main() function.
|
// Run is CoreDNS's main() function.
|
||||||
|
@ -57,9 +60,6 @@ func Run() {
|
||||||
|
|
||||||
flag.Parse()
|
flag.Parse()
|
||||||
|
|
||||||
caddy.AppName = coreName
|
|
||||||
caddy.AppVersion = coreVersion
|
|
||||||
|
|
||||||
// Set up process log before anything bad happens
|
// Set up process log before anything bad happens
|
||||||
switch logfile {
|
switch logfile {
|
||||||
case "stdout":
|
case "stdout":
|
||||||
|
|
|
@ -12,6 +12,7 @@ func init() {
|
||||||
ServerType: "dns",
|
ServerType: "dns",
|
||||||
Action: setup,
|
Action: setup,
|
||||||
})
|
})
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func setup(c *caddy.Controller) error {
|
func setup(c *caddy.Controller) error {
|
||||||
|
@ -28,13 +29,16 @@ func setup(c *caddy.Controller) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
func chaosParse(c *caddy.Controller) (string, map[string]bool, error) {
|
func chaosParse(c *caddy.Controller) (string, map[string]bool, error) {
|
||||||
|
// Set here so we pick up AppName and AppVersion that get set in coremain's init().
|
||||||
|
chaosVersion = caddy.AppName + "-" + caddy.AppVersion
|
||||||
|
|
||||||
version := ""
|
version := ""
|
||||||
authors := make(map[string]bool)
|
authors := make(map[string]bool)
|
||||||
|
|
||||||
for c.Next() {
|
for c.Next() {
|
||||||
args := c.RemainingArgs()
|
args := c.RemainingArgs()
|
||||||
if len(args) == 0 {
|
if len(args) == 0 {
|
||||||
return defaultVersion, nil, nil
|
return chaosVersion, nil, nil
|
||||||
}
|
}
|
||||||
if len(args) == 1 {
|
if len(args) == 1 {
|
||||||
return args[0], nil, nil
|
return args[0], nil, nil
|
||||||
|
@ -48,4 +52,4 @@ func chaosParse(c *caddy.Controller) (string, map[string]bool, error) {
|
||||||
return version, authors, nil
|
return version, authors, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
var defaultVersion = caddy.AppName + "-" + caddy.AppVersion
|
var chaosVersion string
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
package chaos
|
package chaos
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
|
||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
@ -17,20 +16,12 @@ func TestSetupChaos(t *testing.T) {
|
||||||
expectedErrContent string // substring from the expected error. Empty for positive cases.
|
expectedErrContent string // substring from the expected error. Empty for positive cases.
|
||||||
}{
|
}{
|
||||||
// positive
|
// positive
|
||||||
{
|
|
||||||
`chaos`, false, defaultVersion, "", "",
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
`chaos v2`, false, "v2", "", "",
|
`chaos v2`, false, "v2", "", "",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
`chaos v3 "Miek Gieben"`, false, "v3", "Miek Gieben", "",
|
`chaos v3 "Miek Gieben"`, false, "v3", "Miek Gieben", "",
|
||||||
},
|
},
|
||||||
{
|
|
||||||
fmt.Sprintf(`chaos {
|
|
||||||
%s
|
|
||||||
}`, defaultVersion), false, defaultVersion, "", "",
|
|
||||||
},
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for i, test := range tests {
|
for i, test := range tests {
|
||||||
|
|
48
test/chaos_test.go
Normal file
48
test/chaos_test.go
Normal file
|
@ -0,0 +1,48 @@
|
||||||
|
package test
|
||||||
|
|
||||||
|
import (
|
||||||
|
"io/ioutil"
|
||||||
|
"log"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
// Plug in CoreDNS, needed for AppVersion and AppName in this test.
|
||||||
|
_ "github.com/coredns/coredns/coremain"
|
||||||
|
|
||||||
|
"github.com/mholt/caddy"
|
||||||
|
"github.com/miekg/dns"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestChaos(t *testing.T) {
|
||||||
|
corefile := `.:0 {
|
||||||
|
chaos
|
||||||
|
}
|
||||||
|
`
|
||||||
|
|
||||||
|
i, err := CoreDNSServer(corefile)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("Could not get CoreDNS serving instance: %s", err)
|
||||||
|
}
|
||||||
|
// Stop the server.
|
||||||
|
defer i.Stop()
|
||||||
|
|
||||||
|
udp, _ := CoreDNSServerPorts(i, 0)
|
||||||
|
if udp == "" {
|
||||||
|
t.Fatalf("Could not get UDP listening port")
|
||||||
|
}
|
||||||
|
|
||||||
|
log.SetOutput(ioutil.Discard)
|
||||||
|
|
||||||
|
m := new(dns.Msg)
|
||||||
|
m.SetQuestion("version.bind.", dns.TypeTXT)
|
||||||
|
m.Question[0].Qclass = dns.ClassCHAOS
|
||||||
|
|
||||||
|
resp, err := dns.Exchange(m, udp)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("Expected to receive reply, but didn't: %v", err)
|
||||||
|
}
|
||||||
|
chTxt := resp.Answer[0].(*dns.TXT).Txt[0]
|
||||||
|
version := caddy.AppName + "-" + caddy.AppVersion
|
||||||
|
if chTxt != version {
|
||||||
|
t.Fatalf("Expected version to bo %s, got %s", version, chTxt)
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Reference in a new issue