2024-11-15 13:36:56 +01:00
|
|
|
import { test as base } from "@playwright/test";
|
|
|
|
|
import dotenv from "dotenv";
|
|
|
|
|
import path from "path";
|
|
|
|
|
import { loginScreenExpect, loginWithPassword, startLogin } from "./login";
|
|
|
|
|
import { loginname } from "./loginname";
|
|
|
|
|
import { loginnameScreenExpect } from "./loginname-screen";
|
|
|
|
|
import { password } from "./password";
|
|
|
|
|
import { passwordScreenExpect } from "./password-screen";
|
|
|
|
|
import { PasswordUser } from "./user";
|
2024-10-28 19:44:50 +01:00
|
|
|
|
|
|
|
|
// Read from ".env" file.
|
2024-11-15 13:36:56 +01:00
|
|
|
dotenv.config({ path: path.resolve(__dirname, ".env.local") });
|
2024-10-28 19:44:50 +01:00
|
|
|
|
|
|
|
|
const test = base.extend<{ user: PasswordUser }>({
|
2024-11-15 13:36:56 +01:00
|
|
|
user: async ({ page }, use) => {
|
|
|
|
|
const user = new PasswordUser({
|
|
|
|
|
email: "password@example.com",
|
|
|
|
|
firstName: "first",
|
|
|
|
|
lastName: "last",
|
|
|
|
|
password: "Password1!",
|
|
|
|
|
organization: "",
|
|
|
|
|
});
|
|
|
|
|
await user.ensure(page);
|
|
|
|
|
await use(user);
|
|
|
|
|
},
|
2024-10-28 19:44:50 +01:00
|
|
|
});
|
|
|
|
|
|
2024-11-15 13:36:56 +01:00
|
|
|
test("username and password login", async ({ user, page }) => {
|
|
|
|
|
await loginWithPassword(page, user.getUsername(), user.getPassword());
|
|
|
|
|
await loginScreenExpect(page, user.getFullName());
|
2024-10-16 12:23:38 +02:00
|
|
|
});
|
2024-10-28 19:44:50 +01:00
|
|
|
|
2024-11-15 13:36:56 +01:00
|
|
|
test("username and password login, unknown username", async ({ page }) => {
|
|
|
|
|
const username = "unknown";
|
|
|
|
|
await startLogin(page);
|
|
|
|
|
await loginname(page, username);
|
|
|
|
|
await loginnameScreenExpect(page, username);
|
2024-11-13 19:48:25 +01:00
|
|
|
});
|
2024-10-28 19:44:50 +01:00
|
|
|
|
2024-11-15 13:36:56 +01:00
|
|
|
test("username and password login, wrong password", async ({ user, page }) => {
|
|
|
|
|
await startLogin(page);
|
|
|
|
|
await loginname(page, user.getUsername());
|
|
|
|
|
await password(page, "wrong");
|
|
|
|
|
await passwordScreenExpect(page, "wrong");
|
2024-11-13 19:48:25 +01:00
|
|
|
});
|
2024-11-18 09:30:23 +01:00
|
|
|
|
|
|
|
|
test("username and password login, wrong username, ignore unknown usernames", async ({user, page}) => {
|
|
|
|
|
// Given user doesn't exist but ignore unknown usernames setting is set to true
|
|
|
|
|
// Given username password login is enabled on the users organization
|
|
|
|
|
|
|
|
|
|
// enter login name
|
|
|
|
|
// enter password
|
|
|
|
|
// redirect to loginname page --> error message username or password wrong
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
test("username and password login, initial password change", async ({user, page}) => {
|
|
|
|
|
// Given user is created and has changePassword set to true
|
|
|
|
|
// Given username password login is enabled on the users organization
|
|
|
|
|
|
|
|
|
|
// enter login name
|
|
|
|
|
// enter password
|
|
|
|
|
// create new password
|
|
|
|
|
});
|
|
|
|
|
|
2024-11-18 15:30:29 +01:00
|
|
|
|
|
|
|
|
test("username and password login, reset password hidden", async ({user, page}) => {
|
|
|
|
|
// Given the organization has enabled "Password reset hidden" in the login policy
|
|
|
|
|
// Given username password login is enabled on the users organization
|
|
|
|
|
|
|
|
|
|
// enter login name
|
|
|
|
|
// password reset link should not be shown on password screen
|
|
|
|
|
});
|
|
|
|
|
|
2024-11-18 09:30:23 +01:00
|
|
|
test("username and password login, reset password - enter code manually", async ({user, page}) => {
|
|
|
|
|
// Given user has forgotten password and clicks the forgot password button
|
|
|
|
|
// Given username password login is enabled on the users organization
|
|
|
|
|
|
|
|
|
|
// enter login name
|
|
|
|
|
// click password forgotten
|
|
|
|
|
// enter code from email
|
2024-11-18 15:30:29 +01:00
|
|
|
// user is redirected to app (default redirect url)
|
2024-11-18 09:30:23 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
|
|
test("username and password login, reset password - click link", async ({user, page}) => {
|
|
|
|
|
// Given user has forgotten password and clicks the forgot password button, and then the link in the email
|
|
|
|
|
// Given username password login is enabled on the users organization
|
|
|
|
|
|
|
|
|
|
// enter login name
|
|
|
|
|
// click password forgotten
|
|
|
|
|
// click link in email
|
|
|
|
|
// set new password
|
2024-11-18 15:30:29 +01:00
|
|
|
// redirect to app (default redirect url)
|
2024-11-18 09:30:23 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
|
|
test("username and password login, reset password, resend code", async ({user, page}) => {
|
|
|
|
|
// Given user has forgotten password and clicks the forgot password button and then resend code
|
|
|
|
|
// Given username password login is enabled on the users organization
|
|
|
|
|
|
|
|
|
|
// enter login name
|
|
|
|
|
// click password forgotten
|
|
|
|
|
// click resend code
|
|
|
|
|
// enter code from second email
|
2024-11-18 15:30:29 +01:00
|
|
|
// user is redirected to app (default redirect url)
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
test("email login enabled", async ({user, page}) => {
|
|
|
|
|
// Given user with the username "testuser", email test@zitadel.com and phone number 0711111111 exists
|
|
|
|
|
// Given no other user with the same email address exists
|
|
|
|
|
|
|
|
|
|
// enter email address "test@zitadel.com " in login screen
|
|
|
|
|
// user will get to password screen
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
test("email login disabled", async ({user, page}) => {
|
|
|
|
|
// Given user with the username "testuser", email test@zitadel.com and phone number 0711111111 exists
|
|
|
|
|
// Given no other user with the same email address exists
|
|
|
|
|
|
|
|
|
|
// enter email address "test@zitadel.com" in login screen
|
|
|
|
|
// user will see error message "user not found"
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
test("email login enabled - multiple users", async ({user, page}) => {
|
|
|
|
|
// Given user with the username "testuser", email test@zitadel.com and phone number 0711111111 exists
|
|
|
|
|
// Given a second user with the username "testuser2", email test@zitadel.com and phone number 0711111111 exists
|
|
|
|
|
|
|
|
|
|
// enter email address "test@zitadel.com" in login screen
|
|
|
|
|
// user will see error message "user not found"
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
test("phone login enabled", async ({user, page}) => {
|
|
|
|
|
// Given user with the username "testuser", email test@zitadel.com and phone number 0711111111 exists
|
|
|
|
|
// Given no other user with the same phon number exists
|
|
|
|
|
|
|
|
|
|
// enter phone number "0711111111" in login screen
|
|
|
|
|
// user will get to password screen
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
test("phone login disabled", async ({user, page}) => {
|
|
|
|
|
// Given user with the username "testuser", email test@zitadel.com and phone number 0711111111 exists
|
|
|
|
|
// Given no other user with the same phone number exists
|
|
|
|
|
|
|
|
|
|
// enter phone number "0711111111" in login screen
|
|
|
|
|
// user will see error message "user not found"
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
test("phone login enabled - multiple users", async ({user, page}) => {
|
|
|
|
|
// Given user with the username "testuser", email test@zitadel.com and phone number 0711111111 exists
|
|
|
|
|
// Given a second user with the username "testuser2", email test@zitadel.com and phone number 0711111111 exists
|
|
|
|
|
|
|
|
|
|
// enter phone number "0711111111" in login screen
|
|
|
|
|
// user will see error message "user not found"
|
|
|
|
|
});
|
|
|
|
|
|