()
| 18 | ) |
| 19 | |
| 20 | func main() { |
| 21 | const usage = ` |
| 22 | Usage: |
| 23 | codis-ha [--log=FILE] [--log-level=LEVEL] [--interval=SECONDS] --dashboard=ADDR [--no-maintains] |
| 24 | codis-ha --version |
| 25 | |
| 26 | Options: |
| 27 | -l FILE, --log=FILE set path/name of daliy rotated log file. |
| 28 | --log-level=LEVEL set the log-level, should be INFO,WARN,DEBUG or ERROR, default is INFO. |
| 29 | ` |
| 30 | d, err := docopt.Parse(usage, nil, true, "", false) |
| 31 | if err != nil { |
| 32 | log.PanicError(err, "parse arguments failed") |
| 33 | } |
| 34 | |
| 35 | if d["--version"].(bool) { |
| 36 | fmt.Println("version:", utils.Version) |
| 37 | fmt.Println("compile:", utils.Compile) |
| 38 | return |
| 39 | } |
| 40 | |
| 41 | if s, ok := utils.Argument(d, "--log"); ok { |
| 42 | w, err := log.NewRollingFile(s, log.DailyRolling) |
| 43 | if err != nil { |
| 44 | log.PanicErrorf(err, "open log file %s failed", s) |
| 45 | } else { |
| 46 | log.StdLog = log.New(w, "") |
| 47 | } |
| 48 | } |
| 49 | log.SetLevel(log.LevelInfo) |
| 50 | |
| 51 | if s, ok := utils.Argument(d, "--log-level"); ok { |
| 52 | if !log.SetLevelString(s) { |
| 53 | log.Panicf("option --log-level = %s", s) |
| 54 | } |
| 55 | } |
| 56 | |
| 57 | var interval = 5 |
| 58 | if n, ok := utils.ArgumentInteger(d, "--interval"); ok { |
| 59 | if n <= 0 { |
| 60 | log.Panicf("option --interval = %d", n) |
| 61 | } |
| 62 | interval = n |
| 63 | } |
| 64 | |
| 65 | dashboard := utils.ArgumentMust(d, "--dashboard") |
| 66 | log.Warnf("set dashboard = %s", dashboard) |
| 67 | log.Warnf("set interval = %d (seconds)", interval) |
| 68 | |
| 69 | var maintains = true |
| 70 | if d["--no-maintains"].(bool) { |
| 71 | maintains = false |
| 72 | } |
| 73 | |
| 74 | client := topom.NewApiClient(dashboard) |
| 75 | |
| 76 | t, err := client.Model() |
| 77 | if err != nil { |
nothing calls this directly
no test coverage detected