Skip to content

Commit

Permalink
add worker log prefix; proper hard shutdown
Browse files Browse the repository at this point in the history
  • Loading branch information
naltatis committed Aug 26, 2024
1 parent 0360577 commit 76a5417
Showing 1 changed file with 38 additions and 14 deletions.
52 changes: 38 additions & 14 deletions tests/evcc.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import axios from "axios";
import { exec, execSync } from "child_process";
import os from "os";
import path from "path";
import { Transform } from "stream";

const BINARY = "./evcc";

Expand All @@ -16,6 +17,26 @@ function sleep(ms) {
return new Promise((resolve) => setTimeout(resolve, ms));
}

function logPrefix() {
return `[worker:${process.env.TEST_WORKER_INDEX}]`;
}

function createSteamLog() {
return new Transform({
transform(chunk, encoding, callback) {
const lines = chunk.toString().split("\n");
lines.forEach((line) => {
if (line.trim()) log(line);
});
callback();
},
});
}

function log(...args) {
console.log(logPrefix(), ...args);
}

export function baseUrl() {
return `http://localhost:${workerPort()}`;
}
Expand Down Expand Up @@ -55,52 +76,55 @@ export async function cleanRestart(config, sqlDumps) {
async function _restoreDatabase(sqlDumps) {
const dumps = Array.isArray(sqlDumps) ? sqlDumps : [sqlDumps];
for (const dump of dumps) {
console.log("loading database", dbPath(), dump);
log("loading database", dbPath(), dump);
execSync(`sqlite3 ${dbPath()} < tests/${dump}`);
}
}

async function _start(config) {
const configFile = config.includes("/") ? config : `tests/${config}`;
const port = workerPort();
console.log(`wait until port ${port} is available`);
log(`wait until port ${port} is available`);
await waitOn({ resources: [`tcp:localhost:${port}`], reverse: true });
console.log("starting evcc", { config, port });
log("starting evcc", { config, port });
const instance = exec(
`EVCC_NETWORK_PORT=${port} EVCC_DATABASE_DSN=${dbPath()} ${BINARY} --config ${configFile}`
);
instance.stdout.pipe(process.stdout);
instance.stderr.pipe(process.stderr);
const steamLog = createSteamLog();
instance.stdout.pipe(steamLog);
instance.stderr.pipe(steamLog);
instance.on("exit", (code) => {
console.log("evcc terminated", { code, port, config });
log("evcc terminated", { code, port, config });
steamLog.end();
});
await waitOn({ resources: [baseUrl()] });
return instance;
}

async function _stop(instance) {
const port = workerPort();
if (instance) {
console.log("shutting down evcc hard");
log("shutting down evcc hard", { port });
// hard kill, only use of normal shutdown doesn't work
instance.kill("SIGKILL");
await sleep(300);
await waitOn({ resources: [`tcp:localhost:${port}`], reverse: true });
log("evcc is down", { port });
return;
}
const port = workerPort();
console.log("shutting down evcc", { port });
log("shutting down evcc", { port });
const res = await axios.post(`${baseUrl()}/api/auth/login`, { password: "secret" });
console.log(res.status, res.statusText);
log(res.status, res.statusText);
const cookie = res.headers["set-cookie"];
await axios.post(`${baseUrl()}/api/system/shutdown`, {}, { headers: { cookie } });
console.log(`wait until port ${port} is closed`);
log(`wait until port ${port} is closed`);
await waitOn({ resources: [`tcp:localhost:${port}`], reverse: true });
console.log("evcc is down", { port });
log("evcc is down", { port });
}

async function _clean() {
const db = dbPath();
if (fs.existsSync(db)) {
console.log("delete database", db);
log("delete database", db);
fs.unlinkSync(db);
}
}

0 comments on commit 76a5417

Please sign in to comment.