Files
zitadel/acceptance/tests/username-passkey.spec.ts

41 lines
1.3 KiB
TypeScript
Raw Normal View History

2024-11-20 14:22:22 +01:00
import { faker } from "@faker-js/faker";
2024-11-15 13:48:42 +01:00
import { test as base } from "@playwright/test";
import dotenv from "dotenv";
import path from "path";
import { loginScreenExpect, loginWithPasskey } from "./login";
import { PasskeyUser } from "./user";
2024-10-28 19:44:50 +01:00
// Read from ".env" file.
2024-11-15 13:48:42 +01:00
dotenv.config({ path: path.resolve(__dirname, ".env.local") });
2024-10-28 19:44:50 +01:00
const test = base.extend<{ user: PasskeyUser }>({
2024-11-15 13:48:42 +01:00
user: async ({ page }, use) => {
const user = new PasskeyUser({
2024-11-20 14:22:22 +01:00
email: faker.internet.email(),
firstName: faker.person.firstName(),
lastName: faker.person.lastName(),
2024-11-15 13:48:42 +01:00
organization: "",
2024-11-20 14:22:22 +01:00
phone: faker.phone.number(),
2024-11-15 13:48:42 +01:00
});
await user.ensure(page);
await use(user);
2024-11-28 14:38:13 +01:00
await user.cleanup();
2024-11-15 13:48:42 +01:00
},
2024-10-28 19:44:50 +01:00
});
2024-11-15 13:48:42 +01:00
test("username and passkey login", async ({ user, page }) => {
await loginWithPasskey(page, user.getAuthenticatorId(), user.getUsername());
await loginScreenExpect(page, user.getFullName());
2024-10-28 19:44:50 +01:00
});
2024-11-18 09:30:23 +01:00
2024-11-20 14:22:22 +01:00
test("username and passkey login, multiple auth methods", async ({ page }) => {
2024-11-18 18:01:47 +01:00
// Given passkey and password is enabled on the organization of the user
// Given the user has password and passkey registered
// enter username
// passkey popup is directly shown
// user aborts passkey authentication
// user switches to password authentication
// user enters password
// user is redirected to app
2024-11-18 09:30:23 +01:00
});