.agents/skills/deno-testing/SKILL.md
Deno testing with Deno.test and std/testing. Covers unit tests, async tests, mocking, snapshots, and BDD-style testing. USE WHEN: user mentions "deno test", "deno testing", asks about "Deno.test", "assertSnapshot", "FakeTime", "spy", "stub", "BDD deno" DO NOT USE FOR: Node.js projects - use `vitest` or `jest`; Browser-only code - use Playwright; Python - use `pytest`; Java - use `junit`; Non-Deno TypeScript - use `vitest`
npx skillsauth add d-subrahmanyam/deno-fresh-microservices deno-testingInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Deep Knowledge: Use
mcp__documentation__fetch_docswith technology:denofor comprehensive documentation.
Full Reference: See advanced.md for FakeTime, BDD Style, Snapshots, HTTP Testing, Integration Tests, Test Context, Custom Assertions, and Permissions Testing.
vitest or jest for Node.jspytest for Pythonjunit for Javavitest for standard TypeScript// math.ts
export function add(a: number, b: number): number {
return a + b;
}
export function divide(a: number, b: number): number {
if (b === 0) {
throw new Error("Division by zero");
}
return a / b;
}
// math_test.ts
import { assertEquals, assertThrows } from "https://deno.land/[email protected]/assert/mod.ts";
import { add, divide } from "./math.ts";
Deno.test("add positive numbers", () => {
assertEquals(add(2, 3), 5);
});
Deno.test("divide by zero throws", () => {
assertThrows(
() => divide(10, 0),
Error,
"Division by zero"
);
});
# Run all tests
deno test
# Run specific file
deno test math_test.ts
# Run tests matching pattern
deno test --filter "add"
# Allow permissions
deno test --allow-read --allow-net
# Watch mode
deno test --watch
# Coverage
deno test --coverage=cov_profile
deno coverage cov_profile --html
import {
assertEquals,
assertNotEquals,
assertStrictEquals,
assertExists,
assertInstanceOf,
assertArrayIncludes,
assertStringIncludes,
assertMatch,
assertThrows,
assertRejects,
assert,
} from "https://deno.land/[email protected]/assert/mod.ts";
Deno.test("assertions examples", () => {
assertEquals({ a: 1 }, { a: 1 });
assertNotEquals({ a: 1 }, { a: 2 });
assertStrictEquals(obj, obj); // Reference equality
assertExists("value"); // Not null/undefined
assertInstanceOf(new Date(), Date);
assertArrayIncludes([1, 2, 3], [2, 3]);
assertStringIncludes("hello world", "world");
assertMatch("hello123", /\d+/);
assert(true);
});
Deno.test("error assertions", async () => {
assertThrows(() => { throw new Error("oops"); }, Error, "oops");
await assertRejects(async () => { throw new Error("async error"); }, Error);
});
Deno.test("user workflow", async (t) => {
let userId: string;
await t.step("create user", async () => {
const response = await fetch("http://localhost:8000/users", {
method: "POST",
body: JSON.stringify({ name: "Alice" }),
});
const user = await response.json();
userId = user.id;
assertEquals(user.name, "Alice");
});
await t.step("get user", async () => {
const response = await fetch(`http://localhost:8000/users/${userId}`);
const user = await response.json();
assertEquals(user.id, userId);
});
});
Deno.test({
name: "test with options",
permissions: { read: true, net: true },
fn: async () => {
const data = await Deno.readTextFile("./data.txt");
assertEquals(data.length > 0, true);
},
});
Deno.test({
name: "ignored test",
ignore: Deno.build.os === "windows",
fn: () => { /* Skipped on Windows */ },
});
Deno.test({
name: "test with sanitizers disabled",
sanitizeResources: false,
sanitizeOps: false,
fn: async () => { /* Test that might leak resources */ },
});
Deno.test("async test", async () => {
const result = await asyncOperation();
assertEquals(result, "expected");
});
Deno.test("timeout handling", async () => {
const controller = new AbortController();
const timeout = setTimeout(() => controller.abort(), 5000);
try {
const response = await fetch("http://example.com", {
signal: controller.signal,
});
assertEquals(response.ok, true);
} finally {
clearTimeout(timeout);
}
});
import { spy, assertSpyCalls, assertSpyCall } from "https://deno.land/[email protected]/testing/mock.ts";
Deno.test("spy example", () => {
const func = spy((x: number) => x * 2);
assertEquals(func(2), 4);
assertEquals(func(3), 6);
assertSpyCalls(func, 2);
assertSpyCall(func, 0, { args: [2], returned: 4 });
});
Deno.test("spy on object method", () => {
const obj = {
greet(name: string) { return `Hello, ${name}!`; },
};
const greetSpy = spy(obj, "greet");
assertEquals(obj.greet("Alice"), "Hello, Alice!");
assertSpyCalls(greetSpy, 1);
greetSpy.restore();
});
import { stub, returnsNext } from "https://deno.land/[email protected]/testing/mock.ts";
Deno.test("stub example", () => {
const obj = { getValue: () => Math.random() };
const stubFn = stub(obj, "getValue", () => 42);
assertEquals(obj.getValue(), 42);
assertEquals(obj.getValue(), 42);
stubFn.restore();
});
Deno.test("stub with different returns", () => {
const obj = { getValue: () => 0 };
const stubFn = stub(obj, "getValue", returnsNext([1, 2, 3]));
assertEquals(obj.getValue(), 1);
assertEquals(obj.getValue(), 2);
assertEquals(obj.getValue(), 3);
stubFn.restore();
});
Deno.test("mock fetch", async () => {
const mockResponse = new Response(JSON.stringify({ id: 1, name: "Alice" }), {
status: 200,
headers: { "Content-Type": "application/json" },
});
const fetchStub = stub(
globalThis,
"fetch",
() => Promise.resolve(mockResponse)
);
try {
const response = await fetch("http://api.example.com/users/1");
const user = await response.json();
assertEquals(user.name, "Alice");
} finally {
fetchStub.restore();
}
});
| Anti-Pattern | Why It's Bad | Solution | |--------------|--------------|----------| | Not specifying permissions | Tests fail unexpectedly | Use permissions option in test | | Not restoring stubs/spies | Affects other tests | Always call stub.restore() | | Over-using snapshots | Hard to review changes | Use snapshots sparingly | | Disabled sanitizers without reason | Resource leaks | Only disable when necessary | | Not using test steps | Hard to debug complex flows | Use t.step() for workflows | | Hardcoded waits | Slow, unreliable tests | Use proper async patterns |
| Problem | Likely Cause | Solution | |---------|--------------|----------| | "PermissionDenied" | Missing permission in test | Add permissions: { read: true } etc. | | "Leaking resources" | Unclosed file/connection | Close resources or disable sanitizer | | "Leaking async ops" | Unfinished async operation | Await all promises or disable sanitizer | | Snapshot mismatch | Intentional change | Review diff, update with --update | | Stub not working | Not restored from previous test | Call stub.restore() in cleanup | | Test timeout | Infinite loop or slow operation | Add timeout or investigate |
development
Guidelines for building high-performance APIs with Fastify and TypeScript, covering validation, Prisma integration, and testing best practices
development
FastAPI modern Python web framework. Covers routing, Pydantic models, dependency injection, and async support. Use when building Python APIs. USE WHEN: user mentions "fastapi", "pydantic", "async python api", "python rest api", asks about "dependency injection python", "python openapi", "python swagger", "async endpoints", "python api validation", "fastapi middleware" DO NOT USE FOR: Django apps - use `django` instead, Flask apps - use `flask` instead, synchronous Python APIs without type hints, GraphQL-only APIs
tools
FastAPI integration testing specialist. Covers synchronous TestClient, async httpx AsyncClient, dependency injection overrides, auth testing (JWT, OAuth2, API keys), WebSocket testing, file uploads, background tasks, middleware testing, and HTTP mocking with respx, responses, and pytest-httpserver. USE WHEN: user mentions "FastAPI test", "TestClient", "httpx async test", "dependency override test", "respx mock", asks about testing FastAPI endpoints, authentication in tests, or HTTP client mocking. DO NOT USE FOR: Django - use `pytest-django`; pytest internals - use `pytest`; Container infrastructure - use `testcontainers-python`
development
Expert in FastAPI Python development with best practices for APIs and async operations