mirror of
https://github.com/mudler/LocalAI.git
synced 2026-05-30 19:47:47 -04:00
- 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>
21 lines
810 B
JavaScript
21 lines
810 B
JavaScript
import { test, expect } from './coverage-fixtures.js'
|
|
|
|
// Skills feature page (src/pages/Skills.jsx).
|
|
test.describe('Skills page', () => {
|
|
test.beforeEach(async ({ page }) => {
|
|
await page.goto('/app/skills')
|
|
})
|
|
|
|
test('renders the skills list with create affordances', async ({ page }) => {
|
|
await expect(page).toHaveURL(/\/app\/skills$/)
|
|
await expect(page.getByRole('heading', { name: 'Skills', exact: true })).toBeVisible()
|
|
await expect(page.getByRole('button', { name: 'New skill' })).toBeVisible()
|
|
await expect(page.getByRole('button', { name: 'Git Repos' })).toBeVisible()
|
|
})
|
|
|
|
test('New skill navigates to the skill editor', async ({ page }) => {
|
|
await page.getByRole('button', { name: 'New skill' }).click()
|
|
await expect(page).toHaveURL(/\/app\/skills\/new$/)
|
|
})
|
|
})
|