Initial commit: full-stack Bun + Elysia + React template
Elysia.js API with session-based auth (email/password + Google OAuth), role system (USER/ADMIN/SUPER_ADMIN), Prisma + PostgreSQL, React 19 with Mantine UI, TanStack Router, dark theme, and comprehensive test suite (unit, integration, E2E with Lightpanda). Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
59
tests/e2e/login-page.test.ts
Normal file
59
tests/e2e/login-page.test.ts
Normal file
@@ -0,0 +1,59 @@
|
||||
import { test, expect, describe } from 'bun:test'
|
||||
import { createPage, APP_HOST } from './browser'
|
||||
|
||||
describe('E2E: Login page', () => {
|
||||
test('serves HTML with correct title', async () => {
|
||||
const { page, cleanup } = await createPage()
|
||||
try {
|
||||
await page.goto(APP_HOST + '/login')
|
||||
const title = await page.title()
|
||||
expect(title).toBe('My App')
|
||||
} finally {
|
||||
cleanup()
|
||||
}
|
||||
})
|
||||
|
||||
test('has dark theme set on html element', async () => {
|
||||
const { page, cleanup } = await createPage()
|
||||
try {
|
||||
await page.goto(APP_HOST + '/login')
|
||||
const colorScheme = await page.evaluate('document.documentElement.getAttribute("data-mantine-color-scheme")')
|
||||
expect(colorScheme).toBe('dark')
|
||||
} finally {
|
||||
cleanup()
|
||||
}
|
||||
})
|
||||
|
||||
test('has dark background meta', async () => {
|
||||
const { page, cleanup } = await createPage()
|
||||
try {
|
||||
await page.goto(APP_HOST + '/login')
|
||||
const meta = await page.evaluate('document.querySelector("meta[name=color-scheme]").content')
|
||||
expect(meta).toBe('dark')
|
||||
} finally {
|
||||
cleanup()
|
||||
}
|
||||
})
|
||||
|
||||
test('root element exists for React mount', async () => {
|
||||
const { page, cleanup } = await createPage()
|
||||
try {
|
||||
await page.goto(APP_HOST + '/login')
|
||||
const root = await page.evaluate('document.getElementById("root") !== null')
|
||||
expect(root).toBe(true)
|
||||
} finally {
|
||||
cleanup()
|
||||
}
|
||||
})
|
||||
|
||||
test('splash removed after app load', async () => {
|
||||
const { page, cleanup } = await createPage()
|
||||
try {
|
||||
await page.goto(APP_HOST + '/login')
|
||||
const splashGone = await page.evaluate('document.getElementById("splash") === null')
|
||||
expect(splashGone).toBe(true)
|
||||
} finally {
|
||||
cleanup()
|
||||
}
|
||||
})
|
||||
})
|
||||
Reference in New Issue
Block a user