mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-12-20 17:32:15 +03:00
768511c7cc
refs https://github.com/TryGhost/Team/issues/3349 Tidies up the remaining major pieces which were not covered by tests. Extends the existing test patterns, although the API mocks are getting a bit unmanageable.
123 lines
4.6 KiB
TypeScript
123 lines
4.6 KiB
TypeScript
import {expect, test} from '@playwright/test';
|
|
import {mockApi, responseFixtures} from '../../utils/e2e';
|
|
|
|
test.describe('Theme settings', async () => {
|
|
test('Browsing and installing default themes', async ({page}) => {
|
|
const lastApiRequests = await mockApi({page, responses: {
|
|
themes: {
|
|
install: {
|
|
themes: [{
|
|
name: 'headline',
|
|
package: {},
|
|
active: false,
|
|
templates: []
|
|
}]
|
|
}
|
|
}
|
|
}});
|
|
|
|
await page.goto('/');
|
|
|
|
const section = page.getByTestId('theme');
|
|
|
|
await section.getByRole('button', {name: 'Manage themes'}).click();
|
|
|
|
const modal = page.getByTestId('theme-modal');
|
|
|
|
// The default theme is always considered "installed"
|
|
|
|
await modal.getByRole('button', {name: /Casper/}).click();
|
|
|
|
await expect(modal.getByRole('button', {name: 'Installed'})).toBeVisible();
|
|
await expect(modal.getByRole('button', {name: 'Installed'})).toBeDisabled();
|
|
|
|
await expect(page.locator('iframe[title="Theme preview"]')).toHaveAttribute('src', 'https://demo.ghost.io/');
|
|
|
|
await modal.getByRole('button', {name: 'Official themes'}).click();
|
|
|
|
// The "edition" theme is activated in fixtures
|
|
|
|
await modal.getByRole('button', {name: /Edition/}).click();
|
|
|
|
await expect(modal.getByRole('button', {name: 'Activated'})).toBeVisible();
|
|
await expect(modal.getByRole('button', {name: 'Activated'})).toBeDisabled();
|
|
|
|
await expect(page.locator('iframe[title="Theme preview"]')).toHaveAttribute('src', 'https://edition.ghost.io/');
|
|
|
|
await modal.getByRole('button', {name: 'Official themes'}).click();
|
|
|
|
// Try installing another theme
|
|
|
|
await modal.getByRole('button', {name: /Headline/}).click();
|
|
|
|
await modal.getByRole('button', {name: 'Install Headline'}).click();
|
|
|
|
await expect(modal.getByRole('button', {name: 'Installed'})).toBeVisible();
|
|
await expect(modal.getByRole('button', {name: 'Installed'})).toBeDisabled();
|
|
await expect(page.getByTestId('toast')).toHaveText(/Theme installed - headline/);
|
|
|
|
expect(lastApiRequests.themes.install.url).toMatch(/\?source=github&ref=TryGhost%2FHeadline/);
|
|
});
|
|
|
|
test('Managing installed themes', async ({page}) => {
|
|
const lastApiRequests = await mockApi({page, responses: {
|
|
themes: {
|
|
activate: {
|
|
themes: [{
|
|
...responseFixtures.themes.themes.find(theme => theme.name === 'casper')!,
|
|
active: true
|
|
}]
|
|
}
|
|
}
|
|
}});
|
|
|
|
await page.goto('/');
|
|
|
|
const section = page.getByTestId('theme');
|
|
|
|
await section.getByRole('button', {name: 'Manage themes'}).click();
|
|
|
|
const modal = page.getByTestId('theme-modal');
|
|
|
|
await modal.getByRole('tab', {name: 'Installed'}).click();
|
|
|
|
await expect(modal.getByTestId('theme-list-item')).toHaveCount(2);
|
|
|
|
const casper = modal.getByTestId('theme-list-item').filter({hasText: /casper/});
|
|
const edition = modal.getByTestId('theme-list-item').filter({hasText: /edition/});
|
|
|
|
// Activate the inactive theme
|
|
|
|
await expect(casper.getByRole('button', {name: 'Activate'})).toBeVisible();
|
|
await expect(edition).toHaveText(/Active/);
|
|
|
|
await casper.getByRole('button', {name: 'Activate'}).click();
|
|
|
|
await expect(casper).toHaveText(/Active/);
|
|
await expect(edition.getByRole('button', {name: 'Activate'})).toBeVisible();
|
|
|
|
expect(lastApiRequests.themes.activate.url).toMatch(/\/themes\/casper\/activate\//);
|
|
|
|
// Download the active theme
|
|
|
|
await casper.getByRole('button', {name: 'Menu'}).click();
|
|
await casper.getByRole('button', {name: 'Download'}).click();
|
|
|
|
await expect(page.locator('iframe#iframeDownload')).toHaveAttribute('src', /\/api\/admin\/themes\/casper\/download/);
|
|
|
|
await page.locator('[data-testid="menu-overlay"]:visible').click();
|
|
|
|
// Delete the inactive theme
|
|
|
|
await edition.getByRole('button', {name: 'Menu'}).click();
|
|
await edition.getByRole('button', {name: 'Delete'}).click();
|
|
|
|
const confirmation = page.getByTestId('confirmation-modal');
|
|
await confirmation.getByRole('button', {name: 'Delete'}).click();
|
|
|
|
await expect(modal.getByTestId('theme-list-item')).toHaveCount(1);
|
|
|
|
expect(lastApiRequests.themes.delete.url).toMatch(/\/themes\/edition\/$/);
|
|
});
|
|
});
|