main_test.go 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. package main
  2. import "os"
  3. import "flag"
  4. import "testing"
  5. func TestSetFlagsFromEnv(t *testing.T) {
  6. os.Clearenv()
  7. // flags should be settable using env vars
  8. os.Setenv("ETCD_DATA_DIR", "/foo/bar")
  9. // and command-line flags
  10. if err := flag.Set("peer-bind-addr", "1.2.3.4"); err != nil {
  11. t.Fatal(err)
  12. }
  13. // command-line flags take precedence over env vars
  14. os.Setenv("ETCD_ID", "woof")
  15. if err := flag.Set("id", "quack"); err != nil {
  16. t.Fatal(err)
  17. }
  18. // first verify that flags are as expected before reading the env
  19. for f, want := range map[string]string{
  20. "data-dir": "",
  21. "peer-bind-addr": "1.2.3.4",
  22. "id": "quack",
  23. } {
  24. if got := flag.Lookup(f).Value.String(); got != want {
  25. t.Fatalf("flag %q=%q, want %q", f, got, want)
  26. }
  27. }
  28. // now read the env and verify flags were updated as expected
  29. setFlagsFromEnv()
  30. for f, want := range map[string]string{
  31. "data-dir": "/foo/bar",
  32. "peer-bind-addr": "1.2.3.4",
  33. "id": "quack",
  34. } {
  35. if got := flag.Lookup(f).Value.String(); got != want {
  36. t.Errorf("flag %q=%q, want %q", f, got, want)
  37. }
  38. }
  39. }
  40. func TestProxyFlagSet(t *testing.T) {
  41. tests := []struct {
  42. val string
  43. pass bool
  44. }{
  45. // known values
  46. {"on", true},
  47. {"off", true},
  48. // unrecognized values
  49. {"foo", false},
  50. {"", false},
  51. }
  52. for i, tt := range tests {
  53. pf := new(ProxyFlag)
  54. err := pf.Set(tt.val)
  55. if tt.pass != (err == nil) {
  56. t.Errorf("#%d: want pass=%t, but got err=%v", i, tt.pass, err)
  57. }
  58. }
  59. }