import { expect } from "@playwright/test"; import { UserPlan } from "@prisma/client"; import { getFreePlanPrice, getProPlanPrice } from "@calcom/app-store/stripepayment/lib/utils"; import dayjs from "@calcom/dayjs"; import stripe from "@calcom/features/ee/payments/server/stripe"; import { WEBAPP_URL } from "@calcom/lib/constants"; import { test } from "./lib/fixtures"; test.describe.configure({ mode: "parallel" }); const IS_STRIPE_ENABLED = !!( process.env.STRIPE_CLIENT_ID && process.env.NEXT_PUBLIC_STRIPE_PUBLIC_KEY && process.env.STRIPE_PRIVATE_KEY ); const IS_SELF_HOSTED = !( new URL(WEBAPP_URL).hostname.endsWith(".cal.dev") || !!new URL(WEBAPP_URL).hostname.endsWith(".cal.com") ); test.describe("Change username on settings", () => { test.afterEach(async ({ users }) => { await users.deleteAll(); }); test("User can change username", async ({ page, users, prisma }) => { const user = await users.create({ plan: UserPlan.TRIAL }); await user.login(); // Try to go homepage await page.goto("/settings/my-account/profile"); // Change username from normal to normal const usernameInput = page.locator("[data-testid=username-input]"); await usernameInput.fill("demousernamex"); await page.click("[data-testid=update-username-btn]"); await Promise.all([ page.click("[data-testid=save-username]"), page.waitForResponse("**/viewer.updateProfile*"), ]); const newUpdatedUser = await prisma.user.findUniqueOrThrow({ where: { id: user.id, }, }); expect(newUpdatedUser.username).toBe("demousernamex"); }); test("User trial can update to PREMIUM username", async ({ page, users }, testInfo) => { // eslint-disable-next-line playwright/no-skipped-test test.skip(!IS_STRIPE_ENABLED, "It should only run if Stripe is installed"); test.skip(IS_SELF_HOSTED, "It shouldn't run on self hosted"); const user = await users.create({ plan: UserPlan.TRIAL }); const customer = await stripe.customers.create({ email: `${user?.username}@example.com` }); await stripe.subscriptionSchedules.create({ customer: customer.id, start_date: "now", end_behavior: "release", phases: [ { items: [{ price: getProPlanPrice() }], trial_end: dayjs().add(14, "day").unix(), end_date: dayjs().add(14, "day").unix(), }, { items: [{ price: getFreePlanPrice() }], }, ], }); await user.login(); await page.goto("/settings/my-account/profile"); // Change username from normal to premium const usernameInput = page.locator("[data-testid=username-input]"); await usernameInput.fill(`xx${testInfo.workerIndex}`); // Click on save button await page.click('button[type="submit"]'); // Validate modal text fields const currentUsernameText = page.locator("[data-testid=current-username]").innerText(); const newUsernameText = page.locator("[data-testid=new-username]").innerText(); expect(currentUsernameText).not.toBe(newUsernameText); // Click on Go to billing await page.click("[data-testid=go-to-billing]", { timeout: 300 }); await page.waitForLoadState(); await expect(page).toHaveURL(/.*checkout.stripe.com/); }); test("User PRO can update to PREMIUM username", async ({ page, users }, testInfo) => { // eslint-disable-next-line playwright/no-skipped-test test.skip(!IS_STRIPE_ENABLED, "It should only run if Stripe is installed"); test.skip(IS_SELF_HOSTED, "It shouldn't run on self hosted"); const user = await users.create({ plan: UserPlan.PRO }); const customer = await stripe.customers.create({ email: `${user?.username}@example.com` }); const paymentMethod = await stripe.paymentMethods.create({ type: "card", card: { number: "4242424242424242", cvc: "123", exp_month: 12, exp_year: 2040, }, }); await stripe.paymentMethods.attach(paymentMethod.id, { customer: customer.id }); await stripe.subscriptions.create({ customer: customer.id, items: [{ price: getProPlanPrice() }], }); await user.login(); await page.goto("/settings/profile"); // Change username from normal to premium const usernameInput = page.locator("[data-testid=username-input]"); await usernameInput.fill(`xx${testInfo.workerIndex}`); // Click on save button await page.click('button[type="submit"]'); // Validate modal text fields const currentUsernameText = page.locator("[data-testid=current-username]").innerText(); const newUsernameText = page.locator("[data-testid=new-username]").innerText(); expect(currentUsernameText).not.toBe(newUsernameText); // Click on Go to billing await page.click("[data-testid=go-to-billing]", { timeout: 300 }); await page.waitForLoadState(); await expect(page).toHaveURL(/.*billing.stripe.com/); }); });