diff --git a/web/packages/teleport/src/Account/Account.test.tsx b/web/packages/teleport/src/Account/Account.test.tsx
index 2ef6cdc931e25..af4340e48a90b 100644
--- a/web/packages/teleport/src/Account/Account.test.tsx
+++ b/web/packages/teleport/src/Account/Account.test.tsx
@@ -29,10 +29,7 @@ import cfg from 'teleport/config';
import { createTeleportContext } from 'teleport/mocks/contexts';
import { PasswordState } from 'teleport/services/user';
import auth from 'teleport/services/auth/auth';
-import MfaService, {
- MfaDevice,
- WebauthnAssertionResponse,
-} from 'teleport/services/mfa';
+import MfaService, { MfaDevice } from 'teleport/services/mfa';
const defaultAuthType = cfg.auth.second_factor;
const defaultPasswordless = cfg.auth.allowPasswordless;
diff --git a/web/packages/teleport/src/Account/ChangePasswordWizard/ChangePasswordWizard.test.tsx b/web/packages/teleport/src/Account/ChangePasswordWizard/ChangePasswordWizard.test.tsx
index 6ff139610cc8d..eeeb4da32cf88 100644
--- a/web/packages/teleport/src/Account/ChangePasswordWizard/ChangePasswordWizard.test.tsx
+++ b/web/packages/teleport/src/Account/ChangePasswordWizard/ChangePasswordWizard.test.tsx
@@ -25,7 +25,6 @@ import { userEvent, UserEvent } from '@testing-library/user-event';
import auth, { MfaChallengeScope } from 'teleport/services/auth/auth';
import {
- MFA_OPTION_SSO_DEFAULT,
MFA_OPTION_TOTP,
MFA_OPTION_WEBAUTHN,
MfaChallengeResponse,
@@ -90,15 +89,15 @@ describe('with passwordless reauthentication', () => {
async function reauthenticate() {
render();
- const reauthenticateStep = await waitFor(() => {
- return within(screen.getByTestId('reauthenticate-step'));
+ await waitFor(() => {
+ expect(screen.getByTestId('reauthenticate-step')).toBeInTheDocument();
});
expect(auth.getMfaChallenge).toHaveBeenCalledWith({
scope: MfaChallengeScope.CHANGE_PASSWORD,
});
- await user.click(reauthenticateStep.getByText('Passkey'));
- await user.click(reauthenticateStep.getByText('Next'));
+ await user.click(screen.getByText('Passkey'));
+ await user.click(screen.getByText('Next'));
expect(auth.getMfaChallenge).toHaveBeenCalledWith({
scope: MfaChallengeScope.CHANGE_PASSWORD,
userVerificationRequirement: 'required',
@@ -188,15 +187,15 @@ describe('with WebAuthn MFA reauthentication', () => {
async function reauthenticate() {
render();
- const reauthenticateStep = await waitFor(() => {
- return within(screen.getByTestId('reauthenticate-step'));
+ await waitFor(() => {
+ expect(screen.getByTestId('reauthenticate-step')).toBeInTheDocument();
});
expect(auth.getMfaChallenge).toHaveBeenCalledWith({
scope: MfaChallengeScope.CHANGE_PASSWORD,
});
- await user.click(reauthenticateStep.getByText('Security Key'));
- await user.click(reauthenticateStep.getByText('Next'));
+ await user.click(screen.getByText('Security Key'));
+ await user.click(screen.getByText('Next'));
expect(auth.getMfaChallengeResponse).toHaveBeenCalled();
}
@@ -293,11 +292,11 @@ describe('with OTP MFA reauthentication', () => {
async function reauthenticate() {
render();
- const reauthenticateStep = await waitFor(() => {
- return within(screen.getByTestId('reauthenticate-step'));
+ await waitFor(() => {
+ expect(screen.getByTestId('reauthenticate-step')).toBeInTheDocument();
});
- await user.click(reauthenticateStep.getByText('Authenticator App'));
- await user.click(reauthenticateStep.getByText('Next'));
+ await user.click(screen.getByText('Authenticator App'));
+ await user.click(screen.getByText('Next'));
}
it('changes password', async () => {
diff --git a/web/packages/teleport/src/Account/ChangePasswordWizard/ChangePasswordWizard.tsx b/web/packages/teleport/src/Account/ChangePasswordWizard/ChangePasswordWizard.tsx
index d2eb2cc4b45dc..56fda8f9cd90c 100644
--- a/web/packages/teleport/src/Account/ChangePasswordWizard/ChangePasswordWizard.tsx
+++ b/web/packages/teleport/src/Account/ChangePasswordWizard/ChangePasswordWizard.tsx
@@ -35,6 +35,8 @@ import { useAsync } from 'shared/hooks/useAsync';
import Box from 'design/Box';
+import Indicator from 'design/Indicator';
+
import { ChangePasswordReq } from 'teleport/services/auth';
import auth, { MfaChallengeScope } from 'teleport/services/auth/auth';
import {
@@ -43,7 +45,6 @@ import {
WebauthnAssertionResponse,
} from 'teleport/services/mfa';
import useReAuthenticate from 'teleport/components/ReAuthenticate/useReAuthenticate';
-import Indicator from 'design/Indicator';
export interface ChangePasswordWizardProps {
hasPasswordless: boolean;
diff --git a/web/packages/teleport/src/Account/ManageDevices/wizards/AddAuthDeviceWizard.story.tsx b/web/packages/teleport/src/Account/ManageDevices/wizards/AddAuthDeviceWizard.story.tsx
index edd6e72596009..c1b1acd279a12 100644
--- a/web/packages/teleport/src/Account/ManageDevices/wizards/AddAuthDeviceWizard.story.tsx
+++ b/web/packages/teleport/src/Account/ManageDevices/wizards/AddAuthDeviceWizard.story.tsx
@@ -22,13 +22,14 @@ import Dialog from 'design/Dialog';
import { http, HttpResponse, delay } from 'msw';
+import { Attempt } from 'shared/hooks/useAttemptNext';
+
import { createTeleportContext } from 'teleport/mocks/contexts';
import { ContextProvider } from 'teleport/index';
import cfg from 'teleport/config';
import {
- DeviceType,
DeviceUsage,
MFA_OPTION_SSO_DEFAULT,
MFA_OPTION_TOTP,
@@ -41,7 +42,6 @@ import {
SaveDeviceStep,
} from './AddAuthDeviceWizard';
import { ReauthenticateStep } from './ReauthenticateStep';
-import { Attempt } from 'shared/hooks/useAttemptNext';
export default {
title: 'teleport/Account/Manage Devices/Add Device Wizard',
@@ -177,12 +177,12 @@ const stepProps: AddAuthDeviceWizardStepProps = {
MFA_OPTION_TOTP,
MFA_OPTION_SSO_DEFAULT,
],
- submitWithMfa: async (mfaType?: DeviceType, otpCode?: string) => {},
+ submitWithMfa: async () => {},
// Create props
mfaRegisterOptions: [MFA_OPTION_WEBAUTHN, MFA_OPTION_TOTP],
- onDeviceCreated: (c: Credential) => {},
- onNewMfaDeviceTypeChange: (d: DeviceType) => {},
+ onDeviceCreated: () => {},
+ onNewMfaDeviceTypeChange: () => {},
// Save props
credential: { id: 'cred-id', type: 'public-key' },
diff --git a/web/packages/teleport/src/Account/ManageDevices/wizards/AddAuthDeviceWizard.test.tsx b/web/packages/teleport/src/Account/ManageDevices/wizards/AddAuthDeviceWizard.test.tsx
index 0a200980cee4a..f54bd8ee22e90 100644
--- a/web/packages/teleport/src/Account/ManageDevices/wizards/AddAuthDeviceWizard.test.tsx
+++ b/web/packages/teleport/src/Account/ManageDevices/wizards/AddAuthDeviceWizard.test.tsx
@@ -19,7 +19,7 @@
import { render, screen } from 'design/utils/testing';
import React from 'react';
-import { waitFor, within } from '@testing-library/react';
+import { waitFor } from '@testing-library/react';
import { userEvent, UserEvent } from '@testing-library/user-event';
import TeleportContext from 'teleport/teleportContext';
@@ -82,22 +82,18 @@ describe('flow without reauthentication', () => {
);
- const createStep = await waitFor(() => {
- return within(screen.getByTestId('create-step'));
+ await waitFor(() => {
+ expect(screen.getByTestId('create-step')).toBeInTheDocument();
});
- await user.click(
- createStep.getByRole('button', { name: 'Create a passkey' })
- );
+ await user.click(screen.getByRole('button', { name: 'Create a passkey' }));
expect(auth.createNewWebAuthnDevice).toHaveBeenCalledWith({
tokenId: 'privilege-token',
deviceUsage: 'passwordless',
});
- const saveStep = within(screen.getByTestId('save-step'));
- await user.type(saveStep.getByLabelText('Passkey Nickname'), 'new-passkey');
- await user.click(
- saveStep.getByRole('button', { name: 'Save the Passkey' })
- );
+ expect(screen.getByTestId('save-step')).toBeInTheDocument();
+ await user.type(screen.getByLabelText('Passkey Nickname'), 'new-passkey');
+ await user.click(screen.getByRole('button', { name: 'Save the Passkey' }));
expect(ctx.mfaService.saveNewWebAuthnDevice).toHaveBeenCalledWith({
credential: dummyCredential,
addRequest: {
@@ -112,22 +108,22 @@ describe('flow without reauthentication', () => {
test('adds a WebAuthn MFA', async () => {
render();
- const createStep = await waitFor(() => {
- return within(screen.getByTestId('create-step'));
+ await waitFor(() => {
+ expect(screen.getByTestId('create-step')).toBeInTheDocument();
});
- await user.click(createStep.getByLabelText('Security Key'));
+ await user.click(screen.getByLabelText('Security Key'));
await user.click(
- createStep.getByRole('button', { name: 'Create an MFA method' })
+ screen.getByRole('button', { name: 'Create an MFA method' })
);
expect(auth.createNewWebAuthnDevice).toHaveBeenCalledWith({
tokenId: 'privilege-token',
deviceUsage: 'mfa',
});
- const saveStep = within(screen.getByTestId('save-step'));
- await user.type(saveStep.getByLabelText('MFA Method Name'), 'new-mfa');
+ expect(screen.getByTestId('save-step')).toBeInTheDocument();
+ await user.type(screen.getByLabelText('MFA Method Name'), 'new-mfa');
await user.click(
- saveStep.getByRole('button', { name: 'Save the MFA method' })
+ screen.getByRole('button', { name: 'Save the MFA method' })
);
expect(ctx.mfaService.saveNewWebAuthnDevice).toHaveBeenCalledWith({
credential: dummyCredential,
@@ -143,24 +139,24 @@ describe('flow without reauthentication', () => {
test('adds an authenticator app', async () => {
render();
- const createStep = await waitFor(() => {
- return within(screen.getByTestId('create-step'));
+ await waitFor(() => {
+ expect(screen.getByTestId('create-step')).toBeInTheDocument();
});
- await user.click(createStep.getByLabelText('Authenticator App'));
- expect(createStep.getByRole('img')).toHaveAttribute(
+ await user.click(screen.getByLabelText('Authenticator App'));
+ expect(screen.getByRole('img')).toHaveAttribute(
'src',
'-qr-code'
);
await user.click(
- createStep.getByRole('button', { name: 'Create an MFA method' })
+ screen.getByRole('button', { name: 'Create an MFA method' })
);
- const saveStep = within(screen.getByTestId('save-step'));
- await user.type(saveStep.getByLabelText('MFA Method Name'), 'new-mfa');
- await user.type(saveStep.getByLabelText(/Authenticator Code/), '345678');
+ expect(screen.getByTestId('save-step')).toBeInTheDocument();
+ await user.type(screen.getByLabelText('MFA Method Name'), 'new-mfa');
+ await user.type(screen.getByLabelText(/Authenticator Code/), '345678');
await user.click(
- saveStep.getByRole('button', { name: 'Save the MFA method' })
+ screen.getByRole('button', { name: 'Save the MFA method' })
);
expect(ctx.mfaService.addNewTotpDevice).toHaveBeenCalledWith({
tokenId: 'privilege-token',
@@ -186,28 +182,24 @@ describe('flow with reauthentication', () => {
test('adds a passkey with WebAuthn reauthentication', async () => {
render();
- const reauthenticateStep = await waitFor(() => {
- return within(screen.getByTestId('reauthenticate-step'));
+ await waitFor(() => {
+ expect(screen.getByTestId('reauthenticate-step')).toBeInTheDocument();
});
- await user.click(reauthenticateStep.getByText('Verify my identity'));
+ await user.click(screen.getByText('Verify my identity'));
- const createStep = await waitFor(() => {
- return within(screen.getByTestId('create-step'));
+ await waitFor(() => {
+ expect(screen.getByTestId('create-step')).toBeInTheDocument();
});
- await user.click(
- createStep.getByRole('button', { name: 'Create a passkey' })
- );
+ await user.click(screen.getByRole('button', { name: 'Create a passkey' }));
expect(auth.createNewWebAuthnDevice).toHaveBeenCalledWith({
tokenId: 'privilege-token',
deviceUsage: 'passwordless',
});
- const saveStep = within(screen.getByTestId('save-step'));
- await user.type(saveStep.getByLabelText('Passkey Nickname'), 'new-passkey');
- await user.click(
- saveStep.getByRole('button', { name: 'Save the Passkey' })
- );
+ expect(screen.getByTestId('save-step')).toBeInTheDocument();
+ await user.type(screen.getByLabelText('Passkey Nickname'), 'new-passkey');
+ await user.click(screen.getByRole('button', { name: 'Save the Passkey' }));
expect(ctx.mfaService.saveNewWebAuthnDevice).toHaveBeenCalledWith({
credential: dummyCredential,
addRequest: {
@@ -222,33 +214,26 @@ describe('flow with reauthentication', () => {
test('adds a passkey with OTP reauthentication', async () => {
render();
- const reauthenticateStep = await waitFor(() => {
- return within(screen.getByTestId('reauthenticate-step'));
+ await waitFor(() => {
+ expect(screen.getByTestId('reauthenticate-step')).toBeInTheDocument();
});
- await user.click(reauthenticateStep.getByText('Authenticator App'));
- await user.type(
- reauthenticateStep.getByLabelText('Authenticator Code'),
- '654987'
- );
- await user.click(reauthenticateStep.getByText('Verify my identity'));
+ await user.click(screen.getByText('Authenticator App'));
+ await user.type(screen.getByLabelText('Authenticator Code'), '654987');
+ await user.click(screen.getByText('Verify my identity'));
- const createStep = await waitFor(() => {
- return within(screen.getByTestId('create-step'));
+ await waitFor(() => {
+ expect(screen.getByTestId('create-step')).toBeInTheDocument();
});
- await user.click(
- createStep.getByRole('button', { name: 'Create a passkey' })
- );
+ await user.click(screen.getByRole('button', { name: 'Create a passkey' }));
expect(auth.createNewWebAuthnDevice).toHaveBeenCalledWith({
tokenId: 'privilege-token',
deviceUsage: 'passwordless',
});
- const saveStep = within(screen.getByTestId('save-step'));
- await user.type(saveStep.getByLabelText('Passkey Nickname'), 'new-passkey');
- await user.click(
- saveStep.getByRole('button', { name: 'Save the Passkey' })
- );
+ expect(screen.getByTestId('save-step')).toBeInTheDocument();
+ await user.type(screen.getByLabelText('Passkey Nickname'), 'new-passkey');
+ await user.click(screen.getByRole('button', { name: 'Save the Passkey' }));
expect(ctx.mfaService.saveNewWebAuthnDevice).toHaveBeenCalledWith({
credential: dummyCredential,
addRequest: {
@@ -263,15 +248,11 @@ describe('flow with reauthentication', () => {
test('shows reauthentication options', async () => {
render();
- const reauthenticateStep = await waitFor(() => {
- return within(screen.getByTestId('reauthenticate-step'));
+ await waitFor(() => {
+ expect(screen.getByTestId('reauthenticate-step')).toBeInTheDocument();
});
- expect(
- reauthenticateStep.queryByLabelText(/passkey or security key/i)
- ).toBeVisible();
- expect(
- reauthenticateStep.queryByLabelText(/authenticator app/i)
- ).toBeVisible();
+ expect(screen.queryByLabelText(/passkey or security key/i)).toBeVisible();
+ expect(screen.queryByLabelText(/authenticator app/i)).toBeVisible();
});
});
diff --git a/web/packages/teleport/src/Account/ManageDevices/wizards/DeleteAuthDeviceWizard.story.tsx b/web/packages/teleport/src/Account/ManageDevices/wizards/DeleteAuthDeviceWizard.story.tsx
index da707ef1445f6..3cbde51f69c79 100644
--- a/web/packages/teleport/src/Account/ManageDevices/wizards/DeleteAuthDeviceWizard.story.tsx
+++ b/web/packages/teleport/src/Account/ManageDevices/wizards/DeleteAuthDeviceWizard.story.tsx
@@ -20,11 +20,12 @@ import React from 'react';
import Dialog from 'design/Dialog';
+import { Attempt } from 'shared/hooks/useAttemptNext';
+
import { createTeleportContext } from 'teleport/mocks/contexts';
import { ContextProvider } from 'teleport/index';
import {
- DeviceType,
MFA_OPTION_SSO_DEFAULT,
MFA_OPTION_TOTP,
MFA_OPTION_WEBAUTHN,
@@ -36,7 +37,6 @@ import {
DeleteDeviceStep,
} from './DeleteAuthDeviceWizard';
import { ReauthenticateStep } from './ReauthenticateStep';
-import { Attempt } from 'shared/hooks/useAttemptNext';
export default {
title: 'teleport/Account/Manage Devices/Delete Device Wizard',
@@ -121,5 +121,5 @@ const stepProps: DeleteAuthDeviceWizardStepProps = {
MFA_OPTION_TOTP,
MFA_OPTION_SSO_DEFAULT,
],
- submitWithMfa: async (mfaType?: DeviceType, otpCode?: string) => {},
+ submitWithMfa: async () => {},
};
diff --git a/web/packages/teleport/src/Account/ManageDevices/wizards/DeleteAuthDeviceWizard.test.tsx b/web/packages/teleport/src/Account/ManageDevices/wizards/DeleteAuthDeviceWizard.test.tsx
index e51c5cf15df30..76bfd5d72e5d9 100644
--- a/web/packages/teleport/src/Account/ManageDevices/wizards/DeleteAuthDeviceWizard.test.tsx
+++ b/web/packages/teleport/src/Account/ManageDevices/wizards/DeleteAuthDeviceWizard.test.tsx
@@ -19,7 +19,7 @@
import { render, screen } from 'design/utils/testing';
import React from 'react';
-import { waitFor, within } from '@testing-library/react';
+import { waitFor } from '@testing-library/react';
import { userEvent, UserEvent } from '@testing-library/user-event';
import TeleportContext from 'teleport/teleportContext';
@@ -29,7 +29,7 @@ import auth from 'teleport/services/auth';
import { DeleteAuthDeviceWizardStepProps } from './DeleteAuthDeviceWizard';
-import { dummyPasskey, dummyHardwareDevice, deviceCases } from './deviceCases';
+import { dummyPasskey, dummyHardwareDevice } from './deviceCases';
import { DeleteAuthDeviceWizard } from '.';
@@ -73,14 +73,13 @@ function TestWizard(props: Partial) {
test('deletes a device with WebAuthn reauthentication', async () => {
render();
- let reauthenticateStep;
await waitFor(() => {
- reauthenticateStep = within(screen.getByTestId('reauthenticate-step'));
+ expect(screen.getByTestId('reauthenticate-step')).toBeInTheDocument();
});
- await user.click(reauthenticateStep.getByText('Verify my identity'));
+ await user.click(screen.getByText('Verify my identity'));
- const deleteStep = within(screen.getByTestId('delete-step'));
- await user.click(deleteStep.getByRole('button', { name: 'Delete' }));
+ expect(screen.getByTestId('delete-step')).toBeInTheDocument();
+ await user.click(screen.getByRole('button', { name: 'Delete' }));
expect(ctx.mfaService.removeDevice).toHaveBeenCalledWith(
'privilege-token',
@@ -92,19 +91,15 @@ test('deletes a device with WebAuthn reauthentication', async () => {
test('deletes a device with OTP reauthentication', async () => {
render();
- let reauthenticateStep;
await waitFor(() => {
- reauthenticateStep = within(screen.getByTestId('reauthenticate-step'));
+ expect(screen.getByTestId('reauthenticate-step')).toBeInTheDocument();
});
- await user.click(reauthenticateStep.getByText('Authenticator App'));
- await user.type(
- reauthenticateStep.getByLabelText('Authenticator Code'),
- '654987'
- );
- await user.click(reauthenticateStep.getByText('Verify my identity'));
+ await user.click(screen.getByText('Authenticator App'));
+ await user.type(screen.getByLabelText('Authenticator Code'), '654987');
+ await user.click(screen.getByText('Verify my identity'));
- const deleteStep = within(screen.getByTestId('delete-step'));
- await user.click(deleteStep.getByRole('button', { name: 'Delete' }));
+ expect(screen.getByTestId('delete-step')).toBeInTheDocument();
+ await user.click(screen.getByRole('button', { name: 'Delete' }));
expect(ctx.mfaService.removeDevice).toHaveBeenCalledWith(
'privilege-token',
@@ -130,13 +125,13 @@ test.each([
async ({ device, title, message }) => {
render();
- const reauthenticateStep = await waitFor(() => {
- return within(screen.getByTestId('reauthenticate-step'));
+ await waitFor(() => {
+ expect(screen.getByTestId('reauthenticate-step')).toBeInTheDocument();
});
- await user.click(reauthenticateStep.getByText('Verify my identity'));
+ await user.click(screen.getByText('Verify my identity'));
- const deleteStep = within(screen.getByTestId('delete-step'));
- expect(deleteStep.getByText(title)).toBeVisible();
- expect(deleteStep.getByText(message)).toBeVisible();
+ expect(screen.getByTestId('delete-step')).toBeInTheDocument();
+ expect(screen.getByText(title)).toBeVisible();
+ expect(screen.getByText(message)).toBeVisible();
}
);
diff --git a/web/packages/teleport/src/Account/ManageDevices/wizards/DeleteAuthDeviceWizard.tsx b/web/packages/teleport/src/Account/ManageDevices/wizards/DeleteAuthDeviceWizard.tsx
index df51e825c4051..dcd6f4d910e15 100644
--- a/web/packages/teleport/src/Account/ManageDevices/wizards/DeleteAuthDeviceWizard.tsx
+++ b/web/packages/teleport/src/Account/ManageDevices/wizards/DeleteAuthDeviceWizard.tsx
@@ -38,11 +38,12 @@ import { MfaDevice } from 'teleport/services/mfa';
import useReAuthenticate from 'teleport/components/ReAuthenticate/useReAuthenticate';
+import auth, { MfaChallengeScope } from 'teleport/services/auth/auth';
+
import {
ReauthenticateStep,
ReauthenticateStepProps,
} from './ReauthenticateStep';
-import auth, { MfaChallengeScope } from 'teleport/services/auth/auth';
interface DeleteAuthDeviceWizardProps {
/** Device to be removed. */
diff --git a/web/packages/teleport/src/Account/ManageDevices/wizards/ReauthenticateStep.tsx b/web/packages/teleport/src/Account/ManageDevices/wizards/ReauthenticateStep.tsx
index c36e133e73c7b..806d54c910919 100644
--- a/web/packages/teleport/src/Account/ManageDevices/wizards/ReauthenticateStep.tsx
+++ b/web/packages/teleport/src/Account/ManageDevices/wizards/ReauthenticateStep.tsx
@@ -20,7 +20,7 @@ import { OutlineDanger } from 'design/Alert/Alert';
import { ButtonPrimary, ButtonSecondary } from 'design/Button';
import Flex from 'design/Flex';
import { RadioGroup } from 'design/RadioGroup';
-import React, { useState, FormEvent, useEffect } from 'react';
+import React, { useState, FormEvent } from 'react';
import FieldInput from 'shared/components/FieldInput';
import Validation, { Validator } from 'shared/components/Validation';
import { requiredField } from 'shared/components/Validation/rules';
diff --git a/web/packages/teleport/src/components/ReAuthenticate/ReAuthenticate.story.tsx b/web/packages/teleport/src/components/ReAuthenticate/ReAuthenticate.story.tsx
index bf107c81164ea..a202663b5daa7 100644
--- a/web/packages/teleport/src/components/ReAuthenticate/ReAuthenticate.story.tsx
+++ b/web/packages/teleport/src/components/ReAuthenticate/ReAuthenticate.story.tsx
@@ -18,13 +18,14 @@
import React from 'react';
-import { ReAuthenticate, State } from './ReAuthenticate';
import {
MFA_OPTION_SSO_DEFAULT,
MFA_OPTION_TOTP,
MFA_OPTION_WEBAUTHN,
} from 'teleport/services/mfa';
+import { ReAuthenticate, State } from './ReAuthenticate';
+
export default {
title: 'Teleport/ReAuthenticate',
};
diff --git a/web/packages/teleport/src/services/auth/auth.ts b/web/packages/teleport/src/services/auth/auth.ts
index a818eda3e1f5b..c6c9ea277846d 100644
--- a/web/packages/teleport/src/services/auth/auth.ts
+++ b/web/packages/teleport/src/services/auth/auth.ts
@@ -16,8 +16,6 @@
* along with this program. If not, see .
*/
-import { Auth2faType } from 'shared/services';
-
import api from 'teleport/services/api';
import cfg from 'teleport/config';
import {