test: add E2E tests for price history feature
This commit is contained in:
parent
9db43c474e
commit
dd7bec6091
1 changed files with 74 additions and 0 deletions
74
frontend/e2e/price-history.spec.ts
Normal file
74
frontend/e2e/price-history.spec.ts
Normal file
|
|
@ -0,0 +1,74 @@
|
||||||
|
import { test, expect } from "@playwright/test";
|
||||||
|
import { clearAuth, loginUser, REGULAR_USER, ADMIN_USER } from "./helpers/auth";
|
||||||
|
|
||||||
|
test.describe("Price History - E2E", () => {
|
||||||
|
test("admin can view price history page", async ({ page }) => {
|
||||||
|
await clearAuth(page);
|
||||||
|
await loginUser(page, ADMIN_USER.email, ADMIN_USER.password);
|
||||||
|
|
||||||
|
await page.goto("/admin/price-history");
|
||||||
|
await expect(page).toHaveURL("/admin/price-history");
|
||||||
|
|
||||||
|
// Page title should be visible
|
||||||
|
await expect(page.locator("h2")).toContainText("Bitcoin Price History");
|
||||||
|
|
||||||
|
// Table should exist
|
||||||
|
await expect(page.locator("table")).toBeVisible();
|
||||||
|
|
||||||
|
// Fetch Now button should exist
|
||||||
|
await expect(page.getByRole("button", { name: "Fetch Now" })).toBeVisible();
|
||||||
|
});
|
||||||
|
|
||||||
|
test("admin can manually fetch price from Bitfinex", async ({ page }) => {
|
||||||
|
await clearAuth(page);
|
||||||
|
await loginUser(page, ADMIN_USER.email, ADMIN_USER.password);
|
||||||
|
|
||||||
|
await page.goto("/admin/price-history");
|
||||||
|
await expect(page).toHaveURL("/admin/price-history");
|
||||||
|
|
||||||
|
// Click the Fetch Now button
|
||||||
|
await page.getByRole("button", { name: "Fetch Now" }).click();
|
||||||
|
|
||||||
|
// Wait for the button to become enabled again (fetch completed)
|
||||||
|
await expect(page.getByRole("button", { name: "Fetch Now" })).toBeEnabled({
|
||||||
|
timeout: 10000,
|
||||||
|
});
|
||||||
|
|
||||||
|
// The table should now contain a record with bitfinex as source
|
||||||
|
await expect(page.locator("table tbody")).toContainText("bitfinex");
|
||||||
|
|
||||||
|
// Should have BTC/EUR pair
|
||||||
|
await expect(page.locator("table tbody")).toContainText("BTC/EUR");
|
||||||
|
|
||||||
|
// Price should be visible and formatted as EUR
|
||||||
|
// The price cell should contain a € symbol
|
||||||
|
const priceCell = page.locator("table tbody tr td").nth(2);
|
||||||
|
await expect(priceCell).toContainText("€");
|
||||||
|
});
|
||||||
|
|
||||||
|
test("regular user cannot access price history page", async ({ page }) => {
|
||||||
|
await clearAuth(page);
|
||||||
|
await loginUser(page, REGULAR_USER.email, REGULAR_USER.password);
|
||||||
|
|
||||||
|
// Try to navigate directly to the admin page
|
||||||
|
await page.goto("/admin/price-history");
|
||||||
|
|
||||||
|
// Should be redirected away (to "/" since fallbackRedirect is "/")
|
||||||
|
await expect(page).toHaveURL("/");
|
||||||
|
});
|
||||||
|
|
||||||
|
test("price history shows in navigation for admin", async ({ page }) => {
|
||||||
|
await clearAuth(page);
|
||||||
|
await loginUser(page, ADMIN_USER.email, ADMIN_USER.password);
|
||||||
|
|
||||||
|
// Admin should be on audit page by default
|
||||||
|
await expect(page).toHaveURL("/audit");
|
||||||
|
|
||||||
|
// Prices nav link should be visible
|
||||||
|
await expect(page.getByRole("link", { name: "Prices" })).toBeVisible();
|
||||||
|
|
||||||
|
// Click on Prices link
|
||||||
|
await page.getByRole("link", { name: "Prices" }).click();
|
||||||
|
await expect(page).toHaveURL("/admin/price-history");
|
||||||
|
});
|
||||||
|
});
|
||||||
Loading…
Add table
Add a link
Reference in a new issue