import { test, expect } from '@playwright/test'; import { LoginPage } from './pages/LoginPage'; import { DashboardPage } from './pages/DashboardPage'; test.describe('Event Summary Page', () => { // Define test variables const testTrainerUsername = 'test_trainer'; const testTrainerPassword = 'Test123!'; // We'll need to figure out a test event ID during the test let testEventId: string; test.beforeEach(async ({ page }) => { // Log in before each test const loginPage = new LoginPage(page); await loginPage.navigate(); await loginPage.login(testTrainerUsername, testTrainerPassword); // Navigate to dashboard to find an event to use for testing const dashboardPage = new DashboardPage(page); await dashboardPage.navigate(); // Find the first event in the dashboard and get its ID // We'll extract the event ID from the "Summary" link's href const summaryLink = page.locator('.column-actions a:has-text("Summary")').first(); // Check if there's at least one event const linkCount = await summaryLink.count(); if (linkCount === 0) { // No events available for testing, we'll need to skip the tests test.skip(true, 'No events available for testing'); return; } // Get the href attribute from the summary link const summaryUrl = await summaryLink.getAttribute('href'); // Extract the event ID from the URL if (summaryUrl) { const match = summaryUrl.match(/event_id=(\d+)/); if (match && match[1]) { testEventId = match[1]; } else { test.skip(true, 'Could not extract event ID from summary link'); } } else { test.skip(true, 'Summary link has no href attribute'); } }); test('should be accessible from dashboard', async ({ page }) => { // Navigate to dashboard const dashboardPage = new DashboardPage(page); await dashboardPage.navigate(); // Find and click the first summary link const summaryLink = page.locator('.column-actions a:has-text("Summary")').first(); await expect(summaryLink).toBeVisible(); await summaryLink.click(); // Verify we're on the event summary page await expect(page).toHaveURL(/.*\/event-summary\/.*event_id=.*/); await expect(page.locator('h1')).toContainText('Summary'); }); test('should display event overview information', async ({ page }) => { // Navigate directly to the event summary page await page.goto(`/event-summary/?event_id=${testEventId}`); // Check for event overview section await expect(page.locator('h2:has-text("Event Overview")')).toBeVisible(); // Check for basic event details const detailsTable = page.locator('.hvac-details-table'); await expect(detailsTable).toBeVisible(); // Check for specific fields const dateRow = detailsTable.locator('tr', { hasText: 'Date & Time' }); const statusRow = detailsTable.locator('tr', { hasText: 'Status' }); await expect(dateRow).toBeVisible(); await expect(statusRow).toBeVisible(); }); test('should display event statistics', async ({ page }) => { // Navigate directly to the event summary page await page.goto(`/event-summary/?event_id=${testEventId}`); // Check for statistics section await expect(page.locator('h2:has-text("Event Statistics")')).toBeVisible(); // Check for statistics cards const statsRow = page.locator('.hvac-stats-row'); await expect(statsRow).toBeVisible(); // Look for specific metric cards const totalTicketsCard = page.locator('.hvac-stat-card h3:has-text("Total Tickets")'); const totalRevenueCard = page.locator('.hvac-stat-card h3:has-text("Total Revenue")'); await expect(totalTicketsCard).toBeVisible(); await expect(totalRevenueCard).toBeVisible(); }); test('should display ticket sales and attendees information', async ({ page }) => { // Navigate directly to the event summary page await page.goto(`/event-summary/?event_id=${testEventId}`); // Check for ticket sales section await expect(page.locator('h2:has-text("Ticket Sales & Attendees")')).toBeVisible(); // The table might not be visible if there are no attendees, so check for either // the table or the "No ticket sales" message const attendeesTable = page.locator('.hvac-transactions-table'); const noAttendeesMessage = page.locator('text=No ticket sales or attendees found'); const hasTable = await attendeesTable.count() > 0; if (hasTable) { // Check table headers const attendeeHeader = attendeesTable.locator('th', { hasText: 'Attendee' }); const emailHeader = attendeesTable.locator('th', { hasText: 'Email' }); const ticketTypeHeader = attendeesTable.locator('th', { hasText: 'Ticket Type' }); await expect(attendeeHeader).toBeVisible(); await expect(emailHeader).toBeVisible(); await expect(ticketTypeHeader).toBeVisible(); } else { // Check for no attendees message await expect(noAttendeesMessage).toBeVisible(); } }); test('should display event description', async ({ page }) => { // Navigate directly to the event summary page await page.goto(`/event-summary/?event_id=${testEventId}`); // Check for event description section await expect(page.locator('h2:has-text("Event Description")')).toBeVisible(); // Check for description content const descriptionContainer = page.locator('.hvac-event-description'); await expect(descriptionContainer).toBeVisible(); }); test('should have working navigation links', async ({ page }) => { // Navigate directly to the event summary page await page.goto(`/event-summary/?event_id=${testEventId}`); // Check for dashboard navigation link const dashboardLink = page.locator('a[href*="/hvac-dashboard/"]'); await expect(dashboardLink).toBeVisible(); // Check for edit event link (may not be visible if user doesn't have permission) const editEventLink = page.locator('a[href*="/manage-event/"]'); // Check for view public page link const viewPublicLink = page.locator('a[href*="/event/"]'); await expect(viewPublicLink).toBeVisible(); }); test('should redirect to login page when not logged in', async ({ page }) => { // Log out first await page.goto('/wp-login.php?action=logout'); await page.waitForURL(/.*\/community-login.*/); // Try to access event summary page directly await page.goto(`/event-summary/?event_id=${testEventId}`); // Should redirect to login page await expect(page).toHaveURL(/.*\/community-login.*/); }); });