test(api): cover assistant project admin mutations

This commit is contained in:
2026-04-01 00:18:48 +02:00
parent 83d7dbc29f
commit 083857f19f
7 changed files with 696 additions and 0 deletions
@@ -0,0 +1,111 @@
import { beforeEach, describe, expect, it, vi } from "vitest";
import { PermissionKey, SystemRole } from "@capakraken/shared";
import {
createProject,
createToolContext,
executeTool,
} from "./assistant-tools-project-admin-test-helpers.js";
describe("assistant project admin update tools", () => {
beforeEach(() => {
vi.clearAllMocks();
});
it("routes project updates through the real project router path and resolves short codes before updating", async () => {
const auditCreate = vi.fn().mockResolvedValue({ id: "audit_1" });
const projectFindUnique = vi.fn()
.mockResolvedValueOnce(null)
.mockResolvedValueOnce(createProject())
.mockResolvedValueOnce(createProject({ dynamicFields: {}, blueprintId: null }));
const projectUpdate = vi.fn().mockResolvedValue({
id: "project_1",
shortCode: "PROJ-1",
name: "Project One Reloaded",
});
const ctx = createToolContext(
{
project: {
findUnique: projectFindUnique,
findFirst: vi.fn().mockResolvedValue(null),
update: projectUpdate,
},
assignment: {
findMany: vi.fn().mockResolvedValue([]),
},
resource: {
findFirst: vi.fn().mockResolvedValue({
displayName: "Peter Parker",
}),
findMany: vi.fn().mockResolvedValue([]),
},
auditLog: {
create: auditCreate,
},
},
{
userRole: SystemRole.ADMIN,
permissions: [PermissionKey.MANAGE_PROJECTS],
},
);
const result = await executeTool(
"update_project",
JSON.stringify({
id: "PROJ-1",
name: "Project One Reloaded",
responsiblePerson: "Peter Parker",
}),
ctx,
);
expect(JSON.parse(result.content)).toEqual(expect.objectContaining({
success: true,
message: "Updated project Project One Reloaded (PROJ-1)",
updatedFields: ["name", "responsiblePerson"],
}));
expect(projectUpdate).toHaveBeenCalledWith(expect.objectContaining({
where: { id: "project_1" },
data: expect.objectContaining({
name: "Project One Reloaded",
responsiblePerson: "Peter Parker",
}),
}));
expect(auditCreate).toHaveBeenCalledTimes(1);
});
it("returns a stable assistant error when the project disappears during update", async () => {
const ctx = createToolContext(
{
project: {
findUnique: vi.fn()
.mockResolvedValueOnce(null)
.mockResolvedValueOnce(createProject())
.mockResolvedValueOnce(createProject({ dynamicFields: {}, blueprintId: null })),
findFirst: vi.fn().mockResolvedValue(null),
update: vi.fn().mockRejectedValue({
code: "P2025",
message: "Record to update not found.",
}),
},
assignment: {
findMany: vi.fn().mockResolvedValue([]),
},
},
{
userRole: SystemRole.ADMIN,
permissions: [PermissionKey.MANAGE_PROJECTS],
},
);
const result = await executeTool(
"update_project",
JSON.stringify({ id: "PROJ-1", name: "Project One Reloaded" }),
ctx,
);
expect(JSON.parse(result.content)).toEqual({
error: "Project not found with the given criteria.",
});
});
});