2022-11-09 14:34:34 +00:00
|
|
|
import { expect } from '@playwright/test';
|
|
|
|
|
|
|
|
import { loadFixture } from '../../playwright/paths';
|
|
|
|
import { test } from '../../playwright/test';
|
|
|
|
|
|
|
|
test.describe('Debug-Sidebar', async () => {
|
2022-12-06 12:01:30 +00:00
|
|
|
test.slow(process.platform === 'darwin' || process.platform === 'win32', 'Slow app start on these platforms');
|
2022-11-09 14:34:34 +00:00
|
|
|
test.beforeEach(async ({ app, page }) => {
|
2023-01-20 14:49:52 +00:00
|
|
|
await page.getByTestId('project').click();
|
|
|
|
await page.getByRole('button', { name: 'Create' }).click();
|
2022-11-09 14:34:34 +00:00
|
|
|
const text = await loadFixture('simple.yaml');
|
|
|
|
await app.evaluate(async ({ clipboard }, text) => clipboard.writeText(text), text);
|
2023-03-31 10:53:22 +00:00
|
|
|
await page.getByRole('menuitem', { name: 'Import' }).click();
|
|
|
|
await page.getByText('Clipboard').click();
|
|
|
|
await page.getByRole('button', { name: 'Scan' }).click();
|
|
|
|
await page.getByRole('button', { name: 'Import' }).click();
|
|
|
|
|
|
|
|
await page.getByRole('link', { name: 'Debug' }).click();
|
2022-11-09 14:34:34 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
test.describe('Interact with sidebar', async () => {
|
|
|
|
test('Open Properties of an HTTP Request', async ({ page }) => {
|
2023-01-20 14:49:52 +00:00
|
|
|
await page.getByRole('button', { name: 'example http' }).click();
|
2022-11-09 14:34:34 +00:00
|
|
|
await page.locator('[data-testid="Dropdown-example-http"]').click();
|
2023-01-20 14:49:52 +00:00
|
|
|
await page.getByRole('menuitem', { name: 'Settings' }).click();
|
2022-11-09 14:34:34 +00:00
|
|
|
await expect(page.locator('.app')).toContainText('Request Settings req');
|
|
|
|
// Close settings modal
|
|
|
|
await page.locator('.app').press('Escape');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('Open properties of a grpc request', async ({ page }) => {
|
2023-01-20 14:49:52 +00:00
|
|
|
await page.getByRole('button', { name: 'example grpc' }).click();
|
2022-11-09 14:34:34 +00:00
|
|
|
await page.locator('[data-testid="Dropdown-example-grpc"]').click();
|
2023-01-20 14:49:52 +00:00
|
|
|
await page.getByRole('menuitem', { name: 'Settings' }).click();
|
2022-11-09 14:34:34 +00:00
|
|
|
await expect(page.locator('.app')).toContainText('Request Settings greq');
|
|
|
|
// Close settings modal
|
|
|
|
await page.locator('.app').press('Escape');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('Open properties of a websocket request', async ({ page }) => {
|
2023-01-20 14:49:52 +00:00
|
|
|
await page.getByRole('button', { name: 'example websocket' }).click();
|
2022-11-09 14:34:34 +00:00
|
|
|
await page.locator('[data-testid="Dropdown-example-websocket"]').click();
|
2023-01-20 14:49:52 +00:00
|
|
|
await page.getByRole('menuitem', { name: 'Settings' }).click();
|
2022-11-09 14:34:34 +00:00
|
|
|
await expect(page.locator('.app')).toContainText('Request Settings ws-req');
|
|
|
|
// Close settings modal
|
|
|
|
await page.locator('.app').press('Escape');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('Open properties of a graphql request', async ({ page }) => {
|
2023-01-20 14:49:52 +00:00
|
|
|
await page.getByRole('button', { name: 'example graphql' }).click();
|
2022-11-09 14:34:34 +00:00
|
|
|
await page.locator('[data-testid="Dropdown-example-graphql"]').click();
|
2023-01-20 14:49:52 +00:00
|
|
|
await page.getByRole('menuitem', { name: 'Settings' }).click();
|
2022-11-09 14:34:34 +00:00
|
|
|
await expect(page.locator('.app')).toContainText('Request Settings req');
|
|
|
|
// Close settings modal
|
|
|
|
await page.locator('.app').press('Escape');
|
|
|
|
});
|
|
|
|
|
2022-11-17 16:45:07 +00:00
|
|
|
test('Open properties of a folder', async ({ page }) => {
|
2023-01-20 14:49:52 +00:00
|
|
|
await page.getByRole('button', { name: 'test folder' }).click();
|
2022-11-17 16:45:07 +00:00
|
|
|
await page.locator('[data-testid="Dropdown-test-folder"] button').click();
|
2023-01-20 14:49:52 +00:00
|
|
|
await page.getByRole('menuitem', { name: 'Settings' }).click();
|
2022-11-17 16:45:07 +00:00
|
|
|
await expect(page.locator('.app')).toContainText('Folder Settings fld');
|
2022-11-09 14:34:34 +00:00
|
|
|
});
|
|
|
|
|
2022-11-21 17:30:50 +00:00
|
|
|
test('Open properties of the collection', async ({ page }) => {
|
2023-03-31 10:53:22 +00:00
|
|
|
await page.getByRole('button', { name: 'Untitled' }).click();
|
|
|
|
await page.getByRole('menuitem', { name: 'Document Settings' }).click();
|
|
|
|
await page.getByText('Document Settings').click();
|
2022-11-09 14:34:34 +00:00
|
|
|
});
|
|
|
|
|
2022-11-30 09:51:36 +00:00
|
|
|
test('Filter by request name', async ({ page }) => {
|
|
|
|
await page.locator('[placeholder="Filter"]').click();
|
|
|
|
await page.locator('[placeholder="Filter"]').fill('example http');
|
2023-01-20 14:49:52 +00:00
|
|
|
await page.getByRole('button', { name: 'example http' }).click();
|
2022-11-09 14:34:34 +00:00
|
|
|
});
|
|
|
|
|
2022-12-06 12:01:30 +00:00
|
|
|
test('Filter by a folder name', async ({ page }) => {
|
|
|
|
await page.locator('[data-testid="SidebarFilter"] [data-testid="DropdownButton"] button').click();
|
2023-01-20 14:49:52 +00:00
|
|
|
await page.getByRole('menuitem', { name: 'Folders First' }).click();
|
2022-12-06 12:01:30 +00:00
|
|
|
await page.locator('[placeholder="Filter"]').click();
|
|
|
|
await page.locator('[placeholder="Filter"]').fill('test folder');
|
|
|
|
await page.locator('[placeholder="Filter"]').press('Enter');
|
|
|
|
await page.locator('button:has-text("test folderOPEN")').click();
|
2022-11-09 14:34:34 +00:00
|
|
|
});
|
|
|
|
|
2022-12-13 17:46:54 +00:00
|
|
|
test('Open Generate code', async ({ page }) => {
|
2023-01-20 14:49:52 +00:00
|
|
|
await page.getByRole('button', { name: 'example http' }).click();
|
2022-12-13 17:46:54 +00:00
|
|
|
await page.locator('[data-testid="Dropdown-example-http"] button').click();
|
2023-01-20 14:49:52 +00:00
|
|
|
await page.getByRole('menuitem', { name: 'Generate Code' }).click();
|
2022-12-13 17:46:54 +00:00
|
|
|
await page.locator('[data-testid="CodeEditor"] >> text=curl').click();
|
|
|
|
await page.locator('text=Done').click();
|
|
|
|
});
|
|
|
|
|
|
|
|
test.skip('Use Copy as Curl for a request', async ({}) => {
|
|
|
|
// TODO: implement this in a separate ticket
|
2022-11-09 14:34:34 +00:00
|
|
|
});
|
|
|
|
|
2022-12-06 12:01:30 +00:00
|
|
|
test('Pin a Request', async ({ page }) => {
|
2023-01-20 14:49:52 +00:00
|
|
|
await page.getByRole('button', { name: 'example http' }).click();
|
2022-12-06 12:01:30 +00:00
|
|
|
await page.locator('[data-testid="Dropdown-example-http"] button').click();
|
2023-01-20 14:49:52 +00:00
|
|
|
await page.getByRole('menuitem', { name: 'Pin' }).click();
|
2022-12-06 12:01:30 +00:00
|
|
|
// Click pinned request on pinned request list
|
|
|
|
await page.locator('button:has-text("GETexample http")').first().click();
|
|
|
|
// Click pinned request on regular list
|
|
|
|
await page.locator('button:has-text("GETexample http")').nth(1).click();
|
2022-11-09 14:34:34 +00:00
|
|
|
});
|
|
|
|
|
2022-12-06 12:01:30 +00:00
|
|
|
test('Delete Request', async ({ page }) => {
|
2023-01-20 14:49:52 +00:00
|
|
|
await page.getByRole('button', { name: 'example http' }).click();
|
2022-12-06 12:01:30 +00:00
|
|
|
await page.locator('[data-testid="Dropdown-example-http"] button').click();
|
2023-01-20 14:49:52 +00:00
|
|
|
await page.getByRole('menuitem', { name: 'Delete' }).click();
|
|
|
|
await page.getByRole('button', { name: 'Click to confirm' }).click();
|
2022-12-06 12:01:30 +00:00
|
|
|
await expect(page.locator('.app')).not.toContainText('example http');
|
2022-11-09 14:34:34 +00:00
|
|
|
});
|
|
|
|
|
2022-12-06 12:01:30 +00:00
|
|
|
test('Rename a request', async ({ page }) => {
|
2023-01-20 14:49:52 +00:00
|
|
|
await page.getByRole('button', { name: 'example http' }).click();
|
2022-12-06 12:01:30 +00:00
|
|
|
await page.locator('[data-testid="Dropdown-example-http"]').click();
|
2023-01-20 14:49:52 +00:00
|
|
|
await page.getByRole('menuitem', { name: 'Rename' }).click();
|
2022-12-06 12:01:30 +00:00
|
|
|
await page.locator('text=Rename RequestName Rename >> input[type="text"]').fill('example http1');
|
|
|
|
await page.locator('div[role="dialog"] button:has-text("Rename")').click();
|
|
|
|
await page.locator('button:has-text("example http1")').click();
|
2022-11-09 14:34:34 +00:00
|
|
|
});
|
|
|
|
|
2022-11-10 17:54:13 +00:00
|
|
|
test('Create a new HTTP request', async ({ page }) => {
|
2022-11-14 09:10:19 +00:00
|
|
|
await page.locator('[data-testid="SidebarFilter"] [data-testid="SidebarCreateDropdown"] button').click();
|
2023-01-20 14:49:52 +00:00
|
|
|
await page.getByRole('menuitem', { name: 'Http Request' }).click();
|
2022-11-10 17:54:13 +00:00
|
|
|
await expect(page.locator('.app')).toContainText('New Request');
|
2022-11-09 14:34:34 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
// TODO: more scenarios will be added in follow-up iterations of increasing test coverage
|
2022-11-17 16:45:07 +00:00
|
|
|
});
|
2022-11-09 14:34:34 +00:00
|
|
|
});
|