2023-11-24 21:31:26 +00:00
|
|
|
import type { UserProfileConfig } from "@keycloak/keycloak-admin-client/lib/defs/userProfileMetadata";
|
2023-08-31 09:32:39 +00:00
|
|
|
import { expect, test } from "@playwright/test";
|
2023-09-12 11:54:38 +00:00
|
|
|
import {
|
2024-02-27 06:15:23 +00:00
|
|
|
createRandomUserWithPassword,
|
2023-09-12 11:54:38 +00:00
|
|
|
deleteUser,
|
2023-10-06 13:15:39 +00:00
|
|
|
enableLocalization,
|
|
|
|
importUserProfile,
|
2024-02-27 06:15:23 +00:00
|
|
|
inRealm,
|
2023-09-12 11:54:38 +00:00
|
|
|
} from "../admin-client";
|
2023-08-31 09:32:39 +00:00
|
|
|
import { login } from "../login";
|
|
|
|
import userProfileConfig from "./user-profile.json" assert { type: "json" };
|
2024-02-27 06:15:23 +00:00
|
|
|
import { randomUUID } from "crypto";
|
2023-08-31 09:32:39 +00:00
|
|
|
|
2023-09-12 11:54:38 +00:00
|
|
|
const realm = "user-profile";
|
|
|
|
|
2023-08-31 09:32:39 +00:00
|
|
|
test.describe("Personal info page", () => {
|
2024-02-27 06:15:23 +00:00
|
|
|
let user: string;
|
2023-08-31 09:32:39 +00:00
|
|
|
test("sets basic information", async ({ page }) => {
|
2024-02-27 06:15:23 +00:00
|
|
|
user = await createRandomUserWithPassword("user-" + randomUUID(), "pwd");
|
2023-11-14 11:04:55 +00:00
|
|
|
|
2024-03-04 12:38:28 +00:00
|
|
|
await login(page, user, "pwd");
|
2024-02-27 06:15:23 +00:00
|
|
|
|
|
|
|
await page.getByTestId("email").fill(`${user}@somewhere.com`);
|
2023-08-31 09:32:39 +00:00
|
|
|
await page.getByTestId("firstName").fill("Erik");
|
|
|
|
await page.getByTestId("lastName").fill("de Wit");
|
|
|
|
await page.getByTestId("save").click();
|
|
|
|
|
|
|
|
const alerts = page.getByTestId("alerts");
|
|
|
|
await expect(alerts).toHaveText("Your account has been updated.");
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
test.describe("Personal info with userprofile enabled", async () => {
|
2024-02-27 06:15:23 +00:00
|
|
|
let user: string;
|
2023-08-31 09:32:39 +00:00
|
|
|
test.beforeAll(async () => {
|
|
|
|
await importUserProfile(userProfileConfig as UserProfileConfig, realm);
|
2024-02-27 06:15:23 +00:00
|
|
|
user = await inRealm(realm, () =>
|
|
|
|
createRandomUserWithPassword("user-" + randomUUID(), "jdoe", {
|
2023-09-12 11:54:38 +00:00
|
|
|
email: "jdoe@keycloak.org",
|
|
|
|
firstName: "John",
|
|
|
|
lastName: "Doe",
|
|
|
|
realmRoles: [],
|
|
|
|
clientRoles: {
|
|
|
|
account: ["manage-account"],
|
|
|
|
},
|
2024-02-27 06:15:23 +00:00
|
|
|
}),
|
2023-09-12 11:54:38 +00:00
|
|
|
);
|
2023-08-31 09:32:39 +00:00
|
|
|
});
|
|
|
|
|
2024-02-27 06:15:23 +00:00
|
|
|
test.afterAll(async () => await inRealm(realm, () => deleteUser(user)));
|
2023-09-12 11:54:38 +00:00
|
|
|
|
2023-08-31 09:32:39 +00:00
|
|
|
test("render user profile fields", async ({ page }) => {
|
2024-02-27 06:15:23 +00:00
|
|
|
await login(page, user, "jdoe", realm);
|
2023-08-31 09:32:39 +00:00
|
|
|
|
|
|
|
await expect(page.locator("#select")).toBeVisible();
|
2023-11-14 11:04:55 +00:00
|
|
|
await expect(page.getByTestId("help-label-select")).toBeVisible();
|
2023-09-12 11:54:38 +00:00
|
|
|
expect(page.getByText("Alternative email")).toBeDefined();
|
|
|
|
});
|
|
|
|
|
|
|
|
test("save user profile", async ({ page }) => {
|
2024-02-27 06:15:23 +00:00
|
|
|
await login(page, user, "jdoe", realm);
|
2023-09-12 11:54:38 +00:00
|
|
|
|
|
|
|
await page.locator("#select").click();
|
|
|
|
await page.getByRole("option", { name: "two" }).click();
|
2023-11-14 11:04:55 +00:00
|
|
|
await page.getByTestId("email2").fill("non-valid");
|
2023-09-12 11:54:38 +00:00
|
|
|
await page.getByTestId("save").click();
|
|
|
|
await expect(page.getByTestId("alerts")).toHaveText(
|
|
|
|
"Could not update account due to validation errors",
|
|
|
|
);
|
|
|
|
|
2024-04-05 14:37:05 +00:00
|
|
|
await expect(page.getByTestId("email2-helper")).toHaveText(
|
2023-09-12 11:54:38 +00:00
|
|
|
"Invalid email address.",
|
|
|
|
);
|
|
|
|
|
|
|
|
await page.getByTestId("email2").clear();
|
2023-11-14 11:04:55 +00:00
|
|
|
await page.getByTestId("email2").fill("valid@email.com");
|
2023-09-12 11:54:38 +00:00
|
|
|
await page.getByTestId("save").click();
|
|
|
|
|
|
|
|
await page.reload();
|
2023-10-26 11:16:09 +00:00
|
|
|
await page.locator("delete-account").isVisible();
|
2023-09-12 11:54:38 +00:00
|
|
|
await expect(page.getByTestId("email2")).toHaveValue("valid@email.com");
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
// skip currently the locale is not part of the response
|
|
|
|
test.describe.skip("Realm localization", async () => {
|
2024-03-04 12:38:28 +00:00
|
|
|
test.beforeAll(() => enableLocalization());
|
2023-09-12 11:54:38 +00:00
|
|
|
|
|
|
|
test("change locale", async ({ page }) => {
|
2024-02-27 06:15:23 +00:00
|
|
|
const user = await createRandomUserWithPassword(
|
|
|
|
"user-" + randomUUID(),
|
|
|
|
"pwd",
|
|
|
|
);
|
|
|
|
|
2024-03-04 12:38:28 +00:00
|
|
|
await login(page, user, "pwd");
|
2023-09-12 11:54:38 +00:00
|
|
|
await page
|
|
|
|
.locator("div")
|
|
|
|
.filter({ hasText: /^Deutsch$/ })
|
|
|
|
.nth(2)
|
|
|
|
.click();
|
|
|
|
await page.getByRole("option", { name: "English" }).click();
|
|
|
|
await page.getByTestId("save").click();
|
|
|
|
await page.reload();
|
|
|
|
|
|
|
|
expect(page.locator("div").filter({ hasText: /^English$/ })).toBeDefined();
|
2023-08-31 09:32:39 +00:00
|
|
|
});
|
|
|
|
});
|