mirror of
https://github.com/etcd-io/etcd.git
synced 2024-09-27 06:25:44 +00:00
main: add test for setting flags
This commit is contained in:
parent
40c19e525c
commit
844897360c
6
main.go
6
main.go
@ -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
43
main_test.go
Normal 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)
|
||||
}
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user