Skip to content

Commit

Permalink
Fix flaky TestSSHHeadless (#47732)
Browse files Browse the repository at this point in the history
Closes #39562
  • Loading branch information
rosstimothy authored Oct 21, 2024
1 parent c345ee6 commit 6399425
Showing 1 changed file with 37 additions and 23 deletions.
60 changes: 37 additions & 23 deletions tool/tsh/common/tsh_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -2862,34 +2862,48 @@ func TestSSHHeadless(t *testing.T) {
bob.SetRoles([]string{"requester"})

sshHostname := "test-ssh-host"
rootAuth, rootProxy := makeTestServers(t, withBootstrap(nodeAccess, alice, requester, bob), withConfig(func(cfg *servicecfg.Config) {
cfg.Hostname = sshHostname
cfg.SSH.Enabled = true
cfg.SSH.Addr = utils.NetAddr{AddrNetwork: "tcp", Addr: net.JoinHostPort("127.0.0.1", ports.Pop())}
}))
server := testserver.MakeTestServer(t,
testserver.WithConfig(func(cfg *servicecfg.Config) {
cfg.Hostname = sshHostname
cfg.Auth.Enabled = true
cfg.Proxy.Enabled = true
cfg.SSH.Enabled = true
cfg.SSH.DisableCreateHostUser = true

proxyAddr, err := rootProxy.ProxyWebAddr()
require.NoError(t, err)
cfg.Auth.BootstrapResources = []types.Resource{nodeAccess, alice, requester, bob}
cfg.Auth.Preference = &types.AuthPreferenceV2{
Metadata: types.Metadata{
Labels: map[string]string{types.OriginLabel: types.OriginConfigFile},
},
Spec: types.AuthPreferenceSpecV2{
Type: constants.Local,
SecondFactor: constants.SecondFactorOptional,
Webauthn: &types.Webauthn{
RPID: "127.0.0.1",
},
AllowHeadless: types.NewBoolOption(true),
},
}
}),
)

_, err = rootAuth.GetAuthServer().UpsertAuthPreference(ctx, &types.AuthPreferenceV2{
Spec: types.AuthPreferenceSpecV2{
Type: constants.Local,
SecondFactor: constants.SecondFactorOptional,
Webauthn: &types.Webauthn{
RPID: "127.0.0.1",
},
},
})
require.NoError(t, err)
require.EventuallyWithT(t, func(t *assert.CollectT) {
found, err := server.GetAuthServer().GetNodes(ctx, apidefaults.Namespace)
assert.NoError(t, err)
assert.Len(t, found, 1)
}, 10*time.Second, 100*time.Millisecond)

go func() {
if err := approveAllAccessRequests(ctx, rootAuth.GetAuthServer()); err != nil {
// Ensure the context is canceled, so that Run calls don't block
defer cancel()
if err := approveAllAccessRequests(ctx, server.GetAuthServer()); err != nil {
assert.ErrorIs(t, err, context.Canceled, "unexpected error from approveAllAccessRequests")
}
// Cancel the context, so Run calls don't block
cancel()
}()

proxyAddr, err := server.ProxyWebAddr()
require.NoError(t, err)

for _, tc := range []struct {
name string
args []string
Expand Down Expand Up @@ -2930,10 +2944,10 @@ func TestSSHHeadless(t *testing.T) {
"echo", "test",
)

err := Run(ctx, args, CliOption(func(cf *CLIConf) error {
cf.MockHeadlessLogin = mockHeadlessLogin(t, rootAuth.GetAuthServer(), alice)
err := Run(ctx, args, func(cf *CLIConf) error {
cf.MockHeadlessLogin = mockHeadlessLogin(t, server.GetAuthServer(), alice)
return nil
}))
})
tc.assertErr(t, err)
})
}
Expand Down

0 comments on commit 6399425

Please sign in to comment.