Files
bruno/tests/request/headers/header-validation.spec.ts
Pooja aa7b8f4ca1 fix: autosave playwright test (#7641)
* fix: autosave playwright test

* fix
2026-04-01 15:06:31 +05:30

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);
});
});
});