154 lines
4.7 KiB
TypeScript
154 lines
4.7 KiB
TypeScript
import { describe, it, expect, beforeEach, afterEach } from 'vitest';
|
||
import type { StepHarness } from '../support/StepHarness';
|
||
import { createStepHarness } from '../support/StepHarness';
|
||
|
||
describe('Step 9 – add car', () => {
|
||
let harness: StepHarness;
|
||
|
||
beforeEach(async () => {
|
||
harness = await createStepHarness();
|
||
});
|
||
|
||
afterEach(async () => {
|
||
await harness.dispose();
|
||
});
|
||
|
||
describe('happy path', () => {
|
||
it('adds a real car using the JSON-backed car list on Cars page', async () => {
|
||
await harness.navigateToFixtureStep(8);
|
||
await harness.adapter.getPage()?.waitForLoadState('domcontentloaded');
|
||
|
||
const page = harness.adapter.getPage();
|
||
expect(page).not.toBeNull();
|
||
|
||
const result = await harness.executeStep(9, {
|
||
carSearch: 'Acura ARX-06',
|
||
});
|
||
|
||
expect(result.success).toBe(true);
|
||
expect(result.error).toBeUndefined();
|
||
|
||
const carsTable = page!
|
||
.locator('#select-car-set-cars table.table.table-striped')
|
||
.first();
|
||
|
||
expect(await carsTable.count()).toBeGreaterThan(0);
|
||
|
||
const acuraCell = carsTable.locator('tbody tr td >> text=Acura ARX-06 GTP');
|
||
expect(await acuraCell.count()).toBeGreaterThan(0);
|
||
});
|
||
});
|
||
|
||
describe('state validation', () => {
|
||
it('throws when executed on Track page instead of Cars page', async () => {
|
||
await harness.navigateToFixtureStep(11);
|
||
await harness.adapter.getPage()?.waitForLoadState('domcontentloaded');
|
||
|
||
await expect(async () => {
|
||
await harness.executeStep(9, {
|
||
carSearch: 'Mazda MX-5',
|
||
});
|
||
}).rejects.toThrow(/Step 9 FAILED validation/i);
|
||
});
|
||
|
||
it('detects state mismatch when Cars button is missing', async () => {
|
||
await harness.navigateToFixtureStep(11);
|
||
await harness.adapter.getPage()?.waitForLoadState('domcontentloaded');
|
||
|
||
await expect(async () => {
|
||
await harness.executeStep(9, {
|
||
carSearch: 'Porsche 911',
|
||
});
|
||
}).rejects.toThrow(/Step 9 FAILED validation/i);
|
||
});
|
||
|
||
it('detects when Track container is present instead of Cars page', async () => {
|
||
await harness.navigateToFixtureStep(11);
|
||
await harness.adapter.getPage()?.waitForLoadState('domcontentloaded');
|
||
|
||
await expect(async () => {
|
||
await harness.executeStep(9, {
|
||
carSearch: 'Ferrari 488',
|
||
});
|
||
}).rejects.toThrow(/Step 9 FAILED validation/i);
|
||
});
|
||
|
||
it('passes validation when on Cars page', async () => {
|
||
await harness.navigateToFixtureStep(8);
|
||
await harness.adapter.getPage()?.waitForLoadState('domcontentloaded');
|
||
|
||
const result = await harness.executeStep(9, {
|
||
carSearch: 'Acura ARX-06',
|
||
});
|
||
|
||
expect(result.success).toBe(true);
|
||
|
||
const page = harness.adapter.getPage();
|
||
expect(page).not.toBeNull();
|
||
|
||
const carsTable = page!
|
||
.locator('#select-car-set-cars table.table.table-striped')
|
||
.first();
|
||
|
||
expect(await carsTable.count()).toBeGreaterThan(0);
|
||
|
||
const acuraCell = carsTable.locator('tbody tr td >> text=Acura ARX-06 GTP');
|
||
expect(await acuraCell.count()).toBeGreaterThan(0);
|
||
});
|
||
|
||
it('provides detailed error context in validation failure', async () => {
|
||
await harness.navigateToFixtureStep(11);
|
||
await harness.adapter.getPage()?.waitForLoadState('domcontentloaded');
|
||
|
||
let errorMessage = '';
|
||
try {
|
||
await harness.executeStep(9, {
|
||
carSearch: 'BMW M4',
|
||
});
|
||
} catch (error) {
|
||
errorMessage = error instanceof Error ? error.message : String(error);
|
||
}
|
||
|
||
expect(errorMessage).toContain('Step 9');
|
||
expect(errorMessage).toMatch(/validation|mismatch|wrong page/i);
|
||
});
|
||
|
||
it('validates page state before attempting any Step 9 actions', async () => {
|
||
await harness.navigateToFixtureStep(11);
|
||
await harness.adapter.getPage()?.waitForLoadState('domcontentloaded');
|
||
|
||
const page = harness.adapter.getPage();
|
||
if (!page) {
|
||
throw new Error('Page not available');
|
||
}
|
||
|
||
let carModalOpened = false;
|
||
page.on('framenavigated', () => {
|
||
carModalOpened = true;
|
||
});
|
||
|
||
let validationError = false;
|
||
try {
|
||
await harness.executeStep(9, {
|
||
carSearch: 'Audi R8',
|
||
});
|
||
} catch {
|
||
validationError = true;
|
||
}
|
||
|
||
expect(validationError).toBe(true);
|
||
expect(carModalOpened).toBe(false);
|
||
});
|
||
|
||
it('checks wizard footer state in Step 9', async () => {
|
||
await harness.navigateToFixtureStep(11);
|
||
await harness.adapter.getPage()?.waitForLoadState('domcontentloaded');
|
||
|
||
await expect(async () => {
|
||
await harness.executeStep(9, {
|
||
carSearch: 'McLaren 720S',
|
||
});
|
||
}).rejects.toThrow();
|
||
});
|
||
});
|
||
}); |