AVA stores snapshots in a binary format (`.snap`), which produces no
meaningful diffs and bloats Git history. This replaces AVA with the
built-in `node:test` module, whose snapshot support generates
human-readable text files that are easy to diff and review in pull
requests.
The migration also replaces `@sinonjs/fake-timers` and `execa` with
Node.js built-ins (`node:test` mock timers and `node:child_process`),
removing three dev dependencies total.
- **`tests/index.js`**: Rewritten to use `node:test` with a custom
snapshot serializer that renders strings with actual newlines. Uses
subtests for labeled `stderr`/`stdout` snapshots, and only snapshots
non-empty output.
- **`tests/main-repo-skew.test.js`**: Replace `@sinonjs/fake-timers`
with `mock.timers.enable()` from `node:test`.
- **`tests/README.md`**: Updated documentation to reflect `node --test`
and the new snapshot file.
- **`package.json`**: Remove `ava`, `@sinonjs/fake-timers`, and `execa`
from devDependencies. Update test script to `c8 --100 node --test
tests/index.js`.
- **`tests/index.js.snapshot`**: New text-based snapshot file replacing
binary `tests/snapshots/index.js.snap`.
- **`tests/snapshots/`**: Deleted.
All 22 test scenarios (66 subtests) pass with 100% code coverage.
Closes #344
---------
Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
Co-authored-by: Copilot Autofix powered by AI <175728472+Copilot@users.noreply.github.com>
(cherry picked from commit f863ba5554)
65 lines
1.7 KiB
JavaScript
65 lines
1.7 KiB
JavaScript
import { mock } from "node:test";
|
|
|
|
import { test } from "./main.js";
|
|
|
|
// Verify `main` retry when the clock has drifted.
|
|
await test((mockPool) => {
|
|
process.env.INPUT_OWNER = "actions";
|
|
process.env.INPUT_REPOSITORIES = "failed-repo";
|
|
const owner = process.env.INPUT_OWNER;
|
|
const repo = process.env.INPUT_REPOSITORIES;
|
|
const mockInstallationId = "123456";
|
|
const mockAppSlug = "github-actions";
|
|
|
|
mock.timers.enable({ apis: ["Date"], now: 0 });
|
|
|
|
mockPool
|
|
.intercept({
|
|
path: `/repos/${owner}/${repo}/installation`,
|
|
method: "GET",
|
|
headers: {
|
|
accept: "application/vnd.github.v3+json",
|
|
"user-agent": "actions/create-github-app-token",
|
|
// Intentionally omitting the `authorization` header, since JWT creation is not idempotent.
|
|
},
|
|
})
|
|
.reply(({ headers }) => {
|
|
const [_, jwt] = (headers.authorization || "").split(" ");
|
|
const payload = JSON.parse(
|
|
Buffer.from(jwt.split(".")[1], "base64").toString(),
|
|
);
|
|
|
|
if (payload.iat < 0) {
|
|
return {
|
|
statusCode: 401,
|
|
data: {
|
|
message:
|
|
"'Issued at' claim ('iat') must be an Integer representing the time that the assertion was issued.",
|
|
},
|
|
responseOptions: {
|
|
headers: {
|
|
"content-type": "application/json",
|
|
date: new Date(Date.now() + 30000).toUTCString(),
|
|
},
|
|
},
|
|
};
|
|
}
|
|
|
|
return {
|
|
statusCode: 200,
|
|
data: {
|
|
id: mockInstallationId,
|
|
app_slug: mockAppSlug,
|
|
},
|
|
responseOptions: {
|
|
headers: {
|
|
"content-type": "application/json",
|
|
},
|
|
},
|
|
};
|
|
})
|
|
.times(2);
|
|
}).finally(() => {
|
|
mock.timers.reset();
|
|
});
|