2024-09-30 17:02:16 +02:00
|
|
|
import { expect, test } from '@playwright/test';
|
|
|
|
|
|
|
|
|
|
import { createDoc, goToGridDoc, mockedDocument } from './common';
|
|
|
|
|
|
|
|
|
|
test.beforeEach(async ({ page }) => {
|
|
|
|
|
await page.goto('/');
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
test.describe('Doc Version', () => {
|
|
|
|
|
test('it displays the doc versions', async ({ page, browserName }) => {
|
|
|
|
|
const [randomDoc] = await createDoc(page, 'doc-version', browserName, 1);
|
|
|
|
|
|
|
|
|
|
await expect(page.locator('h2').getByText(randomDoc)).toBeVisible();
|
|
|
|
|
|
|
|
|
|
await page.getByLabel('Open the document options').click();
|
|
|
|
|
await page
|
|
|
|
|
.getByRole('button', {
|
|
|
|
|
name: 'Version history',
|
|
|
|
|
})
|
|
|
|
|
.click();
|
|
|
|
|
|
|
|
|
|
const panel = page.getByLabel('Document panel');
|
|
|
|
|
|
|
|
|
|
await expect(panel.getByText('Current version')).toBeVisible();
|
|
|
|
|
expect(await panel.locator('li').count()).toBe(1);
|
|
|
|
|
|
|
|
|
|
await page.locator('.ProseMirror.bn-editor').click();
|
|
|
|
|
await page.locator('.ProseMirror.bn-editor').last().fill('Hello World');
|
|
|
|
|
|
|
|
|
|
await goToGridDoc(page, {
|
|
|
|
|
title: randomDoc,
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
await expect(page.getByText('Hello World')).toBeVisible();
|
|
|
|
|
|
|
|
|
|
await page
|
|
|
|
|
.locator('.ProseMirror .bn-block')
|
|
|
|
|
.getByText('Hello World')
|
|
|
|
|
.fill('It will create a version');
|
|
|
|
|
|
|
|
|
|
await goToGridDoc(page, {
|
|
|
|
|
title: randomDoc,
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
await expect(page.getByText('Hello World')).toBeHidden();
|
|
|
|
|
await expect(page.getByText('It will create a version')).toBeVisible();
|
|
|
|
|
|
|
|
|
|
await page.getByLabel('Open the document options').click();
|
|
|
|
|
await page
|
|
|
|
|
.getByRole('button', {
|
|
|
|
|
name: 'Version history',
|
|
|
|
|
})
|
|
|
|
|
.click();
|
|
|
|
|
|
|
|
|
|
await expect(panel.getByText('Current version')).toBeVisible();
|
|
|
|
|
expect(await panel.locator('li').count()).toBe(2);
|
|
|
|
|
|
|
|
|
|
await panel.locator('li').nth(1).click();
|
|
|
|
|
await expect(
|
|
|
|
|
page.getByText('Read only, you cannot edit document versions.'),
|
|
|
|
|
).toBeVisible();
|
|
|
|
|
await expect(page.getByText('Hello World')).toBeVisible();
|
|
|
|
|
await expect(page.getByText('It will create a version')).toBeHidden();
|
|
|
|
|
|
|
|
|
|
await panel.getByText('Current version').click();
|
|
|
|
|
await expect(page.getByText('Hello World')).toBeHidden();
|
|
|
|
|
await expect(page.getByText('It will create a version')).toBeVisible();
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
test('it does not display the doc versions if not allowed', async ({
|
|
|
|
|
page,
|
|
|
|
|
}) => {
|
|
|
|
|
await mockedDocument(page, {
|
|
|
|
|
abilities: {
|
|
|
|
|
versions_list: false,
|
|
|
|
|
partial_update: true,
|
|
|
|
|
},
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
await goToGridDoc(page);
|
|
|
|
|
|
|
|
|
|
await expect(page.locator('h2').getByText('Mocked document')).toBeVisible();
|
|
|
|
|
|
|
|
|
|
await page.getByLabel('Open the document options').click();
|
|
|
|
|
await expect(
|
|
|
|
|
page.getByRole('button', { name: 'Version history' }),
|
|
|
|
|
).toBeHidden();
|
|
|
|
|
|
|
|
|
|
await page.getByRole('button', { name: 'Table of content' }).click();
|
|
|
|
|
|
|
|
|
|
await expect(
|
|
|
|
|
page.getByLabel('Document panel').getByText('Versions'),
|
|
|
|
|
).toBeHidden();
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
test('it restores the doc version', async ({ page, browserName }) => {
|
|
|
|
|
const [randomDoc] = await createDoc(page, 'doc-version', browserName, 1);
|
|
|
|
|
|
|
|
|
|
await expect(page.locator('h2').getByText(randomDoc)).toBeVisible();
|
|
|
|
|
|
|
|
|
|
await page.locator('.bn-block-outer').last().click();
|
|
|
|
|
await page.locator('.bn-block-outer').last().fill('Hello');
|
|
|
|
|
|
|
|
|
|
await goToGridDoc(page, {
|
|
|
|
|
title: randomDoc,
|
|
|
|
|
});
|
|
|
|
|
|
2024-10-02 11:25:01 +02:00
|
|
|
const editor = page.locator('.ProseMirror');
|
|
|
|
|
await expect(editor.getByText('Hello')).toBeVisible();
|
2024-09-30 17:02:16 +02:00
|
|
|
await page.locator('.bn-block-outer').last().click();
|
|
|
|
|
await page.keyboard.press('Enter');
|
|
|
|
|
await page.locator('.bn-block-outer').last().fill('World');
|
|
|
|
|
|
|
|
|
|
await goToGridDoc(page, {
|
|
|
|
|
title: randomDoc,
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
await expect(page.getByText('World')).toBeVisible();
|
|
|
|
|
|
|
|
|
|
await page.getByLabel('Open the document options').click();
|
|
|
|
|
await page
|
|
|
|
|
.getByRole('button', {
|
|
|
|
|
name: 'Version history',
|
|
|
|
|
})
|
|
|
|
|
.click();
|
|
|
|
|
|
|
|
|
|
const panel = page.getByLabel('Document panel');
|
|
|
|
|
await panel.locator('li').nth(1).click();
|
|
|
|
|
await expect(page.getByText('World')).toBeHidden();
|
|
|
|
|
|
|
|
|
|
await panel.getByLabel('Open the version options').click();
|
|
|
|
|
await page.getByText('Restore the version').click();
|
|
|
|
|
|
|
|
|
|
await expect(page.getByText('Restore this version?')).toBeVisible();
|
|
|
|
|
|
|
|
|
|
await page
|
|
|
|
|
.getByRole('button', {
|
|
|
|
|
name: 'Restore',
|
|
|
|
|
})
|
|
|
|
|
.click();
|
|
|
|
|
|
|
|
|
|
await expect(panel.locator('li')).toHaveCount(3);
|
|
|
|
|
|
|
|
|
|
await panel.getByText('Current version').click();
|
|
|
|
|
await expect(page.getByText('Hello')).toBeVisible();
|
|
|
|
|
await expect(page.getByText('World')).toBeHidden();
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
test('it restores the doc version from button title', async ({
|
|
|
|
|
page,
|
|
|
|
|
browserName,
|
|
|
|
|
}) => {
|
|
|
|
|
const [randomDoc] = await createDoc(page, 'doc-version', browserName, 1);
|
|
|
|
|
|
|
|
|
|
await expect(page.locator('h2').getByText(randomDoc)).toBeVisible();
|
|
|
|
|
|
2024-10-02 11:25:01 +02:00
|
|
|
const editor = page.locator('.ProseMirror');
|
|
|
|
|
await editor.locator('.bn-block-outer').last().click();
|
|
|
|
|
await editor.locator('.bn-block-outer').last().fill('Hello');
|
2024-09-30 17:02:16 +02:00
|
|
|
|
|
|
|
|
await goToGridDoc(page, {
|
|
|
|
|
title: randomDoc,
|
|
|
|
|
});
|
|
|
|
|
|
2024-10-02 11:25:01 +02:00
|
|
|
await expect(editor.getByText('Hello')).toBeVisible();
|
|
|
|
|
await editor.locator('.bn-block-outer').last().click();
|
2024-09-30 17:02:16 +02:00
|
|
|
await page.keyboard.press('Enter');
|
2024-10-02 11:25:01 +02:00
|
|
|
await editor.locator('.bn-block-outer').last().fill('World');
|
2024-09-30 17:02:16 +02:00
|
|
|
|
|
|
|
|
await goToGridDoc(page, {
|
|
|
|
|
title: randomDoc,
|
|
|
|
|
});
|
|
|
|
|
|
2024-10-02 11:25:01 +02:00
|
|
|
await expect(editor.getByText('World')).toBeVisible();
|
2024-09-30 17:02:16 +02:00
|
|
|
|
|
|
|
|
await page.getByLabel('Open the document options').click();
|
|
|
|
|
await page
|
|
|
|
|
.getByRole('button', {
|
|
|
|
|
name: 'Version history',
|
|
|
|
|
})
|
|
|
|
|
.click();
|
|
|
|
|
|
|
|
|
|
const panel = page.getByLabel('Document panel');
|
|
|
|
|
await panel.locator('li').nth(1).click();
|
2024-10-02 11:25:01 +02:00
|
|
|
await expect(editor.getByText('World')).toBeHidden();
|
2024-09-30 17:02:16 +02:00
|
|
|
|
|
|
|
|
await page
|
|
|
|
|
.getByRole('button', {
|
|
|
|
|
name: 'Restore this version',
|
|
|
|
|
})
|
|
|
|
|
.click();
|
|
|
|
|
|
|
|
|
|
await expect(page.getByText('Restore this version?')).toBeVisible();
|
|
|
|
|
|
|
|
|
|
await page
|
|
|
|
|
.getByRole('button', {
|
|
|
|
|
name: 'Restore',
|
|
|
|
|
})
|
|
|
|
|
.click();
|
|
|
|
|
|
|
|
|
|
await expect(panel.locator('li')).toHaveCount(3);
|
|
|
|
|
|
|
|
|
|
await panel.getByText('Current version').click();
|
2024-10-02 11:25:01 +02:00
|
|
|
await expect(editor.getByText('Hello')).toBeVisible();
|
|
|
|
|
await expect(editor.getByText('World')).toBeHidden();
|
2024-09-30 17:02:16 +02:00
|
|
|
});
|
|
|
|
|
});
|