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:
Miek Gieben 2017-05-22 13:09:35 +01:00 committed by John Belamaric
parent 7e6f5c77aa
commit 024f56682d
4 changed files with 57 additions and 14 deletions

View file

@ -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":

View file

@ -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

View file

@ -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
View 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)
}
}