From 75e0ec93a32fd99f8193235df1988058582da456 Mon Sep 17 00:00:00 2001 From: billyct Date: Wed, 15 Dec 2021 07:49:00 +0800 Subject: [PATCH] Fix timeout error in some cases (#24) Co-authored-by: Sindre Sorhus --- index.js | 46 +++++++++++++++++++++++----------------------- 1 file changed, 23 insertions(+), 23 deletions(-) diff --git a/index.js b/index.js index 1cb8832..46943a2 100644 --- a/index.js +++ b/index.js @@ -109,20 +109,6 @@ class Aperture { recorderOptions.videoCodec = codecMap.get(videoCodec); } - this.recorder = execa( - BIN, [ - 'record', - '--process-id', - this.processId, - JSON.stringify(recorderOptions) - ] - ); - - this.isFileReady = (async () => { - await this.waitForEvent('onFileReady'); - return this.tmpPath; - })(); - const timeout = setTimeout(() => { // `.stopRecording()` was called already if (this.recorder === undefined) { @@ -136,15 +122,6 @@ class Aperture { reject(error); }, 5000); - this.recorder.catch(error => { - clearTimeout(timeout); - delete this.recorder; - reject(error); - }); - - this.recorder.stdout.setEncoding('utf8'); - this.recorder.stdout.on('data', log); - (async () => { try { await this.waitForEvent('onStart'); @@ -154,6 +131,29 @@ class Aperture { reject(error); } })(); + + this.isFileReady = (async () => { + await this.waitForEvent('onFileReady'); + return this.tmpPath; + })(); + + this.recorder = execa( + BIN, [ + 'record', + '--process-id', + this.processId, + JSON.stringify(recorderOptions) + ] + ); + + this.recorder.catch(error => { + clearTimeout(timeout); + delete this.recorder; + reject(error); + }); + + this.recorder.stdout.setEncoding('utf8'); + this.recorder.stdout.on('data', log); }); }