package command import ( "testing" "github.com/hashicorp/nomad/ci" "github.com/hashicorp/nomad/nomad/mock" "github.com/hashicorp/nomad/nomad/structs" "github.com/mitchellh/cli" "github.com/posener/complete" "github.com/shoenig/test/must" ) func TestLogsCommand_Implements(t *testing.T) { ci.Parallel(t) var _ cli.Command = &AllocLogsCommand{} } func TestLogsCommand_Fails(t *testing.T) { ci.Parallel(t) srv, _, url := testServer(t, false, nil) defer stopTestAgent(srv) ui := cli.NewMockUi() cmd := &AllocLogsCommand{Meta: Meta{Ui: ui}} // Fails on misuse code := cmd.Run([]string{"some", "bad", "args"}) must.One(t, code) out := ui.ErrorWriter.String() must.StrContains(t, out, commandErrorText(cmd)) ui.ErrorWriter.Reset() // Fails on connection failure code = cmd.Run([]string{"-address=nope", "foobar"}) must.One(t, code) out = ui.ErrorWriter.String() must.StrContains(t, out, "Error querying allocation") ui.ErrorWriter.Reset() // Fails on missing alloc code = cmd.Run([]string{"-address=" + url, "26470238-5CF2-438F-8772-DC67CFB0705C"}) must.One(t, code) out = ui.ErrorWriter.String() must.StrContains(t, out, "No allocation(s) with prefix or id") ui.ErrorWriter.Reset() // Fail on identifier with too few characters code = cmd.Run([]string{"-address=" + url, "2"}) must.One(t, code) out = ui.ErrorWriter.String() must.StrContains(t, out, "must contain at least two characters.") ui.ErrorWriter.Reset() // Identifiers with uneven length should produce a query result code = cmd.Run([]string{"-address=" + url, "123"}) must.One(t, code) out = ui.ErrorWriter.String() must.StrContains(t, out, "No allocation(s) with prefix or id") } func TestLogsCommand_AutocompleteArgs(t *testing.T) { ci.Parallel(t) srv, _, url := testServer(t, true, nil) defer stopTestAgent(srv) ui := cli.NewMockUi() cmd := &AllocLogsCommand{Meta: Meta{Ui: ui, flagAddress: url}} // Create a fake alloc state := srv.Agent.Server().State() a := mock.Alloc() must.NoError(t, state.UpsertAllocs(structs.MsgTypeTestSetup, 1000, []*structs.Allocation{a})) prefix := a.ID[:5] args := complete.Args{Last: prefix} predictor := cmd.AutocompleteArgs() res := predictor.Predict(args) must.Len(t, 1, res) must.Eq(t, a.ID, res[0]) }