Files
LocalAI/core/http/react-ui/e2e/settings-backend-logging.spec.js
Richard Palethorpe 8d70855ea6 test: add Go + React UI coverage gates and fill test gaps (#9989)
- Strict monotonic Go coverage gate (make test-coverage-check, 45% baseline)
  run in CI; fixes ginkgo dropping all-but-one coverprofile across multiple
  recursive roots, builds with -tags auth, and folds in the in-process
  tests/e2e suite via --coverpkg.
- React UI e2e coverage (make test-ui-coverage: vite-plugin-istanbul + nyc,
  nix-provided Chromium) plus e2e specs for 6 previously-untested pages, and a
  UI coverage gate (make test-ui-coverage-check) with a small tolerance since
  e2e line coverage jitters ~0.5pp run-to-run.
- pre-commit hook: lint + coverage on Go changes, Playwright e2e + UI coverage
  gate on react-ui changes; install with make install-hooks.
- New Go handler tests (settings, branding), hermetic base64 download test.
- fix(ui): model editor reads vram_display (snake_case), so the VRAM estimate
  renders again; covered by a regression test.

Assisted-by: Claude:claude-opus-4-7

Signed-off-by: Richard Palethorpe <io@richiejp.com>
2026-05-26 22:06:10 +02:00

42 lines
1.6 KiB
JavaScript

import { test, expect } from './coverage-fixtures.js'
test.describe('Settings - Backend Logging', () => {
test.beforeEach(async ({ page }) => {
await page.goto('/app/settings')
// Wait for settings to load
await expect(page.locator('h3', { hasText: 'Tracing' })).toBeVisible({ timeout: 10_000 })
})
test('backend logging toggle is visible in tracing section', async ({ page }) => {
await expect(page.locator('text=Enable Backend Logging')).toBeVisible()
})
test('backend logging toggle can be toggled', async ({ page }) => {
// Find the checkbox associated with backend logging
const section = page.locator('div', { has: page.locator('text=Enable Backend Logging') })
const checkbox = section.locator('input[type="checkbox"]').last()
// Toggle on
const wasChecked = await checkbox.isChecked()
await checkbox.locator('..').click()
if (wasChecked) {
await expect(checkbox).not.toBeChecked()
} else {
await expect(checkbox).toBeChecked()
}
})
test('save shows toast', async ({ page }) => {
// Toggle a setting to enable the Save button (it's disabled when no changes)
const section = page.locator('div', { has: page.locator('text=Enable Backend Logging') })
const checkbox = section.locator('input[type="checkbox"]').last()
await checkbox.locator('..').click()
// Click save button
await page.locator('button', { hasText: /Save Changes/ }).click()
// Verify toast appears
await expect(page.locator('text=Settings saved successfully')).toBeVisible({ timeout: 5_000 })
})
})