insomnia/packages/insomnia-smoke-test/tests/prerelease/debug-sidebar-interactions.test.ts
Pavlos Koutoglou e38ece1ab7
Feature/ins-2070-bug-updowntabshifttab-not-working (#5615)
* Update version of react-aria package

* Create dropdown hint component

* Create dropdown button component

* Create the popover component

* Create the menu item component

* Create the menu section component

* Create the menu component

* Create the dropdown related components

* Change the hotkey html tag

* Added full width option for prompt-button

* Replace the dropdown with the new

* Add some default props for dropdown

* Used themed button into dropdown button

* Added style prop for dropdown

* Remove checkmark from menu item

* Added styled props to popover

* Remove inner button from account toolbar

* Added new dropdown into cookie-list

* Revert package update

* WIP

* Delete button component and replace it's usage with dropdown button

* Fix spacing

* Added className for code-editor dropdown

* Remove the old dropdown

* Change import

* Revert some ref changes

* Added ref to dropdown

* Fixed some styles

* Fix issues like autosave and added isDisable prop

* Add title

* Remove insomnia-common imports

* Remove insomnia-common imports

* Fix code format

* Change style and fix code format

* Fix styles

* Replace dropdown import

* Fix divider style

* Fix last icon in sidebar create dropdown

* Fix issue with dropdown and the resizing screen

* Fix linter issues

* Moved the prompt button into itemContent component

* Change styled component

* Fix issue with sidebar-request-row to display the dropdown on hover

* Remove the item content in a separate component

* Remove unused css

* Destructure children props

* Fix trigger prop for grpc-method-dropdown

* Added prompt button when user delete test suite

* Hide empty dropdown items from section

* Fix linter issues

* Added Checkmark into item content

* Fix issue with linter and shortcut component

* Fixed linter issues

* Revert fragments

* Fix linter issues

* Added props for multiple select and disable

* Fix close issue with sidebar dropdown

* Update disable and stay open prop for all dropdowns

* Added aria-label for dropdown, section, items

* Added selected style for item

* Added logic for disabled items

* Fixed issue with selected items

* Fix issue with selection of grpc method dropdown

* Added aria-label to code-editor

* Fix issue with onClick and prompt

* Hide sections if it's empty

* Remove on select from item content

* Pass closeOnSelect props in the menu

* Removed dataTestId from dropdown items in request-actions

* Fix debug sidebar dropdown tests

* Change the cookie editor interactions tests

* Fix dashboard interactions tests

* Fix design-interactions tests

* Fixed grpc-interactions tests

* Fix plugins interactions tests

* Fix preferences interactions tests

* Fixed request-pane-tab tests

* Fixed app smoke tests

* Update git-sync smoke tests

* Fix space issue

* Fixed graphql smoke test

* Fixed oauth smoke test

* Fixed oauth smoke test

* Fixed websocket smoke test

* Fixed cookie-editor-interactions tests

* Remove the dropdown unit test

* Made small refactoring and remove unnecessary props

* Fix issue with grpc-method-dropdown

* Change the grpc smoke test

* Added default role props

* Update all tests that use project role

* Remove console.log

* Fix issue with themes

* REmove dropdown import from index.less file

* Remove handleClick and add some comments

* Use getItemCount from react-stately

* Remove method-dropdown css

* Fix shortcut button style

* remove extra space on sync-dropdown

* fix lint

* Remove unused prop

* Fix issue with remote workspace dropdown

* remove divider on first section if empty

* remove unused showGrpc option in method dropdown

* Fix issue with workspace-dropdown

* Fix git-sync-dropdown issues

* Fix issue with remove workspaces dropdown

* Fix sync-dropdown component

* Added disable style

* Moved server reflection and proto file outside of the dropdown

* Fix style when item is selected

* Fix issue with grpc smoke test

* Fix issue with menu props

* Disable server reflection button if url is empty

Co-authored-by: Filipe Freire <livrofubia@gmail.com>
Co-authored-by: gatzjames <jamesgatzos@gmail.com>
2023-01-20 16:49:52 +02:00

130 lines
6.4 KiB
TypeScript

import { expect } from '@playwright/test';
import { loadFixture } from '../../playwright/paths';
import { test } from '../../playwright/test';
test.describe('Debug-Sidebar', async () => {
test.slow(process.platform === 'darwin' || process.platform === 'win32', 'Slow app start on these platforms');
test.beforeEach(async ({ app, page }) => {
await page.getByTestId('project').click();
await page.getByRole('button', { name: 'Create' }).click();
const text = await loadFixture('simple.yaml');
await app.evaluate(async ({ clipboard }, text) => clipboard.writeText(text), text);
await page.getByRole('menuitem', { name: 'Clipboard' }).click();
await page.click('text=Collectionsimplejust now');
});
test.describe('Interact with sidebar', async () => {
test('Open Properties of an HTTP Request', async ({ page }) => {
await page.getByRole('button', { name: 'example http' }).click();
await page.locator('[data-testid="Dropdown-example-http"]').click();
await page.getByRole('menuitem', { name: 'Settings' }).click();
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 }) => {
await page.getByRole('button', { name: 'example grpc' }).click();
await page.locator('[data-testid="Dropdown-example-grpc"]').click();
await page.getByRole('menuitem', { name: 'Settings' }).click();
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 }) => {
await page.getByRole('button', { name: 'example websocket' }).click();
await page.locator('[data-testid="Dropdown-example-websocket"]').click();
await page.getByRole('menuitem', { name: 'Settings' }).click();
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 }) => {
await page.getByRole('button', { name: 'example graphql' }).click();
await page.locator('[data-testid="Dropdown-example-graphql"]').click();
await page.getByRole('menuitem', { name: 'Settings' }).click();
await expect(page.locator('.app')).toContainText('Request Settings req');
// Close settings modal
await page.locator('.app').press('Escape');
});
test('Open properties of a folder', async ({ page }) => {
await page.getByRole('button', { name: 'test folder' }).click();
await page.locator('[data-testid="Dropdown-test-folder"] button').click();
await page.getByRole('menuitem', { name: 'Settings' }).click();
await expect(page.locator('.app')).toContainText('Folder Settings fld');
});
test('Open properties of the collection', async ({ page }) => {
await page.getByRole('button', { name: 'simple' }).click();
await page.getByRole('menuitem', { name: 'Collection Settings' }).click();
await expect(page.locator('.app')).toContainText('Collection Settings wrk');
});
test('Filter by request name', async ({ page }) => {
await page.locator('[placeholder="Filter"]').click();
await page.locator('[placeholder="Filter"]').fill('example http');
await page.getByRole('button', { name: 'example http' }).click();
});
test('Filter by a folder name', async ({ page }) => {
await page.locator('[data-testid="SidebarFilter"] [data-testid="DropdownButton"] button').click();
await page.getByRole('menuitem', { name: 'Folders First' }).click();
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();
});
test('Open Generate code', async ({ page }) => {
await page.getByRole('button', { name: 'example http' }).click();
await page.locator('[data-testid="Dropdown-example-http"] button').click();
await page.getByRole('menuitem', { name: 'Generate Code' }).click();
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
});
test('Pin a Request', async ({ page }) => {
await page.getByRole('button', { name: 'example http' }).click();
await page.locator('[data-testid="Dropdown-example-http"] button').click();
await page.getByRole('menuitem', { name: 'Pin' }).click();
// 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();
});
test('Delete Request', async ({ page }) => {
await page.getByRole('button', { name: 'example http' }).click();
await page.locator('[data-testid="Dropdown-example-http"] button').click();
await page.getByRole('menuitem', { name: 'Delete' }).click();
await page.getByRole('button', { name: 'Click to confirm' }).click();
await expect(page.locator('.app')).not.toContainText('example http');
});
test('Rename a request', async ({ page }) => {
await page.getByRole('button', { name: 'example http' }).click();
await page.locator('[data-testid="Dropdown-example-http"]').click();
await page.getByRole('menuitem', { name: 'Rename' }).click();
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();
});
test('Create a new HTTP request', async ({ page }) => {
await page.locator('[data-testid="SidebarFilter"] [data-testid="SidebarCreateDropdown"] button').click();
await page.getByRole('menuitem', { name: 'Http Request' }).click();
await expect(page.locator('.app')).toContainText('New Request');
});
// TODO: more scenarios will be added in follow-up iterations of increasing test coverage
});
});