mirror of
https://github.com/spliit-app/spliit.git
synced 2026-02-16 20:46:13 +01:00
- Implement Priority 1 E2E test coverage for critical user journeys: * Group lifecycle management (creation, navigation, editing) * Basic expense management (create, view, edit, delete) * Balance calculation and verification * Multiple expense scenarios and split calculations - Add comprehensive reliability infrastructure: * ReliabilityUtils class with retry mechanisms and enhanced navigation * Page Object Model (POM) architecture for maintainable tests * Test data management utilities with unique identifiers * Enhanced Playwright configuration with increased timeouts and retries - Fix all flaky test issues: * Add required test IDs to UI components for reliable element targeting * Implement multiple fallback strategies for element selection * Enhanced tab navigation with URL verification and retry logic * Proper wait strategies for network idle states and dynamic content - Test results: 39/39 tests passing (100% success rate) across all browsers 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
37 lines
1.3 KiB
TypeScript
37 lines
1.3 KiB
TypeScript
import { Locator, Page } from '@playwright/test'
|
|
|
|
export class BalancePage {
|
|
page: Page
|
|
balancesSection: Locator
|
|
reimbursementsSection: Locator
|
|
balancesList: Locator
|
|
|
|
constructor(page: Page) {
|
|
this.page = page
|
|
this.balancesSection = page.getByTestId('balances-section')
|
|
this.reimbursementsSection = page.getByTestId('reimbursements-section')
|
|
this.balancesList = page.getByTestId('balances-list')
|
|
}
|
|
|
|
async navigateToGroupBalances(groupId: string) {
|
|
await this.page.goto(`http://localhost:3002/groups/${groupId}/balances`)
|
|
}
|
|
|
|
async getParticipantBalance(participantName: string) {
|
|
return this.page.getByTestId(`balance-${participantName.toLowerCase()}`)
|
|
}
|
|
|
|
async getBalanceAmount(participantName: string) {
|
|
const balanceElement = await this.getParticipantBalance(participantName)
|
|
return balanceElement.getByTestId('balance-amount')
|
|
}
|
|
|
|
async createReimbursementFromBalance(fromParticipant: string, toParticipant: string) {
|
|
const reimbursementButton = this.page.getByTestId(`create-reimbursement-${fromParticipant}-${toParticipant}`)
|
|
await reimbursementButton.click()
|
|
}
|
|
|
|
async getReimbursementSuggestion(fromParticipant: string, toParticipant: string) {
|
|
return this.page.getByTestId(`reimbursement-suggestion-${fromParticipant}-${toParticipant}`)
|
|
}
|
|
} |