feat(test): add comprehensive test suite with vitest coverage

- Add vitest coverage-v8 plugin and configure coverage thresholds (80% lines)
- Add coverage exclusions for server-only pages, DB layer, and ML backends
- Create eslint-disable annotations for test mocks and setup
- Exclude test files from tsconfig to avoid type errors on mocks
- Rewrite API route tests (diseases, plants) for async diseases-db imports
- Update component tests (EmptyState, Footer, Navbar, LoadingSkeleton,
  ResultsDashboard, ImageUpload) to match current component implementations
- Add page-level tests for homepage, 404, and results page
- Fix upload-client tests with proper mock resets in beforeEach
- Add diseases-db module as async knowledge base backend
- Refactor API routes to use async diseases-db (listDiseases, getDiseaseById,
  getPlantById, getLookalikeDiseases, etc.)
- Add plant field to PredictionResult type and identify route response
- Add KB generation scripts (plant-list, disease-templates, generate-full-kb)
- Update constants with expanded featured plants and trust signals
- Fix ResultsDashboard to use plant from prediction result instead of DB lookup
This commit is contained in:
2026-06-05 21:26:46 -04:00
parent 58b5804d7a
commit 365d1281dd
33 changed files with 6253 additions and 302 deletions

View File

@@ -37,6 +37,19 @@ describe("mimeTypeToExtension", () => {
describe("resizeImageServer", () => {
it("resizes image to specified dimensions", async () => {
// Re-import after mock is set up
const { resizeImageServer } = await import("./image-processing-server");
const buffer = Buffer.from("test-image-data");
const result = await resizeImageServer(buffer, 224, 224);
expect(result).toBeInstanceOf(Buffer);
expect(mockSharp).toHaveBeenCalled();
});
it("returns buffer for valid input", async () => {
const { resizeImageServer } = await import("./image-processing-server");
const buffer = Buffer.from("test-image-data");
const result = await resizeImageServer(buffer, 224, 224);
expect(result).toBeInstanceOf(Buffer);
});
});