mirror of
https://github.com/Kong/insomnia
synced 2024-11-08 14:49:53 +00:00
e38ece1ab7
* 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>
168 lines
7.8 KiB
TypeScript
168 lines
7.8 KiB
TypeScript
import { expect } from '@playwright/test';
|
|
|
|
import { loadFixture } from '../../playwright/paths';
|
|
import { test } from '../../playwright/test';
|
|
|
|
test.describe('Dashboard', async () => {
|
|
test.slow(process.platform === 'darwin' || process.platform === 'win32', 'Slow app start on these platforms');
|
|
test.describe('Projects', async () => {
|
|
test('Can create, rename and delete new project', async ({ page }) => {
|
|
// Return to Dashboard
|
|
await page.getByTestId('project').click();
|
|
await expect(page.locator('.app')).toContainText('All Files (1)');
|
|
await expect(page.locator('.app')).not.toContainText('Setup Git Sync');
|
|
|
|
// Create new project
|
|
await page.click('[data-testid="CreateProjectButton"]');
|
|
await page.locator('text=Create').nth(1).click();
|
|
|
|
// Check empty project
|
|
await expect(page.locator('.app')).toContainText('This is an empty project, to get started create your first resource:');
|
|
|
|
// Rename Project
|
|
await page.click('[data-testid="ProjectDropDown-My-Project"] button');
|
|
await page.getByRole('menuitem', { name: 'Project Settings' }).click();
|
|
await page.getByPlaceholder('My Project').click();
|
|
await page.getByPlaceholder('My Project').fill('My Project123');
|
|
|
|
// Check that the project name is updated on modal
|
|
await expect(page.locator('.app')).toContainText('My Project123');
|
|
|
|
// Close project settings modal
|
|
await page.locator('.app').press('Escape');
|
|
await expect(page.locator('.app')).toContainText('My Project123');
|
|
|
|
// Delete project
|
|
await page.click('[data-testid="ProjectDropDown-My-Project123"] button');
|
|
await page.getByRole('menuitem', { name: 'Project Settings' }).click();
|
|
// Click text=NameActions Delete >> button
|
|
await page.click('text=NameActions Delete >> button');
|
|
await page.getByRole('button', { name: 'Click to confirm' }).click();
|
|
|
|
// After deleting project, return to default Insomnia Dashboard
|
|
await expect(page.locator('.app')).toContainText('Insomnia');
|
|
await expect(page.locator('.app')).not.toContainText('My Project123');
|
|
await expect(page.locator('.app')).toContainText('New Document');
|
|
await expect(page.locator('.app')).toContainText('All Files (1)');
|
|
await expect(page.locator('.app')).not.toContainText('Setup Git Sync');
|
|
});
|
|
});
|
|
test.describe('Interactions', async () => { // Not sure about the name here
|
|
test('Can filter through multiple collections', async ({ app, page }) => {
|
|
await page.getByTestId('project').click();
|
|
await expect(page.locator('.app')).toContainText('All Files (1)');
|
|
await expect(page.locator('.app')).not.toContainText('Setup Git Sync');
|
|
|
|
await page.getByRole('button', { name: 'Create' }).click();
|
|
const text = await loadFixture('multiple-workspaces.yaml');
|
|
await app.evaluate(async ({ clipboard }, text) => clipboard.writeText(text), text);
|
|
await page.getByRole('menuitem', { name: 'Clipboard' }).click();
|
|
|
|
// Check that 10 new workspaces are imported besides the default one
|
|
const workspaceCards = page.locator('.card-badge');
|
|
await expect(workspaceCards).toHaveCount(11);
|
|
await expect(page.locator('.app')).toContainText('New Document');
|
|
await expect(page.locator('.app')).toContainText('collection 1');
|
|
await expect(page.locator('.app')).toContainText('design doc 1');
|
|
await expect(page.locator('.app')).toContainText('Swagger Petstore V3 JSON 1.0.0');
|
|
await expect(page.locator('.app')).toContainText('Swagger Petstore V3 YAML 1.0.0');
|
|
|
|
// Filter by collection
|
|
const filter = page.locator('[placeholder="Filter\\.\\.\\."]');
|
|
|
|
// Filter by word with results expected
|
|
await filter.fill('design');
|
|
await expect(page.locator('.card-badge')).toHaveCount(4);
|
|
|
|
// Filter by number
|
|
await filter.fill('3');
|
|
await expect(page.locator('.card-badge')).toHaveCount(2);
|
|
|
|
// Filter by word with no results expected
|
|
await filter.fill('invalid');
|
|
await expect(page.locator('.card-badge')).toHaveCount(0);
|
|
});
|
|
|
|
test('Can create, rename and delete a document', async ({ page }) => {
|
|
await page.getByTestId('project').click();
|
|
await expect(page.locator('.app')).toContainText('All Files (1)');
|
|
await expect(page.locator('.app')).not.toContainText('Setup Git Sync');
|
|
|
|
// Create new document
|
|
await page.getByRole('button', { name: 'Create' }).click();
|
|
await page.getByRole('menuitem', { name: 'Design Document' }).click();
|
|
await page.locator('text=Create').nth(1).click();
|
|
|
|
// Return to dashboard
|
|
await page.getByTestId('project').click();
|
|
await expect(page.locator('.app')).toContainText('my-spec.yaml');
|
|
|
|
// Rename document
|
|
await page.click('text=Documentmy-spec.yamljust now >> button');
|
|
await page.getByRole('menuitem', { name: 'Rename' }).click();
|
|
await page.locator('text=Rename DocumentName Rename >> input[type="text"]').fill('test123');
|
|
await page.click('#root button:has-text("Rename")');
|
|
await expect(page.locator('.app')).toContainText('test123');
|
|
|
|
// Duplicate document
|
|
await page.click('text=Documenttest123just now >> button');
|
|
await page.getByRole('menuitem', { name: 'Duplicate' }).click();
|
|
await page.locator('input[name="name"]').fill('test123-duplicate');
|
|
await page.click('[role="dialog"] button:has-text("Duplicate")');
|
|
|
|
// Return to dashboard
|
|
await page.getByTestId('project').click();
|
|
await expect(page.locator('.app')).toContainText('test123-duplicate');
|
|
|
|
const workspaceCards = page.locator('.card-badge');
|
|
await expect(workspaceCards).toHaveCount(3);
|
|
|
|
// Delete document
|
|
await page.click('text=Documenttest123just now >> button');
|
|
await page.getByRole('menuitem', { name: 'Delete' }).click();
|
|
await page.locator('text=Yes').click();
|
|
await expect(workspaceCards).toHaveCount(2);
|
|
});
|
|
|
|
test('Can create, rename and delete a collection', async ({ page }) => {
|
|
await page.getByTestId('project').click();
|
|
await expect(page.locator('.app')).toContainText('All Files (1)');
|
|
await expect(page.locator('.app')).not.toContainText('Setup Git Sync');
|
|
|
|
// Create new collection
|
|
await page.getByRole('button', { name: 'Create' }).click();
|
|
await page.getByRole('menuitem', { name: 'Request Collection' }).click();
|
|
await page.locator('text=Create').nth(1).click();
|
|
|
|
// Return to dashboard
|
|
await page.getByTestId('project').click();
|
|
await expect(page.locator('.app')).toContainText('My Collection');
|
|
|
|
// Rename collection
|
|
await page.click('text=CollectionMy Collectionjust now >> button');
|
|
await page.getByRole('menuitem', { name: 'Rename' }).click();
|
|
await page.locator('text=Rename CollectionName Rename >> input[type="text"]').fill('test123');
|
|
await page.click('#root button:has-text("Rename")');
|
|
await expect(page.locator('.app')).toContainText('test123');
|
|
|
|
// Duplicate collection
|
|
await page.click('text=Collectiontest123just now >> button');
|
|
await page.getByRole('menuitem', { name: 'Duplicate' }).click();
|
|
await page.locator('input[name="name"]').fill('test123-duplicate');
|
|
await page.click('[role="dialog"] button:has-text("Duplicate")');
|
|
|
|
// Return to dashboard
|
|
await page.getByTestId('project').click();
|
|
await expect(page.locator('.app')).toContainText('test123-duplicate');
|
|
const workspaceCards = page.locator('.card-badge');
|
|
await expect(workspaceCards).toHaveCount(3);
|
|
|
|
// Delete collection
|
|
await page.click('text=Collectiontest123just now >> button');
|
|
await page.getByRole('menuitem', { name: 'Delete' }).click();
|
|
await page.locator('text=Yes').click();
|
|
await expect(workspaceCards).toHaveCount(2);
|
|
});
|
|
});
|
|
});
|