mirror of
https://github.com/actualbudget/actual.git
synced 2026-03-21 15:36:50 -05:00
* Dummy commit * Delete js snapshots * Move extended expect and test to fixtures * Fix wrong commit * Update VRT * Dummy commit to run GH actions * Convert test page models to TS * Release notes * Fix typecheck errors * New page models to TS * Fix typecheck error * Fix page name * Put awaits on getTableTotals --------- Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
169 lines
5.8 KiB
TypeScript
169 lines
5.8 KiB
TypeScript
import { type Page } from '@playwright/test';
|
|
|
|
import { expect, test } from './fixtures';
|
|
import { type AccountPage } from './page-models/account-page';
|
|
import { ConfigurationPage } from './page-models/configuration-page';
|
|
import { Navigation } from './page-models/navigation';
|
|
|
|
test.describe('Transactions', () => {
|
|
let page: Page;
|
|
let navigation: Navigation;
|
|
let accountPage: AccountPage;
|
|
let configurationPage: ConfigurationPage;
|
|
|
|
test.beforeAll(async ({ browser }) => {
|
|
page = await browser.newPage();
|
|
navigation = new Navigation(page);
|
|
configurationPage = new ConfigurationPage(page);
|
|
|
|
await page.goto('/');
|
|
await configurationPage.createTestFile();
|
|
});
|
|
|
|
test.afterAll(async () => {
|
|
await page.close();
|
|
});
|
|
|
|
test.beforeEach(async () => {
|
|
accountPage = await navigation.goToAccountPage('Ally Savings');
|
|
});
|
|
|
|
test('checks the page visuals', async () => {
|
|
await expect(page).toMatchThemeScreenshots();
|
|
});
|
|
|
|
test.describe('filters transactions', () => {
|
|
// Reset filters
|
|
test.afterEach(async () => {
|
|
await accountPage.removeFilter(0);
|
|
});
|
|
|
|
test('by date', async () => {
|
|
const filterTooltip = await accountPage.filterBy('Date');
|
|
await expect(filterTooltip.locator).toMatchThemeScreenshots();
|
|
|
|
// Open datepicker
|
|
await page.keyboard.press('Space');
|
|
const datepicker = page.getByTestId('date-select-tooltip');
|
|
await expect(datepicker).toMatchThemeScreenshots();
|
|
|
|
// Select "is xxxxx"
|
|
await datepicker.getByText('20', { exact: true }).click();
|
|
await filterTooltip.applyButton.click();
|
|
|
|
// Assert that there are no transactions
|
|
await expect(accountPage.transactionTable).toHaveText('No transactions');
|
|
await expect(page).toMatchThemeScreenshots();
|
|
});
|
|
|
|
test('by category', async () => {
|
|
const filterTooltip = await accountPage.filterBy('Category');
|
|
await expect(filterTooltip.locator).toMatchThemeScreenshots();
|
|
|
|
// Type in the autocomplete box
|
|
const autocomplete = page.getByTestId('autocomplete');
|
|
await expect(autocomplete).toMatchThemeScreenshots();
|
|
|
|
// Select the active item
|
|
await page.getByTestId('Clothing-category-item').click();
|
|
await filterTooltip.applyButton.click();
|
|
|
|
// Assert that there are only clothing transactions
|
|
await expect(accountPage.getNthTransaction(0).category).toHaveText(
|
|
'Clothing',
|
|
);
|
|
await expect(accountPage.getNthTransaction(1).category).toHaveText(
|
|
'Clothing',
|
|
);
|
|
await expect(accountPage.getNthTransaction(2).category).toHaveText(
|
|
'Clothing',
|
|
);
|
|
await expect(accountPage.getNthTransaction(3).category).toHaveText(
|
|
'Clothing',
|
|
);
|
|
await expect(accountPage.getNthTransaction(4).category).toHaveText(
|
|
'Clothing',
|
|
);
|
|
await expect(page).toMatchThemeScreenshots();
|
|
});
|
|
});
|
|
|
|
test('creates a test transaction', async () => {
|
|
await accountPage.createSingleTransaction({
|
|
payee: 'Home Depot',
|
|
notes: 'Notes field',
|
|
category: 'Food',
|
|
debit: '12.34',
|
|
});
|
|
|
|
const transaction = accountPage.getNthTransaction(0);
|
|
await expect(transaction.payee).toHaveText('Home Depot');
|
|
await expect(transaction.notes).toHaveText('Notes field');
|
|
await expect(transaction.category).toHaveText('Food');
|
|
await expect(transaction.debit).toHaveText('12.34');
|
|
await expect(transaction.credit).toHaveText('');
|
|
await expect(page).toMatchThemeScreenshots();
|
|
});
|
|
|
|
test('creates a split test transaction', async () => {
|
|
await accountPage.createSplitTransaction([
|
|
{
|
|
payee: 'Krogger',
|
|
notes: 'Notes',
|
|
debit: '333.33',
|
|
},
|
|
{
|
|
category: 'General',
|
|
debit: '222.22',
|
|
},
|
|
{
|
|
debit: '111.11',
|
|
},
|
|
]);
|
|
|
|
const firstTransaction = accountPage.getNthTransaction(0);
|
|
await expect(firstTransaction.payee).toHaveText('Krogger');
|
|
await expect(firstTransaction.notes).toHaveText('Notes');
|
|
await expect(firstTransaction.category).toHaveText('Split');
|
|
await expect(firstTransaction.debit).toHaveText('333.33');
|
|
await expect(firstTransaction.credit).toHaveText('');
|
|
|
|
const secondTransaction = accountPage.getNthTransaction(1);
|
|
await expect(secondTransaction.payee).toHaveText('Krogger');
|
|
await expect(secondTransaction.notes).toHaveText('');
|
|
await expect(secondTransaction.category).toHaveText('General');
|
|
await expect(secondTransaction.debit).toHaveText('222.22');
|
|
await expect(secondTransaction.credit).toHaveText('');
|
|
|
|
const thirdTransaction = accountPage.getNthTransaction(2);
|
|
await expect(thirdTransaction.payee).toHaveText('Krogger');
|
|
await expect(thirdTransaction.notes).toHaveText('');
|
|
await expect(thirdTransaction.category).toHaveText('Categorize');
|
|
await expect(thirdTransaction.debit).toHaveText('111.11');
|
|
await expect(thirdTransaction.credit).toHaveText('');
|
|
await expect(page).toMatchThemeScreenshots();
|
|
});
|
|
|
|
test('creates a transfer test transaction', async () => {
|
|
await accountPage.enterSingleTransaction({
|
|
payee: 'Bank of America',
|
|
notes: 'Notes field',
|
|
debit: '12.34',
|
|
});
|
|
|
|
let transaction = accountPage.getEnteredTransaction();
|
|
await expect(transaction.category.locator('input')).toHaveValue('Transfer');
|
|
await expect(page).toMatchThemeScreenshots();
|
|
|
|
await accountPage.addEnteredTransaction();
|
|
|
|
transaction = accountPage.getNthTransaction(0);
|
|
await expect(transaction.payee).toHaveText('Bank of America');
|
|
await expect(transaction.notes).toHaveText('Notes field');
|
|
await expect(transaction.category).toHaveText('Transfer');
|
|
await expect(transaction.debit).toHaveText('12.34');
|
|
await expect(transaction.credit).toHaveText('');
|
|
await expect(page).toMatchThemeScreenshots();
|
|
});
|
|
});
|