From 4a3e8b7ce3c3e122e9edb2c6370ec4879fad1548 Mon Sep 17 00:00:00 2001 From: Eelco Dolstra Date: Thu, 14 Dec 2023 15:58:27 +0100 Subject: [PATCH 1/3] magic-nix-cache no longer forks into the background --- bun.lockb | Bin 24784 -> 24784 bytes dist/index.js | 26 ++++++++++++++++++-------- src/index.ts | 29 +++++++++++++++++++++-------- 3 files changed, 39 insertions(+), 16 deletions(-) diff --git a/bun.lockb b/bun.lockb index 5f50faf32cf4f999d52eccbc3b5b8fcfb7abe56b..f3e62912f3b30ea1b7d9c03a1c162e9e9830278f 100755 GIT binary patch delta 43 zcmV+`0M!4`!2!_00kD_^llT}olMn?6v)BY=DgsqilQ9Jzvv4oa0h3@a6th4vkS~4{ B59j~@ delta 98 zcmca`knzGn#tk!A%nnTb`~QDE104K^f(y$WY#y>OFcbs>2_SIz#RI0p?6o37LpPse h$3c8@q<`{97O~9*`WF}{C+Lf8b}*cv4*>4ACxQR~ diff --git a/dist/index.js b/dist/index.js index 4256df1..ca60af0 100644 --- a/dist/index.js +++ b/dist/index.js @@ -12181,10 +12181,11 @@ async function setUpAutoCache() { else { runEnv = process.env; } - const outputPath = `${daemonDir}/parent.log`; + // Start the server. + const outputPath = `${daemonDir}/daemon.log`; const output = openSync(outputPath, 'a'); - const launch = spawn(daemonBin, [ - '--daemon-dir', daemonDir, + const daemon = spawn(daemonBin, [ + '--notify-fd', '3', '--listen', coreExports.getInput('listen'), '--upstream', coreExports.getInput('upstream-cache'), '--diagnostic-endpoint', coreExports.getInput('diagnostic-endpoint'), @@ -12197,13 +12198,20 @@ async function setUpAutoCache() { ] : []).concat(coreExports.getInput('use-gha-cache') === 'true' ? [ '--use-gha-cache' ] : []), { - stdio: ['ignore', output, output], - env: runEnv + stdio: ['ignore', output, output, 'pipe'], + env: runEnv, + detached: true }); + const pidFile = path$1.join(daemonDir, 'daemon.pid'); + await fs$2.writeFile(pidFile, `${daemon.pid}`); await new Promise((resolve, reject) => { - launch.on('exit', async (code, signal) => { + daemon.stdio[3].on('data', (data) => { + if (data.toString().trim() == 'INIT') { + resolve(); + } + }); + daemon.on('exit', async (code, signal) => { const log = await fs$2.readFile(outputPath, 'utf-8'); - console.log(log); if (signal) { reject(new Error(`Daemon was killed by signal ${signal}: ${log}`)); } @@ -12211,10 +12219,11 @@ async function setUpAutoCache() { reject(new Error(`Daemon exited with code ${code}: ${log}`)); } else { - resolve(); + reject(new Error(`Daemon unexpectedly exited: ${log}`)); } }); }); + daemon.unref(); coreExports.info('Launched Magic Nix Cache'); coreExports.exportVariable(ENV_CACHE_DAEMONDIR, daemonDir); } @@ -12224,6 +12233,7 @@ async function notifyAutoCache() { return; } try { + // FIXME: remove this coreExports.debug(`Indicating workflow start`); const res = await gotClient.post(`http://${coreExports.getInput('listen')}/api/workflow-start`).json(); coreExports.debug(`back from post`); diff --git a/src/index.ts b/src/index.ts index 406f927..5aad26d 100644 --- a/src/index.ts +++ b/src/index.ts @@ -113,12 +113,13 @@ async function setUpAutoCache() { runEnv = process.env; } - const outputPath = `${daemonDir}/parent.log`; + // Start the server. + const outputPath = `${daemonDir}/daemon.log`; const output = openSync(outputPath, 'a'); - const launch = spawn( + const daemon = spawn( daemonBin, [ - '--daemon-dir', daemonDir, + '--notify-fd', '3', '--listen', core.getInput('listen'), '--upstream', core.getInput('upstream-cache'), '--diagnostic-endpoint', core.getInput('diagnostic-endpoint'), @@ -134,25 +135,36 @@ async function setUpAutoCache() { '--use-gha-cache' ] : []), { - stdio: ['ignore', output, output], - env: runEnv + stdio: ['ignore', output, output, 'pipe'], + env: runEnv, + detached: true } ); + const pidFile = path.join(daemonDir, 'daemon.pid'); + await fs.writeFile(pidFile, `${daemon.pid}`); + await new Promise((resolve, reject) => { - launch.on('exit', async (code, signal) => { + daemon.stdio[3].on('data', (data) => { + if (data.toString().trim() == 'INIT') { + resolve(); + } + }); + + daemon.on('exit', async (code, signal) => { const log: string = await fs.readFile(outputPath, 'utf-8'); - console.log(log); if (signal) { reject(new Error(`Daemon was killed by signal ${signal}: ${log}`)); } else if (code) { reject(new Error(`Daemon exited with code ${code}: ${log}`)); } else { - resolve(); + reject(new Error(`Daemon unexpectedly exited: ${log}`)); } }); }); + daemon.unref(); + core.info('Launched Magic Nix Cache'); core.exportVariable(ENV_CACHE_DAEMONDIR, daemonDir); } @@ -165,6 +177,7 @@ async function notifyAutoCache() { } try { + // FIXME: remove this core.debug(`Indicating workflow start`); const res: any = await gotClient.post(`http://${core.getInput('listen')}/api/workflow-start`).json(); core.debug(`back from post`); From 5e52b9d4a2addae69e7c9c173ad25f8e1f845fba Mon Sep 17 00:00:00 2001 From: Eelco Dolstra Date: Thu, 14 Dec 2023 15:58:53 +0100 Subject: [PATCH 2/3] Use https://github.com/DeterminateSystems/magic-nix-cache-priv/pull/3 --- action.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/action.yml b/action.yml index dc1e7a3..49bf257 100644 --- a/action.yml +++ b/action.yml @@ -23,7 +23,7 @@ inputs: source-pr: description: The PR of `magic-nix-cache` to use. Conflicts with all other `source-*` options. required: false - default: 1 + default: 3 source-revision: description: The revision of `nix-magic-nix-cache` to use. Conflicts with all other `source-*` options. required: false From 9d7fb1fb0edeee596c7b42e46f286bfe7a2e8af5 Mon Sep 17 00:00:00 2001 From: Eelco Dolstra Date: Fri, 15 Dec 2023 17:15:58 +0100 Subject: [PATCH 3/3] Use a constant for the notification file descriptor --- dist/index.js | 8 ++++---- src/index.ts | 8 ++++---- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/dist/index.js b/dist/index.js index ca60af0..9fe91b1 100644 --- a/dist/index.js +++ b/dist/index.js @@ -12181,11 +12181,12 @@ async function setUpAutoCache() { else { runEnv = process.env; } - // Start the server. + // Start the server. Once it is ready, it will notify us via file descriptor 3. const outputPath = `${daemonDir}/daemon.log`; const output = openSync(outputPath, 'a'); + const notifyFd = 3; const daemon = spawn(daemonBin, [ - '--notify-fd', '3', + '--notify-fd', String(notifyFd), '--listen', coreExports.getInput('listen'), '--upstream', coreExports.getInput('upstream-cache'), '--diagnostic-endpoint', coreExports.getInput('diagnostic-endpoint'), @@ -12205,7 +12206,7 @@ async function setUpAutoCache() { const pidFile = path$1.join(daemonDir, 'daemon.pid'); await fs$2.writeFile(pidFile, `${daemon.pid}`); await new Promise((resolve, reject) => { - daemon.stdio[3].on('data', (data) => { + daemon.stdio[notifyFd].on('data', (data) => { if (data.toString().trim() == 'INIT') { resolve(); } @@ -12233,7 +12234,6 @@ async function notifyAutoCache() { return; } try { - // FIXME: remove this coreExports.debug(`Indicating workflow start`); const res = await gotClient.post(`http://${coreExports.getInput('listen')}/api/workflow-start`).json(); coreExports.debug(`back from post`); diff --git a/src/index.ts b/src/index.ts index 5aad26d..79ade61 100644 --- a/src/index.ts +++ b/src/index.ts @@ -113,13 +113,14 @@ async function setUpAutoCache() { runEnv = process.env; } - // Start the server. + // Start the server. Once it is ready, it will notify us via file descriptor 3. const outputPath = `${daemonDir}/daemon.log`; const output = openSync(outputPath, 'a'); + const notifyFd = 3; const daemon = spawn( daemonBin, [ - '--notify-fd', '3', + '--notify-fd', String(notifyFd), '--listen', core.getInput('listen'), '--upstream', core.getInput('upstream-cache'), '--diagnostic-endpoint', core.getInput('diagnostic-endpoint'), @@ -145,7 +146,7 @@ async function setUpAutoCache() { await fs.writeFile(pidFile, `${daemon.pid}`); await new Promise((resolve, reject) => { - daemon.stdio[3].on('data', (data) => { + daemon.stdio[notifyFd].on('data', (data) => { if (data.toString().trim() == 'INIT') { resolve(); } @@ -177,7 +178,6 @@ async function notifyAutoCache() { } try { - // FIXME: remove this core.debug(`Indicating workflow start`); const res: any = await gotClient.post(`http://${core.getInput('listen')}/api/workflow-start`).json(); core.debug(`back from post`);