open-nomad/command/status_test.go

106 lines
2.9 KiB
Go
Raw Normal View History

2015-09-11 07:38:15 +00:00
package command
import (
2015-09-12 21:50:05 +00:00
"strings"
2015-09-11 07:38:15 +00:00
"testing"
"github.com/mitchellh/cli"
)
func TestStatusCommand_Implements(t *testing.T) {
var _ cli.Command = &StatusCommand{}
}
2015-09-12 21:50:05 +00:00
func TestStatusCommand_Run(t *testing.T) {
srv, client, url := testServer(t, nil)
defer srv.Stop()
2015-09-12 21:50:05 +00:00
ui := new(cli.MockUi)
cmd := &StatusCommand{Meta: Meta{Ui: ui}}
2015-09-12 21:50:05 +00:00
// Should return blank for no jobs
if code := cmd.Run([]string{"-address=" + url}); code != 0 {
t.Fatalf("expected exit 0, got: %d", code)
2015-09-12 21:50:05 +00:00
}
// Check for this awkward nil string, since a nil bytes.Buffer
// returns this purposely, and mitchellh/cli has a nil pointer
// if nothing was ever output.
if out := ui.OutputWriter.String(); out != "<nil>" {
t.Fatalf("expected empty output, got: %s", out)
}
// Register two jobs
job1 := testJob("job1")
2015-09-12 21:50:05 +00:00
if _, _, err := client.Jobs().Register(job1, nil); err != nil {
t.Fatalf("err: %s", err)
}
job2 := testJob("job2")
2015-09-12 21:50:05 +00:00
if _, _, err := client.Jobs().Register(job2, nil); err != nil {
t.Fatalf("err: %s", err)
}
// Query again and check the result
if code := cmd.Run([]string{"-address=" + url}); code != 0 {
2015-09-12 21:50:05 +00:00
t.Fatalf("expected exit 0, got: %d", code)
}
out := ui.OutputWriter.String()
if !strings.Contains(out, "job1") || !strings.Contains(out, "job2") {
t.Fatalf("expected job1 and job2, got: %s", out)
}
ui.OutputWriter.Reset()
// Query a single job
if code := cmd.Run([]string{"-address=" + url, "job2"}); code != 0 {
2015-09-12 21:50:05 +00:00
t.Fatalf("expected exit 0, got: %d", code)
}
out = ui.OutputWriter.String()
if strings.Contains(out, "job1") || !strings.Contains(out, "job2") {
t.Fatalf("expected only job2, got: %s", out)
}
if !strings.Contains(out, "Evaluations") {
t.Fatalf("should dump evaluations")
}
if !strings.Contains(out, "Allocations") {
t.Fatalf("should dump allocations")
}
ui.OutputWriter.Reset()
// Query in short view mode
if code := cmd.Run([]string{"-address=" + url, "-short", "job2"}); code != 0 {
t.Fatalf("expected exit 0, got: %d", code)
}
out = ui.OutputWriter.String()
if !strings.Contains(out, "job2") {
t.Fatalf("expected job2, got: %s", out)
}
if strings.Contains(out, "Evaluations") {
t.Fatalf("should not dump evaluations")
}
if strings.Contains(out, "Allocations") {
t.Fatalf("should not dump allocations")
}
2015-09-12 21:50:05 +00:00
}
func TestStatusCommand_Fails(t *testing.T) {
ui := new(cli.MockUi)
cmd := &StatusCommand{Meta: Meta{Ui: ui}}
2015-09-12 21:50:05 +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)
}
2015-09-12 23:36:44 +00:00
ui.ErrorWriter.Reset()
2015-09-12 21:50:05 +00:00
// Fails on connection failure
if code := cmd.Run([]string{"-address=nope"}); code != 1 {
2015-09-12 21:50:05 +00:00
t.Fatalf("expected exit code 1, got: %d", code)
}
if out := ui.ErrorWriter.String(); !strings.Contains(out, "Error querying jobs") {
2015-09-12 21:50:05 +00:00
t.Fatalf("expected failed query error, got: %s", out)
}
}