diff --git a/spec-main/api-crash-reporter-spec.ts b/spec-main/api-crash-reporter-spec.ts index 3bdc528e7d3..8f8f6af7dd0 100644 --- a/spec-main/api-crash-reporter-spec.ts +++ b/spec-main/api-crash-reporter-spec.ts @@ -3,7 +3,7 @@ import * as childProcess from 'child_process'; import * as http from 'http'; import * as Busboy from 'busboy'; import * as path from 'path'; -import { ifdescribe, ifit, defer, startRemoteControlApp, delay } from './spec-helpers'; +import { ifdescribe, ifit, defer, startRemoteControlApp, delay, repeatedly } from './spec-helpers'; import { app } from 'electron/main'; import { crashReporter } from 'electron/common'; import { AddressInfo } from 'net'; @@ -401,7 +401,9 @@ ifdescribe(!isLinuxOnArm && !process.mas && !process.env.DISABLE_CRASH_REPORTER_ }); await waitForCrash(); // 3. get the crash from getLastCrashReport. - const firstReport = await remotely(() => require('electron').crashReporter.getLastCrashReport()); + const firstReport = await repeatedly( + () => remotely(() => require('electron').crashReporter.getLastCrashReport()) + ); expect(firstReport).to.not.be.null(); expect(firstReport.date).to.be.an.instanceOf(Date); expect((+new Date()) - (+firstReport.date)).to.be.lessThan(30000); diff --git a/spec-main/spec-helpers.ts b/spec-main/spec-helpers.ts index c644f402b53..434f68636f2 100644 --- a/spec-main/spec-helpers.ts +++ b/spec-main/spec-helpers.ts @@ -132,3 +132,16 @@ export function waitUntil ( }, timeout); }); } + +export async function repeatedly ( + fn: () => Promise, + opts?: { until?: (x: T) => boolean, timeLimit?: number } +) { + const { until = (x: T) => !!x, timeLimit = 10000 } = opts ?? {}; + const begin = +new Date(); + while (true) { + const ret = await fn(); + if (until(ret)) { return ret; } + if (+new Date() - begin > timeLimit) { throw new Error(`repeatedly timed out (limit=${timeLimit})`); } + } +}