mirror of
https://github.com/coder/coder.git
synced 2025-07-12 00:14:10 +00:00
chore(cli): fix test flake in TestSSH_Container/NotFound (#16771)
If you hit the list containers endpoint with no containers running, the response is different. This uses a mock lister to ensure a consistent response from the agent endpoint.
This commit is contained in:
@ -29,6 +29,7 @@ import (
|
|||||||
"github.com/spf13/afero"
|
"github.com/spf13/afero"
|
||||||
"github.com/stretchr/testify/assert"
|
"github.com/stretchr/testify/assert"
|
||||||
"github.com/stretchr/testify/require"
|
"github.com/stretchr/testify/require"
|
||||||
|
"go.uber.org/mock/gomock"
|
||||||
"golang.org/x/crypto/ssh"
|
"golang.org/x/crypto/ssh"
|
||||||
gosshagent "golang.org/x/crypto/ssh/agent"
|
gosshagent "golang.org/x/crypto/ssh/agent"
|
||||||
"golang.org/x/sync/errgroup"
|
"golang.org/x/sync/errgroup"
|
||||||
@ -36,6 +37,7 @@ import (
|
|||||||
|
|
||||||
"github.com/coder/coder/v2/agent"
|
"github.com/coder/coder/v2/agent"
|
||||||
"github.com/coder/coder/v2/agent/agentcontainers"
|
"github.com/coder/coder/v2/agent/agentcontainers"
|
||||||
|
"github.com/coder/coder/v2/agent/agentcontainers/acmock"
|
||||||
"github.com/coder/coder/v2/agent/agentssh"
|
"github.com/coder/coder/v2/agent/agentssh"
|
||||||
"github.com/coder/coder/v2/agent/agenttest"
|
"github.com/coder/coder/v2/agent/agenttest"
|
||||||
agentproto "github.com/coder/coder/v2/agent/proto"
|
agentproto "github.com/coder/coder/v2/agent/proto"
|
||||||
@ -1986,13 +1988,26 @@ func TestSSH_Container(t *testing.T) {
|
|||||||
|
|
||||||
ctx := testutil.Context(t, testutil.WaitShort)
|
ctx := testutil.Context(t, testutil.WaitShort)
|
||||||
client, workspace, agentToken := setupWorkspaceForAgent(t)
|
client, workspace, agentToken := setupWorkspaceForAgent(t)
|
||||||
|
ctrl := gomock.NewController(t)
|
||||||
|
mLister := acmock.NewMockLister(ctrl)
|
||||||
_ = agenttest.New(t, client.URL, agentToken, func(o *agent.Options) {
|
_ = agenttest.New(t, client.URL, agentToken, func(o *agent.Options) {
|
||||||
o.ExperimentalDevcontainersEnabled = true
|
o.ExperimentalDevcontainersEnabled = true
|
||||||
o.ContainerLister = agentcontainers.NewDocker(o.Execer)
|
o.ContainerLister = mLister
|
||||||
})
|
})
|
||||||
_ = coderdtest.NewWorkspaceAgentWaiter(t, client, workspace.ID).Wait()
|
_ = coderdtest.NewWorkspaceAgentWaiter(t, client, workspace.ID).Wait()
|
||||||
|
|
||||||
inv, root := clitest.New(t, "ssh", workspace.Name, "-c", uuid.NewString())
|
mLister.EXPECT().List(gomock.Any()).Return(codersdk.WorkspaceAgentListContainersResponse{
|
||||||
|
Containers: []codersdk.WorkspaceAgentDevcontainer{
|
||||||
|
{
|
||||||
|
ID: uuid.NewString(),
|
||||||
|
FriendlyName: "something_completely_different",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Warnings: nil,
|
||||||
|
}, nil)
|
||||||
|
|
||||||
|
cID := uuid.NewString()
|
||||||
|
inv, root := clitest.New(t, "ssh", workspace.Name, "-c", cID)
|
||||||
clitest.SetupConfig(t, client, root)
|
clitest.SetupConfig(t, client, root)
|
||||||
ptty := ptytest.New(t).Attach(inv)
|
ptty := ptytest.New(t).Attach(inv)
|
||||||
|
|
||||||
@ -2001,7 +2016,8 @@ func TestSSH_Container(t *testing.T) {
|
|||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
})
|
})
|
||||||
|
|
||||||
ptty.ExpectMatch("Container not found:")
|
ptty.ExpectMatch(fmt.Sprintf("Container not found: %q", cID))
|
||||||
|
ptty.ExpectMatch("Available containers: [something_completely_different]")
|
||||||
<-cmdDone
|
<-cmdDone
|
||||||
})
|
})
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user