use fastify for test server

This commit is contained in:
silverwind 2020-03-15 01:14:12 +01:00
parent 45340d6a2c
commit ae8738de11
Signed by: silverwind
GPG Key ID: 2E62B41C93869443
2 changed files with 19 additions and 14 deletions

@ -31,11 +31,11 @@
"@rollup/plugin-node-resolve": "7.1.1",
"ansi-regex": "5.0.0",
"colorette": "1.1.0",
"create-test-server": "3.0.1",
"del": "5.1.0",
"eslint": "6.8.0",
"eslint-config-silverwind": "10.0.1",
"execa": "4.0.0",
"fastify": "2.12.1",
"hosted-git-info": "3.0.4",
"jest": "25.1.0",
"make-fetch-happen": "8.0.4",

31
test.js

@ -1,13 +1,14 @@
"use strict";
const createTestServer = require("create-test-server");
const del = require("del");
const execa = require("execa");
const fastify = require("fastify");
const tempy = require("tempy");
const {bin} = require("./package.json");
const {join} = require("path");
const {test, expect, beforeAll, afterAll} = global;
const {writeFile, readFile} = require("fs").promises;
const {bin} = require("./package.json");
const {promisify} = require("util");
const packageJson = require("./fixtures/test.json");
const testDir = tempy.directory();
@ -19,20 +20,20 @@ const dependencyTypes = [
"optionalDependencies",
];
const testPackages = [];
const testPackages = new Set();
for (const dependencyType of dependencyTypes) {
for (const name of Object.keys(packageJson[dependencyType] || [])) {
testPackages.push(name);
testPackages.add(name);
}
}
let npmServer, githubServer, githubApiUrl;
let npmServer, githubServer, githubUrl, npmUrl;
beforeAll(async () => {
let commits, tags;
[npmServer, githubServer, commits, tags] = await Promise.all([
createTestServer(),
createTestServer(),
fastify(),
fastify(),
readFile(join(__dirname, "fixtures/github/updates-commits.json")),
readFile(join(__dirname, "fixtures/github/updates-tags.json"))
]);
@ -40,14 +41,18 @@ beforeAll(async () => {
for (const packageName of testPackages) {
const name = packageName.replace(/\//g, "%2f");
const path = join(__dirname, `fixtures/npm/${name}.json`);
npmServer.get(`/${name}`, await readFile(path));
npmServer.get(`/${name}`, async (_, res) => res.send(await readFile(path)));
}
githubServer.get("/repos/silverwind/updates/commits", commits);
githubServer.get("/repos/silverwind/updates/git/refs/tags", tags);
githubServer.get("/repos/silverwind/updates/commits", (_, res) => res.send(commits));
githubServer.get("/repos/silverwind/updates/git/refs/tags", (_, res) => res.send(tags));
githubApiUrl = githubServer.sslUrl;
await writeFile(join(testDir, ".npmrc"), `registry=${npmServer.sslUrl}`); // Fake registry
[githubUrl, npmUrl] = await Promise.all([
promisify(githubServer.listen).bind(githubServer)(0),
promisify(npmServer.listen).bind(npmServer)(0),
]);
await writeFile(join(testDir, ".npmrc"), `registry=${npmUrl}`); // Fake registry
await writeFile(join(testDir, "package.json"), JSON.stringify(packageJson, null, 2)); // Copy fixture
});
@ -61,7 +66,7 @@ afterAll(async () => {
function makeTest(args, expected) {
return async () => {
const argsArr = [...args.split(/\s+/), "-G", githubApiUrl];
const argsArr = [...args.split(/\s+/), "-G", githubUrl];
const {stdout} = await execa(join(__dirname, bin), argsArr, {cwd: testDir});
const {results} = JSON.parse(stdout);