2015-09-16 23:05:57 +00:00
|
|
|
package command
|
|
|
|
|
|
|
|
import (
|
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/mitchellh/cli"
|
|
|
|
)
|
|
|
|
|
2016-05-25 21:11:14 +00:00
|
|
|
func TestEvalStatusCommand_Implements(t *testing.T) {
|
|
|
|
var _ cli.Command = &EvalStatusCommand{}
|
2015-09-16 23:05:57 +00:00
|
|
|
}
|
|
|
|
|
2016-05-25 21:11:14 +00:00
|
|
|
func TestEvalStatusCommand_Fails(t *testing.T) {
|
2015-09-16 23:05:57 +00:00
|
|
|
srv, _, url := testServer(t, nil)
|
|
|
|
defer srv.Stop()
|
|
|
|
|
|
|
|
ui := new(cli.MockUi)
|
2016-05-25 21:11:14 +00:00
|
|
|
cmd := &EvalStatusCommand{Meta: Meta{Ui: ui}}
|
2015-09-16 23:05:57 +00:00
|
|
|
|
|
|
|
// Fails on misuse
|
|
|
|
if code := cmd.Run([]string{"some", "bad", "args"}); code != 1 {
|
|
|
|
t.Fatalf("expected exit code 1, got: %d", code)
|
|
|
|
}
|
|
|
|
if out := ui.ErrorWriter.String(); !strings.Contains(out, cmd.Help()) {
|
|
|
|
t.Fatalf("expected help output, got: %s", out)
|
|
|
|
}
|
|
|
|
ui.ErrorWriter.Reset()
|
|
|
|
|
|
|
|
// Fails on eval lookup failure
|
|
|
|
if code := cmd.Run([]string{"-address=" + url, "3E55C771-76FC-423B-BCED-3E5314F433B1"}); code != 1 {
|
|
|
|
t.Fatalf("expect exit 1, got: %d", code)
|
|
|
|
}
|
2015-12-24 10:46:59 +00:00
|
|
|
if out := ui.ErrorWriter.String(); !strings.Contains(out, "No evaluation(s) with prefix or id") {
|
2015-09-16 23:05:57 +00:00
|
|
|
t.Fatalf("expect not found error, got: %s", out)
|
|
|
|
}
|
|
|
|
ui.ErrorWriter.Reset()
|
|
|
|
|
|
|
|
// Fails on connection failure
|
2016-01-14 20:57:43 +00:00
|
|
|
if code := cmd.Run([]string{"-address=nope", "12345678-abcd-efab-cdef-123456789abc"}); code != 1 {
|
2015-09-16 23:05:57 +00:00
|
|
|
t.Fatalf("expected exit code 1, got: %d", code)
|
|
|
|
}
|
2016-05-25 21:11:14 +00:00
|
|
|
if out := ui.ErrorWriter.String(); !strings.Contains(out, "Error querying evaluation") {
|
2015-09-16 23:05:57 +00:00
|
|
|
t.Fatalf("expected failed query error, got: %s", out)
|
|
|
|
}
|
2016-08-06 12:38:41 +00:00
|
|
|
ui.ErrorWriter.Reset()
|
|
|
|
|
|
|
|
// Failed on both -json and -t options are specified
|
|
|
|
if code := cmd.Run([]string{"-address=" + url, "-json", "-t", "{{.ID}}"}); code != 1 {
|
|
|
|
t.Fatalf("expected exit 1, got: %d", code)
|
|
|
|
}
|
|
|
|
if out := ui.ErrorWriter.String(); !strings.Contains(out, "Both -json and -t are not allowed") {
|
|
|
|
t.Fatalf("expected getting formatter error, got: %s", out)
|
|
|
|
}
|
|
|
|
|
2015-09-16 23:05:57 +00:00
|
|
|
}
|