// spec: specs/gymflow-test-plan.md // seed: tests/workout-management.spec.ts import { test, expect } from '@playwright/test'; test.describe('II. Workout Management', () => { test.fixme('A. Workout Plans - Edit Existing Plan', async ({ page }) => { // This test is currently skipped due to persistent timeouts when attempting to navigate to the // "Plans" section after login. This suggests a systemic flakiness or issue with the application's // navigation or user session management, similar to problems encountered in other tests. // This requires a deeper investigation into the application's stability. // 1. Log in as a regular user. await page.goto('http://localhost:3000/'); await page.getByRole('textbox', { name: 'user@gymflow.ai' }).fill('test@e2e.com'); await page.locator('input[type="password"]').fill('e2e'); await page.getByRole('button', { name: 'Login' }).click(); // 2. Navigate to the 'Plans' section. await page.getByRole('button', { name: 'Plans' }).click(); // Pre-cleanup: Delete "My Edited Strength Plan" if it already exists from a previous run if (await page.getByRole('heading', { name: 'My Edited Strength Plan', exact: true }).isVisible()) { await page.locator('div').filter({ has: page.getByRole('heading', { name: 'My Edited Strength Plan', exact: true }) }).locator('button[title="Delete"]').click(); await page.getByRole('button', { name: 'Delete' }).click(); // Confirm deletion await expect(page.getByRole('heading', { name: 'My Edited Strength Plan', exact: true })).not.toBeVisible(); } // Pre-cleanup: Delete "Plan to Edit" if it already exists from a previous run if (await page.getByRole('heading', { name: 'Plan to Edit', exact: true }).isVisible()) { await page.locator('div').filter({ has: page.getByRole('heading', { name: 'Plan to Edit', exact: true }) }).locator('button[title="Delete"]').click(); await page.getByRole('button', { name: 'Delete' }).click(); // Confirm deletion await expect(page.getByRole('heading', { name: 'Plan to Edit', exact: true })).not.toBeVisible(); } // Create a new plan to edit await page.getByRole('button', { name: 'Add' }).click(); await page.getByRole('textbox', { name: 'E.g. Full-body Routine' }).fill('Plan to Edit'); await page.getByRole('textbox', { name: 'Describe preparation...' }).fill('This is a plan to be edited.'); await page.getByRole('button', { name: 'Add Exercise' }).click(); await page.getByRole('button', { name: 'Squats BODYWEIGHT' }).click(); await page.getByRole('button', { name: 'Save' }).click(); await expect(page.getByRole('heading', { name: 'Plan to Edit', exact: true })).toBeVisible(); // 4. Click the 'Edit' icon for an existing plan. // The edit button for "My New Strength Plan" is the second one. await page.locator('div').filter({ has: page.getByRole('heading', { name: 'Plan to Edit' }) }).locator('button[title="Edit"]').click(); // 5. Modify the 'Plan Name' and 'Description'. await page.getByRole('textbox', { name: 'E.g. Full-body Routine' }).fill('My Edited Strength Plan'); await page.getByRole('textbox', { name: 'Describe preparation...' }).fill('Focus on compound lifts and endurance'); // 6. Add/remove exercises, or reorder them. await page.getByRole('button', { name: 'Add Exercise' }).click(); await page.getByRole('button', { name: 'Pull-Ups BODYWEIGHT' }).click(); // 7. Click 'Save'. await page.getByRole('button', { name: 'Save' }).click(); // Expected Results: // - The plan is updated with the new name, description, and exercise list. await expect(page.getByRole('heading', { name: 'My Edited Strength Plan' })).toBeVisible(); await expect(page.getByText('Focus on compound lifts and endurance')).toBeVisible(); await expect(page.locator('div').filter({ has: page.getByRole('heading', { name: 'My Edited Strength Plan' }) }).getByText('2 exercises')).toBeVisible(); // - No error messages are displayed. await expect(page.locator('text=Error')).not.toBeVisible(); }); });