/** * Feature Backlog E2E Test * * Happy path: Add a feature to the backlog */ import { test, expect } from '@playwright/test'; import * as fs from 'fs'; import * as path from 'path'; import { createTempDirPath, cleanupTempDir, setupRealProject, waitForNetworkIdle, clickAddFeature, fillAddFeatureDialog, confirmAddFeature, } from '../utils'; const TEST_TEMP_DIR = createTempDirPath('feature-backlog-test'); test.describe('Feature Backlog', () => { let projectPath: string; const projectName = `test-project-${Date.now()}`; test.beforeAll(async () => { if (!fs.existsSync(TEST_TEMP_DIR)) { fs.mkdirSync(TEST_TEMP_DIR, { recursive: true }); } projectPath = path.join(TEST_TEMP_DIR, projectName); fs.mkdirSync(projectPath, { recursive: true }); fs.writeFileSync( path.join(projectPath, 'package.json'), JSON.stringify({ name: projectName, version: '1.0.0' }, null, 2) ); const automakerDir = path.join(projectPath, '.automaker'); fs.mkdirSync(automakerDir, { recursive: true }); fs.mkdirSync(path.join(automakerDir, 'features'), { recursive: true }); fs.mkdirSync(path.join(automakerDir, 'context'), { recursive: true }); fs.writeFileSync( path.join(automakerDir, 'categories.json'), JSON.stringify({ categories: [] }, null, 2) ); fs.writeFileSync( path.join(automakerDir, 'app_spec.txt'), `# ${projectName}\n\nA test project for e2e testing.` ); }); test.afterAll(async () => { cleanupTempDir(TEST_TEMP_DIR); }); test('should add a new feature to the backlog', async ({ page }) => { const featureDescription = `Test feature ${Date.now()}`; await setupRealProject(page, projectPath, projectName, { setAsCurrent: true }); await page.goto('/board'); await waitForNetworkIdle(page); await expect(page.locator('[data-testid="board-view"]')).toBeVisible({ timeout: 10000 }); await expect(page.locator('[data-testid="kanban-column-backlog"]')).toBeVisible({ timeout: 5000, }); await clickAddFeature(page); await fillAddFeatureDialog(page, featureDescription); await confirmAddFeature(page); // Wait for the feature to appear in the backlog await expect(async () => { const backlogColumn = page.locator('[data-testid="kanban-column-backlog"]'); const featureCard = backlogColumn.locator('[data-testid^="kanban-card-"]').filter({ hasText: featureDescription, }); expect(await featureCard.count()).toBeGreaterThan(0); }).toPass({ timeout: 10000 }); }); });