mirror of
https://github.com/CorentinTh/it-tools.git
synced 2025-05-05 05:47:10 -04:00
40 lines
1.4 KiB
TypeScript
40 lines
1.4 KiB
TypeScript
![]() |
import { test, expect } from '@playwright/test';
|
||
|
|
||
|
test.describe('Tool - JSON diff', () => {
|
||
|
test.beforeEach(async ({ page }) => {
|
||
|
await page.goto('/json-diff');
|
||
|
});
|
||
|
|
||
|
test('Has correct title', async ({ page }) => {
|
||
|
await expect(page).toHaveTitle('JSON diff - IT Tools');
|
||
|
});
|
||
|
|
||
|
test('Identical JSONs have a custom result message', async ({ page }) => {
|
||
|
await page.getByTestId('leftJson').fill('{"foo":"bar"}');
|
||
|
await page.getByTestId('rightJson').fill('{ "foo": "bar" } ');
|
||
|
|
||
|
const result = await page.getByTestId('diff-result').innerText();
|
||
|
|
||
|
expect(result).toContain('The provided JSONs are the same');
|
||
|
});
|
||
|
|
||
|
test('Different JSONs have differences listed', async ({ page }) => {
|
||
|
await page.getByTestId('leftJson').fill('{"foo":"bar"}');
|
||
|
await page.getByTestId('rightJson').fill('{"foo":"buz","baz":"qux"}');
|
||
|
|
||
|
const result = await page.getByTestId('diff-result').innerText();
|
||
|
|
||
|
expect(result).toContain(`{\nfoo: "bar""buz",\nbaz: "qux",\n},`);
|
||
|
});
|
||
|
|
||
|
test('Different JSONs have only differences listed when "Only show differences" is checked', async ({ page }) => {
|
||
|
await page.getByTestId('leftJson').fill('{"foo":"bar"}');
|
||
|
await page.getByTestId('rightJson').fill('{"foo":"bar","baz":"qux"}');
|
||
|
await page.getByRole('switch').click();
|
||
|
|
||
|
const result = await page.getByTestId('diff-result').innerText();
|
||
|
|
||
|
expect(result).toContain(`{\nbaz: "qux",\n},`);
|
||
|
});
|
||
|
});
|