2023-09-06 03:53:33 -05:00
|
|
|
import {expect, test} from '@playwright/test';
|
|
|
|
import {globalDataRequests, mockApi, mockSitePreview, responseFixtures} from '../../utils/e2e';
|
|
|
|
|
|
|
|
test.describe('Announcement Bar', async () => {
|
|
|
|
test('Working with the announcement bar preview', async ({page}) => {
|
|
|
|
await mockApi({page, requests: {
|
|
|
|
...globalDataRequests,
|
|
|
|
browseLatestPost: {method: 'GET', path: /^\/posts\/.+limit=1/, response: responseFixtures.latestPost}
|
|
|
|
}});
|
|
|
|
await mockSitePreview({
|
|
|
|
page,
|
|
|
|
url: responseFixtures.site.site.url,
|
|
|
|
response: '<html><head><style></style></head><body><div>homepage preview</div></body></html>'
|
|
|
|
});
|
|
|
|
await mockSitePreview({
|
|
|
|
page,
|
|
|
|
url: responseFixtures.latestPost.posts[0].url,
|
|
|
|
response: '<html><head><style></style></head><body><div>post preview</div></body></html>'
|
|
|
|
});
|
|
|
|
|
|
|
|
await page.goto('/');
|
2023-09-07 01:38:20 -05:00
|
|
|
|
2023-09-06 03:53:33 -05:00
|
|
|
const section = page.getByTestId('announcement-bar');
|
2023-09-07 01:38:20 -05:00
|
|
|
|
2023-09-06 03:53:33 -05:00
|
|
|
await section.getByRole('button', {name: 'Customize'}).click();
|
2023-09-07 01:38:20 -05:00
|
|
|
|
2023-09-11 03:23:12 -05:00
|
|
|
// // Homepage and post preview
|
|
|
|
await page.waitForSelector('[data-testid="announcement-bar-preview-iframe"]');
|
|
|
|
const iframeCount = await page.$$eval('[data-testid="announcement-bar-preview-iframe"] > iframe', frames => frames.length);
|
|
|
|
|
|
|
|
expect(iframeCount).toEqual(2);
|
|
|
|
|
2023-09-06 03:53:33 -05:00
|
|
|
const modal = page.getByTestId('announcement-bar-modal');
|
2023-09-07 01:38:20 -05:00
|
|
|
|
2023-09-11 03:23:12 -05:00
|
|
|
await page.waitForSelector('[data-testid="announcement-bar-preview-iframe"]');
|
|
|
|
|
|
|
|
// Get the iframes inside the modal
|
|
|
|
const iframesHandleHome = await page.$$('[data-testid="announcement-bar-preview-iframe"] > iframe');
|
2023-09-07 01:38:20 -05:00
|
|
|
|
2023-09-11 03:23:12 -05:00
|
|
|
const homeiframeHandler = iframesHandleHome[1]; // index 1 since that's the visible iframe
|
|
|
|
const frameHome = await homeiframeHandler.contentFrame();
|
|
|
|
const textExistsInFirstIframe = await frameHome?.$eval('body', (body, textToSearch) => {
|
|
|
|
return body.innerText.includes(textToSearch);
|
|
|
|
}, 'homepage preview');
|
|
|
|
|
|
|
|
expect(textExistsInFirstIframe).toBeTruthy();
|
2023-09-07 01:38:20 -05:00
|
|
|
|
2023-09-06 03:53:33 -05:00
|
|
|
await modal.getByTestId('design-toolbar').getByRole('tab', {name: 'Post'}).click();
|
2023-09-07 01:38:20 -05:00
|
|
|
|
2023-09-11 03:23:12 -05:00
|
|
|
await page.waitForSelector('[data-testid="announcement-bar-preview-iframe"]');
|
|
|
|
|
|
|
|
const iframesHandlePost = await page.$$('[data-testid="announcement-bar-preview-iframe"] > iframe');
|
|
|
|
|
|
|
|
const postiframeHandler = iframesHandlePost[0]; // index 0 since that's the visible iframe
|
|
|
|
const framePost = await postiframeHandler.contentFrame();
|
|
|
|
|
|
|
|
const textExistsInSecondIframe = await framePost?.$eval('body', (body, textToSearch) => {
|
|
|
|
return body.innerText.includes(textToSearch);
|
|
|
|
}, 'post preview');
|
|
|
|
|
|
|
|
expect(textExistsInSecondIframe).toBeTruthy();
|
2023-09-06 03:53:33 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
// TODO - lexical isn't loading in the preview
|
|
|
|
// test('Editing announcement bar text content', async ({page}) => {
|
|
|
|
// await mockApi({page, requests: {
|
|
|
|
// ...globalDataRequests,
|
|
|
|
// editSettings: {method: 'PUT', path: '/settings/', response: responseFixtures.settings}
|
|
|
|
// }});
|
|
|
|
|
|
|
|
// await mockSitePreview({
|
|
|
|
// page,
|
|
|
|
// url: responseFixtures.site.site.url,
|
|
|
|
// response: '<html><head><style></style></head><body><div>homepage preview</div></body></html>'
|
|
|
|
// });
|
|
|
|
|
|
|
|
// await page.goto('/');
|
|
|
|
|
|
|
|
// const section = page.getByTestId('announcement-bar');
|
2023-09-07 01:38:20 -05:00
|
|
|
|
2023-09-06 03:53:33 -05:00
|
|
|
// await section.getByRole('button', {name: 'Customize'}).click();
|
2023-09-07 01:38:20 -05:00
|
|
|
|
2023-09-06 03:53:33 -05:00
|
|
|
// const modal = page.getByTestId('announcement-bar-modal');
|
|
|
|
|
|
|
|
// await expect(modal.frameLocator('[data-testid="announcement-bar-preview"]').getByText('homepage preview')).toHaveCount(1);
|
|
|
|
// });
|
|
|
|
|
|
|
|
test('Can toggle colours', async ({page}) => {
|
|
|
|
const {lastApiRequests} = await mockApi({page, requests: {
|
|
|
|
...globalDataRequests,
|
|
|
|
editSettings: {method: 'PUT', path: '/settings/', response: responseFixtures.settings}
|
|
|
|
}});
|
|
|
|
|
|
|
|
// find label background color
|
|
|
|
|
|
|
|
await page.goto('/');
|
|
|
|
|
|
|
|
const section = page.getByTestId('announcement-bar');
|
|
|
|
|
|
|
|
await section.getByRole('button', {name: 'Customize'}).click();
|
|
|
|
|
2023-09-07 01:38:20 -05:00
|
|
|
const labelElement = page.locator('label:text("Background color")');
|
2023-09-06 03:53:33 -05:00
|
|
|
|
2023-09-07 01:38:20 -05:00
|
|
|
await expect(labelElement).toHaveCount(1);
|
2023-09-06 03:53:33 -05:00
|
|
|
|
|
|
|
const modal = page.getByTestId('announcement-bar-modal');
|
|
|
|
|
|
|
|
// Check the titles of the buttons.
|
|
|
|
// Get the parent div of the label
|
2023-09-07 01:38:20 -05:00
|
|
|
const parentDiv = labelElement.locator('..');
|
2023-09-06 03:53:33 -05:00
|
|
|
|
|
|
|
// Then get the div that follows the label within the parent div
|
2023-09-07 01:38:20 -05:00
|
|
|
const buttonContainer = parentDiv.locator('div');
|
2023-09-06 03:53:33 -05:00
|
|
|
|
2023-09-07 01:38:20 -05:00
|
|
|
const darkButton = buttonContainer.locator('button[title="Dark"]');
|
|
|
|
const lightButton = buttonContainer.locator('button[title="Light"]');
|
|
|
|
const accentButton = buttonContainer.locator('button[title="Accent"]');
|
2023-09-06 03:53:33 -05:00
|
|
|
|
2023-09-07 01:38:20 -05:00
|
|
|
await expect(darkButton).toHaveCount(1);
|
|
|
|
await expect(lightButton).toHaveCount(1);
|
|
|
|
await expect(accentButton).toHaveCount(1);
|
2023-09-06 03:53:33 -05:00
|
|
|
|
|
|
|
await lightButton?.click();
|
|
|
|
|
|
|
|
await modal.getByRole('button', {name: 'Save'}).click();
|
|
|
|
|
|
|
|
expect(lastApiRequests.editSettings?.body).toEqual({
|
|
|
|
settings: [
|
|
|
|
{key: 'announcement_background', value: 'light'}
|
|
|
|
]
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
test('Can toggle visibility', async ({page}) => {
|
|
|
|
const {lastApiRequests} = await mockApi({page, requests: {
|
|
|
|
...globalDataRequests,
|
|
|
|
editSettings: {method: 'PUT', path: '/settings/', response: responseFixtures.settings}
|
|
|
|
}});
|
|
|
|
|
|
|
|
// find label background color
|
|
|
|
|
|
|
|
await page.goto('/');
|
|
|
|
|
|
|
|
const section = page.getByTestId('announcement-bar');
|
|
|
|
|
|
|
|
await section.getByRole('button', {name: 'Customize'}).click();
|
|
|
|
|
2023-09-07 01:38:20 -05:00
|
|
|
const labelElement = page.locator('h6:text("Visibility")');
|
2023-09-06 03:53:33 -05:00
|
|
|
|
2023-09-07 01:38:20 -05:00
|
|
|
await expect(labelElement).toHaveCount(1);
|
2023-09-06 03:53:33 -05:00
|
|
|
|
|
|
|
const modal = page.getByTestId('announcement-bar-modal');
|
|
|
|
|
|
|
|
// get checkbox input with value of free_members
|
|
|
|
|
|
|
|
const checkbox = await page.$('input[value="free_members"]');
|
|
|
|
|
|
|
|
expect(checkbox).not.toBeNull();
|
|
|
|
|
|
|
|
await checkbox?.check();
|
|
|
|
|
|
|
|
await modal.getByRole('button', {name: 'Save'}).click();
|
|
|
|
|
|
|
|
// Note - the value is a stringified array
|
|
|
|
expect(lastApiRequests.editSettings?.body).toEqual({
|
|
|
|
settings: [
|
|
|
|
{key: 'announcement_visibility', value: '["free_members"]'}
|
|
|
|
]
|
|
|
|
});
|
|
|
|
});
|
2023-09-07 01:38:20 -05:00
|
|
|
});
|