Files
console/e2e/steps/pro-project.ts
2026-01-27 14:21:37 +05:30

83 lines
3.4 KiB
TypeScript

import { test, expect, type Page } from '@playwright/test';
import { getOrganizationIdFromUrl, getProjectIdFromUrl } from '../helpers/url';
type Metadata = {
id: string;
organizationId: string;
};
export async function enterCreditCard(page: Page) {
// click the `add` button inside correct view layer
await page
.locator('#no-payments-card-stack')
.getByRole('button', { name: 'add' })
.first()
.click();
const dialog = page.locator('.modal').filter({ hasText: 'add payment method' });
await dialog.waitFor({ state: 'visible' });
await page.getByPlaceholder('cardholder').fill('Test User');
const stripe = page.locator('[title="Secure payment input frame"]').nth(0).contentFrame();
await stripe.locator('id=payment-numberInput').fill('4242424242424242');
await stripe.locator('id=payment-expiryInput').fill('1250');
await stripe.locator('id=payment-cvcInput').fill('123');
await stripe.locator('id=payment-countryInput').selectOption('DE');
await dialog.getByRole('button', { name: 'Add', exact: true }).click();
await page.locator('id=state-picker').click(); // open dropdown
await page.getByRole('option', { name: 'Alabama' }).click();
await dialog.getByRole('button', { name: 'Add', exact: true }).click();
await dialog.waitFor({
state: 'hidden'
});
}
export async function createProProject(page: Page): Promise<Metadata> {
const organizationId = await test.step('create organization', async () => {
await page.goto('./create-organization');
await page.locator('id=name').fill('test org');
await page.getByRole('radio', { name: /^Pro\b/ }).check();
// `create organization` because there's already free created on start!
await page.getByRole('button', { name: 'create organization' }).click();
await enterCreditCard(page);
// skip members
await page.getByRole('button', { name: 'create organization' }).click();
await page.waitForURL(/\/organization-[^/]+/);
return getOrganizationIdFromUrl(page.url());
});
const projectId = await test.step('create project', async () => {
await page.waitForURL(/\/organization-[^/]+/);
await page.getByRole('button', { name: 'create project' }).first().click();
const dialog = page.locator('dialog[open]');
await dialog.getByPlaceholder('Project name').fill('test project');
let region = 'fra'; // for fallback
const regionPicker = dialog.locator('button[role="combobox"]');
if (await regionPicker.isVisible()) {
await regionPicker.click();
const firstEnabledOption = page
.locator('[role="option"]:not([data-disabled="true"])')
.first();
if ((await firstEnabledOption.count()) > 0) {
const selectedRegion = await firstEnabledOption.getAttribute('data-value');
await firstEnabledOption.click();
region = selectedRegion?.replace(/"/g, '') || 'fra';
}
}
await dialog.getByRole('button', { name: 'create' }).click();
await page.waitForURL(new RegExp(`/project-${region}-[^/]+`));
expect(page.url()).toContain(`/console/project-${region}-`);
return getProjectIdFromUrl(page.url());
});
return {
id: projectId,
organizationId
};
}