mirror of
https://github.com/usebruno/bruno.git
synced 2026-06-11 09:51:30 +00:00
98 lines
3.8 KiB
TypeScript
98 lines
3.8 KiB
TypeScript
import { test, expect } from '../../../playwright';
|
|
import { closeAllCollections, createCollection, createRequest, openCollection, openRequest, saveRequest, selectRequestPaneTab } from '../../utils/page';
|
|
import { getTableCell } from '../../utils/page/locators';
|
|
|
|
const saveShortcut = process.platform === 'darwin' ? 'Meta+s' : 'Control+s';
|
|
|
|
test.describe.serial('Header Validation', () => {
|
|
test.afterAll(async ({ page }) => {
|
|
await closeAllCollections(page);
|
|
});
|
|
|
|
test.beforeAll(async ({ page, createTmpDir }) => {
|
|
await test.step('Create collection and request', async () => {
|
|
await createCollection(page, 'header-validation', await createTmpDir('header-validation'));
|
|
await createRequest(page, 'test-headers', '', {
|
|
url: 'https://httpbin.org/get',
|
|
inFolder: false
|
|
});
|
|
});
|
|
|
|
await test.step('Open the request', async () => {
|
|
await openCollection(page, 'header-validation');
|
|
await openRequest(page, 'header-validation', 'test-headers', { persist: true });
|
|
});
|
|
});
|
|
|
|
test('should show error icon when header name contains spaces', async ({ page, createTmpDir }) => {
|
|
await test.step('Navigate to Headers tab', async () => {
|
|
await selectRequestPaneTab(page, 'Headers');
|
|
});
|
|
|
|
await test.step('Enter header name with space and verify error icon', async () => {
|
|
const headerRow = page.locator('table tbody tr').first();
|
|
const nameCell = getTableCell(headerRow, 0);
|
|
|
|
// Click on the CodeMirror editor and type a header name with space
|
|
await nameCell.locator('.CodeMirror').click();
|
|
await nameCell.locator('textarea').fill('invalid header');
|
|
|
|
// Verify the error icon is visible
|
|
const errorIcon = headerRow.locator('.text-red-600');
|
|
await expect(errorIcon).toBeVisible();
|
|
|
|
// Hover over the error icon to show the tooltip
|
|
await errorIcon.hover();
|
|
|
|
// Verify the tooltip message
|
|
const tooltip = page.locator('.tooltip-mod');
|
|
await expect(tooltip).toContainText('Header name cannot contain spaces or newlines');
|
|
});
|
|
|
|
await test.step('Enter valid header name and verify no error icon', async () => {
|
|
const headerRow = page.locator('table tbody tr').first();
|
|
const nameCell = getTableCell(headerRow, 0);
|
|
|
|
// Clear and enter a valid header name - use triple-click to select all (works cross-platform)
|
|
await nameCell.locator('.CodeMirror').click({ clickCount: 3 });
|
|
await nameCell.locator('textarea').fill('Valid-Header');
|
|
|
|
// Verify the error icon is not visible
|
|
const errorIcon = headerRow.locator('.text-red-600');
|
|
|
|
// wait for formik to revalidate
|
|
await headerRow.click();
|
|
await expect(errorIcon).not.toBeVisible({});
|
|
});
|
|
});
|
|
|
|
test('should show error icon when header value contains newlines', async ({ page }) => {
|
|
await test.step('Navigate to Headers tab', async () => {
|
|
await selectRequestPaneTab(page, 'Headers');
|
|
});
|
|
|
|
await test.step('Enter header value with newline and verify error icon', async () => {
|
|
const headerRow = page.locator('table tbody tr').first();
|
|
const valueCell = getTableCell(headerRow, 1);
|
|
|
|
// Click on the value CodeMirror editor and type a value with newline
|
|
await valueCell.locator('.CodeMirror').click();
|
|
await valueCell.locator('textarea').fill('header\nValue');
|
|
|
|
// Verify the error icon is visible
|
|
const errorIcon = headerRow.locator('.text-red-600');
|
|
await expect(errorIcon).toBeVisible();
|
|
|
|
// Hover over the error icon to show the tooltip
|
|
await errorIcon.hover();
|
|
|
|
// Verify the tooltip message
|
|
const tooltip = page.locator('.tooltip-mod');
|
|
await expect(tooltip).toContainText('Header value cannot contain newlines');
|
|
|
|
// Save the request
|
|
await page.keyboard.press(saveShortcut);
|
|
});
|
|
});
|
|
});
|