test : changed test format + added playwright support
Check Deno code / Check Deno code (pull_request) Has been cancelled
Tests / Unit tests (pull_request) Has been cancelled
Tests / Integration tests (pull_request) Has been cancelled
Check Deno code / Check Deno code (push) Has been cancelled
Tests / Unit tests (push) Has been cancelled
Tests / Integration tests (push) Has been cancelled
Check Deno code / Check Deno code (pull_request) Has been cancelled
Tests / Unit tests (pull_request) Has been cancelled
Tests / Integration tests (pull_request) Has been cancelled
Check Deno code / Check Deno code (push) Has been cancelled
Tests / Unit tests (push) Has been cancelled
Tests / Integration tests (push) Has been cancelled
This commit was merged in pull request #153.
This commit is contained in:
+126
-38
@@ -1,89 +1,177 @@
|
||||
// Integration tests for /ues — Drizzle ORM direct on real DB
|
||||
// E2E tests for /ues endpoints — handler + real DB
|
||||
|
||||
import { assertEquals, assertExists, assertRejects } from "@std/assert";
|
||||
import { seedUes, testDb, truncateAll } from "../helpers/db_integration.ts";
|
||||
import { ues } from "$root/databases/schema.ts";
|
||||
import { eq } from "npm:drizzle-orm@0.45.2";
|
||||
import { assertEquals, assertExists } from "@std/assert";
|
||||
import {
|
||||
makeEmployeeContext,
|
||||
makeGetRequest,
|
||||
makeJsonRequest,
|
||||
} from "../helpers/handler.ts";
|
||||
import { seedUes, truncateAll } from "../helpers/db_integration.ts";
|
||||
import { handler as uesHandler } from "$apps/admin/api/ues.ts";
|
||||
import { handler as ueHandler } from "$apps/admin/api/ues/[idUE].ts";
|
||||
|
||||
// --- GET /ues ---
|
||||
|
||||
Deno.test({
|
||||
name: "integration ues: list all UEs",
|
||||
name: "e2e ues: GET /ues returns all UEs",
|
||||
async fn() {
|
||||
await truncateAll();
|
||||
await seedUes([{ nom: "UE Informatique" }, { nom: "UE Mathématiques" }]);
|
||||
const rows = await testDb.select().from(ues);
|
||||
assertEquals(rows.length, 2);
|
||||
const res = await uesHandler.GET!(
|
||||
makeGetRequest("/ues"),
|
||||
makeEmployeeContext(),
|
||||
);
|
||||
assertEquals(res.status, 200);
|
||||
const body = await res.json();
|
||||
assertEquals(body.length, 2);
|
||||
},
|
||||
sanitizeResources: false,
|
||||
sanitizeOps: false,
|
||||
});
|
||||
|
||||
Deno.test({
|
||||
name: "integration ues: create and retrieve by id",
|
||||
name: "e2e ues: GET /ues returns empty when no UEs",
|
||||
async fn() {
|
||||
await truncateAll();
|
||||
const [created] = await testDb.insert(ues).values({ nom: "UE Physique" })
|
||||
.returning();
|
||||
assertExists(created);
|
||||
assertExists(created.id);
|
||||
assertEquals(created.nom, "UE Physique");
|
||||
|
||||
const row = await testDb.select().from(ues).where(eq(ues.id, created.id))
|
||||
.then((r) => r[0] ?? null);
|
||||
assertExists(row);
|
||||
assertEquals(row.nom, "UE Physique");
|
||||
const res = await uesHandler.GET!(
|
||||
makeGetRequest("/ues"),
|
||||
makeEmployeeContext(),
|
||||
);
|
||||
assertEquals(res.status, 200);
|
||||
const body = await res.json();
|
||||
assertEquals(body.length, 0);
|
||||
},
|
||||
sanitizeResources: false,
|
||||
sanitizeOps: false,
|
||||
});
|
||||
|
||||
// --- POST /ues ---
|
||||
|
||||
Deno.test({
|
||||
name: "integration ues: get by id returns null when not found",
|
||||
name: "e2e ues: POST /ues creates UE (201)",
|
||||
async fn() {
|
||||
await truncateAll();
|
||||
const row = await testDb.select().from(ues).where(eq(ues.id, 99999)).then((
|
||||
r,
|
||||
) => r[0] ?? null);
|
||||
assertEquals(row, null);
|
||||
const res = await uesHandler.POST!(
|
||||
makeJsonRequest("/ues", "POST", { nom: "UE Physique" }),
|
||||
makeEmployeeContext(),
|
||||
);
|
||||
assertEquals(res.status, 201);
|
||||
const body = await res.json();
|
||||
assertExists(body.id);
|
||||
assertEquals(body.nom, "UE Physique");
|
||||
},
|
||||
sanitizeResources: false,
|
||||
sanitizeOps: false,
|
||||
});
|
||||
|
||||
Deno.test({
|
||||
name: "integration ues: update nom",
|
||||
name: "e2e ues: POST /ues 400 on missing nom",
|
||||
async fn() {
|
||||
await truncateAll();
|
||||
const res = await uesHandler.POST!(
|
||||
makeJsonRequest("/ues", "POST", {}),
|
||||
makeEmployeeContext(),
|
||||
);
|
||||
assertEquals(res.status, 400);
|
||||
},
|
||||
sanitizeResources: false,
|
||||
sanitizeOps: false,
|
||||
});
|
||||
|
||||
// --- GET /ues/:id ---
|
||||
|
||||
Deno.test({
|
||||
name: "e2e ues: GET /ues/:id returns UE",
|
||||
async fn() {
|
||||
await truncateAll();
|
||||
const [ue] = await seedUes([{ nom: "UE Chimie" }]);
|
||||
const [updated] = await testDb.update(ues).set({
|
||||
nom: "UE Chimie organique",
|
||||
}).where(eq(ues.id, ue.id)).returning();
|
||||
assertEquals(updated.nom, "UE Chimie organique");
|
||||
const res = await ueHandler.GET!(
|
||||
makeGetRequest(`/ues/${ue.id}`),
|
||||
makeEmployeeContext({ idUE: String(ue.id) }),
|
||||
);
|
||||
assertEquals(res.status, 200);
|
||||
const body = await res.json();
|
||||
assertEquals(body.nom, "UE Chimie");
|
||||
},
|
||||
sanitizeResources: false,
|
||||
sanitizeOps: false,
|
||||
});
|
||||
|
||||
Deno.test({
|
||||
name: "integration ues: delete removes the UE",
|
||||
name: "e2e ues: GET /ues/:id 404 when not found",
|
||||
async fn() {
|
||||
await truncateAll();
|
||||
const res = await ueHandler.GET!(
|
||||
makeGetRequest("/ues/99999"),
|
||||
makeEmployeeContext({ idUE: "99999" }),
|
||||
);
|
||||
assertEquals(res.status, 404);
|
||||
},
|
||||
sanitizeResources: false,
|
||||
sanitizeOps: false,
|
||||
});
|
||||
|
||||
// --- PUT /ues/:id ---
|
||||
|
||||
Deno.test({
|
||||
name: "e2e ues: PUT /ues/:id updates nom",
|
||||
async fn() {
|
||||
await truncateAll();
|
||||
const [ue] = await seedUes([{ nom: "UE Biologie" }]);
|
||||
const res = await ueHandler.PUT!(
|
||||
makeJsonRequest(`/ues/${ue.id}`, "PUT", {
|
||||
nom: "UE Biologie moléculaire",
|
||||
}),
|
||||
makeEmployeeContext({ idUE: String(ue.id) }),
|
||||
);
|
||||
assertEquals(res.status, 200);
|
||||
const body = await res.json();
|
||||
assertEquals(body.nom, "UE Biologie moléculaire");
|
||||
},
|
||||
sanitizeResources: false,
|
||||
sanitizeOps: false,
|
||||
});
|
||||
|
||||
Deno.test({
|
||||
name: "e2e ues: PUT /ues/:id 404 when not found",
|
||||
async fn() {
|
||||
await truncateAll();
|
||||
const res = await ueHandler.PUT!(
|
||||
makeJsonRequest("/ues/99999", "PUT", { nom: "X" }),
|
||||
makeEmployeeContext({ idUE: "99999" }),
|
||||
);
|
||||
assertEquals(res.status, 404);
|
||||
},
|
||||
sanitizeResources: false,
|
||||
sanitizeOps: false,
|
||||
});
|
||||
|
||||
// --- DELETE /ues/:id ---
|
||||
|
||||
Deno.test({
|
||||
name: "e2e ues: DELETE /ues/:id returns 204",
|
||||
async fn() {
|
||||
await truncateAll();
|
||||
const [ue] = await seedUes([{ nom: "UE à supprimer" }]);
|
||||
await testDb.delete(ues).where(eq(ues.id, ue.id));
|
||||
const row = await testDb.select().from(ues).where(eq(ues.id, ue.id)).then((
|
||||
r,
|
||||
) => r[0] ?? null);
|
||||
assertEquals(row, null);
|
||||
const res = await ueHandler.DELETE!(
|
||||
makeGetRequest(`/ues/${ue.id}`),
|
||||
makeEmployeeContext({ idUE: String(ue.id) }),
|
||||
);
|
||||
assertEquals(res.status, 204);
|
||||
},
|
||||
sanitizeResources: false,
|
||||
sanitizeOps: false,
|
||||
});
|
||||
|
||||
Deno.test({
|
||||
name: "integration ues: nom is required (not null)",
|
||||
name: "e2e ues: DELETE /ues/:id 404 when not found",
|
||||
async fn() {
|
||||
await truncateAll();
|
||||
// deno-lint-ignore no-explicit-any
|
||||
await assertRejects(() => testDb.insert(ues).values({ nom: null as any }));
|
||||
const res = await ueHandler.DELETE!(
|
||||
makeGetRequest("/ues/99999"),
|
||||
makeEmployeeContext({ idUE: "99999" }),
|
||||
);
|
||||
assertEquals(res.status, 404);
|
||||
},
|
||||
sanitizeResources: false,
|
||||
sanitizeOps: false,
|
||||
|
||||
Reference in New Issue
Block a user