main: add test for setting flags

release-2.0
Jonathan Boulle 2014-09-17 14:12:04 -07:00
parent 40c19e525c
commit 844897360c
2 changed files with 46 additions and 3 deletions

View File

@ -46,7 +46,7 @@ func init() {
func main() {
flag.Parse()
getFlagsFromEnv()
setFlagsFromEnv()
if *proxyMode {
startProxy()
@ -182,12 +182,12 @@ func (as *Addrs) String() string {
return strings.Join(*as, ",")
}
// getFlagsFromEnv parses all registered flags in the global flagset,
// setFlagsFromEnv parses all registered flags in the global flagset,
// and if they are not already set it attempts to set their values from
// environment variables. Environment variables take the name of the flag but
// are UPPERCASE, have the prefix "ETCD_", and any dashes are replaced by
// underscores - for example: some-flag => ETCD_SOME_FLAG
func getFlagsFromEnv() {
func setFlagsFromEnv() {
alreadySet := make(map[string]bool)
flag.Visit(func(f *flag.Flag) {
alreadySet[f.Name] = true

43
main_test.go Normal file
View File

@ -0,0 +1,43 @@
package main
import "os"
import "flag"
import "testing"
func TestSetFlagsFromEnv(t *testing.T) {
os.Clearenv()
// flags should be settable using env vars
os.Setenv("ETCD_DATA_DIR", "/foo/bar")
// and command-line flags
if err := flag.Set("peer-bind-addr", "1.2.3.4"); err != nil {
t.Fatal(err)
}
// command-line flags take precedence over env vars
os.Setenv("ETCD_ID", "woof")
if err := flag.Set("id", "quack"); err != nil {
t.Fatal(err)
}
// first verify that flags are as expected before reading the env
for f, want := range map[string]string{
"data-dir": "",
"peer-bind-addr": "1.2.3.4",
"id": "quack",
} {
if got := flag.Lookup(f).Value.String(); got != want {
t.Fatalf("flag %q=%q, want %q", f, got, want)
}
}
// now read the env and verify flags were updated as expected
setFlagsFromEnv()
for f, want := range map[string]string{
"data-dir": "/foo/bar",
"peer-bind-addr": "1.2.3.4",
"id": "quack",
} {
if got := flag.Lookup(f).Value.String(); got != want {
t.Errorf("flag %q=%q, want %q", f, got, want)
}
}
}