// @watch start // templates/repo/diff/** // web_src/css/features/imagediff.css // web_src/css/modules/tab.css // web_src/js/modules/tab.ts // @watch end import {expect} from '@playwright/test'; import {save_visual, test, dynamic_id} from './utils_e2e.ts'; test.use({user: 'user2'}); test('Repository image diff', async ({page}) => { // Generate a temporary SVG and edit it. let response = await page.goto('/user2/repo1/_new/master', {waitUntil: 'domcontentloaded'}); expect(response?.status()).toBe(200); const filename = `${dynamic_id()}.svg`; await page.getByPlaceholder('Name your file…').fill(filename); await page.locator('.monaco-editor').click(); await page.keyboard.type('\n'); await page.locator('.quick-pull-choice input[value="direct"]').click(); await page.getByRole('button', {name: 'Commit changes'}).click(); response = await page.goto(`/user2/repo1/_edit/master/${filename}`, {waitUntil: 'domcontentloaded'}); expect(response?.status()).toBe(200); await page.locator('.monaco-editor').click(); await page.keyboard.press('Meta+KeyA'); await page.keyboard.type('\n'); await page.locator('.quick-pull-choice input[value="direct"]').click(); await page.getByRole('button', {name: 'Commit changes'}).click(); // Go to the commit page, where a image diff is shown. await page.locator('.commit-summary a.default-link').click(); // Exhaustively test tabs works as expected await expect(page.locator('.item[data-tab="diff-side-by-side-1"]')).toContainClass('active'); await expect(page.locator('.item[data-tab="diff-swipe-1"]')).not.toContainClass('active'); await expect(page.locator('.item[data-tab="diff-overlay-1"]')).not.toContainClass('active'); await expect(page.locator('.tab[data-tab="diff-side-by-side-1"]')).toBeVisible(); await expect(page.locator('.tab[data-tab="diff-swipe-1"]')).toBeHidden(); await expect(page.locator('.tab[data-tab="diff-overlay-1"]')).toBeHidden(); await save_visual(page); await page.getByText('Swipe').click(); await expect(page.locator('.item[data-tab="diff-side-by-side-1"]')).not.toContainClass('active'); await expect(page.locator('.item[data-tab="diff-swipe-1"]')).toContainClass('active'); await expect(page.locator('.item[data-tab="diff-overlay-1"]')).not.toContainClass('active'); await expect(page.locator('.tab[data-tab="diff-side-by-side-1"]')).toBeHidden(); await expect(page.locator('.tab[data-tab="diff-swipe-1"]')).toBeVisible(); await expect(page.locator('.tab[data-tab="diff-overlay-1"]')).toBeHidden(); await save_visual(page); await page.getByText('Overlay').click(); await expect(page.locator('.item[data-tab="diff-side-by-side-1"]')).not.toContainClass('active'); await expect(page.locator('.item[data-tab="diff-swipe-1"]')).not.toContainClass('active'); await expect(page.locator('.item[data-tab="diff-overlay-1"]')).toContainClass('active'); await expect(page.locator('.tab[data-tab="diff-side-by-side-1"]')).toBeHidden(); await expect(page.locator('.tab[data-tab="diff-swipe-1"]')).toBeHidden(); await expect(page.locator('.tab[data-tab="diff-overlay-1"]')).toBeVisible(); await save_visual(page); });