The `import/order` rule isn't enough to sort import within a single import group alphabetically. This adds `sort-imports` rule that handles the sorting within groups.
159 lines
5.5 KiB
TypeScript
159 lines
5.5 KiB
TypeScript
import { expect } from '@playwright/test';
|
|
import { v4 as uuidv4 } from 'uuid';
|
|
|
|
import { test } from '../fixtures/customizations';
|
|
import { isHosted } from '../helpers/helpers';
|
|
import { ensureAuthenticated } from '../helpers/login';
|
|
import {
|
|
ibFrame,
|
|
navigateToLandingPage,
|
|
navigateToOptionalSteps,
|
|
} from '../helpers/navHelpers';
|
|
import {
|
|
createBlueprint,
|
|
deleteBlueprint,
|
|
exportBlueprint,
|
|
fillInDetails,
|
|
fillInImageOutputGuest,
|
|
importBlueprint,
|
|
registerLater,
|
|
} from '../helpers/wizardHelpers';
|
|
|
|
test('Create a blueprint with Locale customization', async ({
|
|
page,
|
|
cleanup,
|
|
}) => {
|
|
const blueprintName = 'test-' + uuidv4();
|
|
|
|
// Delete the blueprint after the run fixture
|
|
await cleanup.add(() => deleteBlueprint(page, blueprintName));
|
|
|
|
await ensureAuthenticated(page);
|
|
|
|
// Navigate to IB landing page and get the frame
|
|
await navigateToLandingPage(page);
|
|
const frame = await ibFrame(page);
|
|
|
|
await test.step('Navigate to optional steps in Wizard', async () => {
|
|
await navigateToOptionalSteps(frame);
|
|
await registerLater(frame);
|
|
});
|
|
|
|
await test.step('Select and fill the Locale step', async () => {
|
|
await frame.getByRole('button', { name: 'Locale' }).click();
|
|
await frame.getByPlaceholder('Select a language').fill('fy');
|
|
await frame
|
|
.getByRole('option', { name: 'Western Frisian - Germany (fy_DE.UTF-8)' })
|
|
.click();
|
|
await expect(
|
|
frame.getByRole('button', {
|
|
name: 'Close Western Frisian - Germany (fy_DE.UTF-8)',
|
|
})
|
|
).toBeEnabled();
|
|
await frame
|
|
.getByRole('button', {
|
|
name: 'Close Western Frisian - Germany (fy_DE.UTF-8)',
|
|
})
|
|
.click();
|
|
await expect(
|
|
frame.getByRole('button', {
|
|
name: 'Close Western Frisian - Germany (fy_DE.UTF-8)',
|
|
})
|
|
).toBeHidden();
|
|
await frame.getByPlaceholder('Select a language').fill('fy');
|
|
await frame
|
|
.getByRole('option', { name: 'Western Frisian - Germany (fy_DE.UTF-8)' })
|
|
.click();
|
|
await expect(
|
|
frame.getByRole('button', {
|
|
name: 'Close Western Frisian - Germany (fy_DE.UTF-8)',
|
|
})
|
|
).toBeEnabled();
|
|
await frame.getByPlaceholder('Select a language').fill('aa');
|
|
await frame
|
|
.getByRole('option', { name: 'aa - Djibouti (aa_DJ.UTF-8)' })
|
|
.click();
|
|
await expect(
|
|
frame.getByRole('button', { name: 'Close aa - Djibouti (aa_DJ.UTF-8)' })
|
|
).toBeEnabled();
|
|
await frame.getByPlaceholder('Select a language').fill('aa');
|
|
await expect(
|
|
frame.getByText(
|
|
'aa - Djibouti (aa_DJ.UTF-8)Language already addedaa - Eritrea (aa_ER.UTF-8)aa - Ethiopia (aa_ET.UTF-8)'
|
|
)
|
|
).toBeAttached();
|
|
await frame.getByPlaceholder('Select a language').fill('xxx');
|
|
await expect(frame.getByText('No results found for')).toBeAttached();
|
|
await frame.getByRole('button', { name: 'Menu toggle' }).nth(1).click();
|
|
await frame.getByPlaceholder('Select a keyboard').fill('ami');
|
|
await frame.getByRole('option', { name: 'amiga-de' }).click();
|
|
await frame.getByRole('button', { name: 'Review and finish' }).click();
|
|
});
|
|
|
|
await test.step('Fill the BP details', async () => {
|
|
await fillInDetails(frame, blueprintName);
|
|
});
|
|
|
|
await test.step('Create BP', async () => {
|
|
await createBlueprint(frame, blueprintName);
|
|
});
|
|
|
|
await test.step('Edit BP', async () => {
|
|
await frame.getByRole('button', { name: 'Edit blueprint' }).click();
|
|
await frame.getByLabel('Revisit Locale step').click();
|
|
await expect(
|
|
frame.getByRole('button', {
|
|
name: 'Close Western Frisian - Germany (fy_DE.UTF-8)',
|
|
})
|
|
).toBeEnabled();
|
|
await expect(
|
|
frame.getByRole('button', { name: 'Close aa - Djibouti (aa_DJ.UTF-8)' })
|
|
).toBeEnabled();
|
|
await frame.getByPlaceholder('Select a language').fill('aa');
|
|
await frame
|
|
.getByRole('option', { name: 'aa - Eritrea (aa_ER.UTF-8)' })
|
|
.click();
|
|
await expect(
|
|
frame.getByRole('button', { name: 'Close aa - Eritrea (aa_ER.UTF-8)' })
|
|
).toBeEnabled();
|
|
await frame.getByRole('button', { name: 'Clear input' }).click();
|
|
await frame.getByRole('button', { name: 'Menu toggle' }).nth(1).click();
|
|
await frame.getByRole('option', { name: 'ANSI-dvorak' }).click();
|
|
await frame.getByRole('button', { name: 'Review and finish' }).click();
|
|
await frame
|
|
.getByRole('button', { name: 'Save changes to blueprint' })
|
|
.click();
|
|
});
|
|
|
|
// This is for hosted service only as these features are not available in cockpit plugin
|
|
await test.step('Export BP', async (step) => {
|
|
step.skip(!isHosted(), 'Exporting is not available in the plugin');
|
|
await exportBlueprint(page, blueprintName);
|
|
});
|
|
|
|
await test.step('Import BP', async (step) => {
|
|
step.skip(!isHosted(), 'Importing is not available in the plugin');
|
|
await importBlueprint(page, blueprintName);
|
|
});
|
|
|
|
await test.step('Review imported BP', async (step) => {
|
|
step.skip(!isHosted(), 'Importing is not available in the plugin');
|
|
await fillInImageOutputGuest(page);
|
|
await page.getByRole('button', { name: 'Locale' }).click();
|
|
await expect(
|
|
frame.getByRole('button', {
|
|
name: 'Close Western Frisian - Germany (fy_DE.UTF-8)',
|
|
})
|
|
).toBeEnabled();
|
|
await expect(
|
|
frame.getByRole('button', { name: 'Close aa - Djibouti (aa_DJ.UTF-8)' })
|
|
).toBeEnabled();
|
|
await expect(
|
|
frame.getByRole('button', { name: 'Close aa - Eritrea (aa_ER.UTF-8)' })
|
|
).toBeEnabled();
|
|
await expect(frame.getByPlaceholder('Select a keyboard')).toHaveValue(
|
|
'ANSI-dvorak'
|
|
);
|
|
await page.getByRole('button', { name: 'Cancel' }).click();
|
|
});
|
|
});
|