From 24e9d5fb1516646284a0b11e37a7a0d7c5cac7e8 Mon Sep 17 00:00:00 2001 From: davemay99 Date: Wed, 9 Dec 2020 17:48:13 -0500 Subject: [PATCH 1/3] debug: update test to identify bug in GH-9566 --- command/operator_debug_test.go | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/command/operator_debug_test.go b/command/operator_debug_test.go index 72c543cfc4a..0efd47dc4c1 100644 --- a/command/operator_debug_test.go +++ b/command/operator_debug_test.go @@ -164,10 +164,11 @@ func TestDebug_NodeClass(t *testing.T) { args: []string{"-address", url, "-duration", "250ms", "-server-id", "all", "-node-id", "all", "-node-class", "clienta", "-max-nodes", "2"}, expectedCode: 0, expectedOutputs: []string{ - "Starting debugger", - "Created debug archive", + "Servers: (1/1)", + "Clients: (2/3)", "Max node count reached (2)", "Node Class: clienta", + "Created debug archive", }, expectedError: "", }, @@ -176,9 +177,10 @@ func TestDebug_NodeClass(t *testing.T) { args: []string{"-address", url, "-duration", "250ms", "-server-id", "all", "-node-id", "all", "-node-class", "clientb", "-max-nodes", "2"}, expectedCode: 0, expectedOutputs: []string{ - "Starting debugger", - "Created debug archive", + "Servers: (1/1)", + "Clients: (1/3)", "Node Class: clientb", + "Created debug archive", }, expectedError: "", }, From ce16d90e61091f9ae4a5e501b58b3e92ca79646e Mon Sep 17 00:00:00 2001 From: davemay99 Date: Fri, 11 Dec 2020 17:35:44 -0500 Subject: [PATCH 2/3] debug: range tests need fresh cmd each iteration --- command/operator_debug_test.go | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/command/operator_debug_test.go b/command/operator_debug_test.go index 0efd47dc4c1..8329ca305c3 100644 --- a/command/operator_debug_test.go +++ b/command/operator_debug_test.go @@ -147,10 +147,6 @@ func TestDebug_NodeClass(t *testing.T) { testutil.WaitForClient(t, srv.Agent.RPC, client3NodeID) t.Logf("[TEST] Client3 ready, id: %s", client3NodeID) - // Setup mock UI - ui := cli.NewMockUi() - cmd := &OperatorDebugCommand{Meta: Meta{Ui: ui}} - // Setup test cases struct cases := []struct { name string @@ -188,6 +184,10 @@ func TestDebug_NodeClass(t *testing.T) { for _, c := range cases { t.Run(c.name, func(t *testing.T) { + // Setup mock UI + ui := cli.NewMockUi() + cmd := &OperatorDebugCommand{Meta: Meta{Ui: ui}} + // Run test case code := cmd.Run(c.args) out := ui.OutputWriter.String() @@ -275,10 +275,6 @@ func TestDebug_ClientToServer(t *testing.T) { t.Logf("[TEST] Server api address: %s", addrServer) t.Logf("[TEST] Client1 api address: %s", addrClient1) - // Setup mock UI - ui := cli.NewMockUi() - cmd := &OperatorDebugCommand{Meta: Meta{Ui: ui}} - // Setup test cases struct cases := []struct { name string @@ -300,6 +296,10 @@ func TestDebug_ClientToServer(t *testing.T) { for _, c := range cases { t.Run(c.name, func(t *testing.T) { + // Setup mock UI + ui := cli.NewMockUi() + cmd := &OperatorDebugCommand{Meta: Meta{Ui: ui}} + // Run test case code := cmd.Run([]string{"-address", c.url, "-duration", "250ms", "-server-id", "all", "-node-id", "all"}) out := ui.OutputWriter.String() From f6417171e49efbe09c96ec453c5332664174f67b Mon Sep 17 00:00:00 2001 From: davemay99 Date: Fri, 11 Dec 2020 17:37:26 -0500 Subject: [PATCH 3/3] debug: fix node count bug in GH-9566 --- command/operator_debug.go | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/command/operator_debug.go b/command/operator_debug.go index 494e61a6f4a..278af6e7e56 100644 --- a/command/operator_debug.go +++ b/command/operator_debug.go @@ -328,13 +328,14 @@ func (c *OperatorDebugCommand) Run(args []string) int { } // Increment fail count if no nodes are found - nodesFound = len(nodes) - if nodesFound == 0 { + if len(nodes) == 0 { c.Ui.Error(fmt.Sprintf("No node(s) with prefix %q found", id)) nodeLookupFailCount++ continue } + nodesFound += len(nodes) + // Apply constraints to nodes found for _, n := range nodes { // Ignore nodes that do not match specified class