diff --git a/src/common/Page.ts b/src/common/Page.ts index 0f078cc40ab..213094ce8b7 100644 --- a/src/common/Page.ts +++ b/src/common/Page.ts @@ -763,25 +763,28 @@ export class Page extends EventEmitter { * await fileChooser.accept(['/tmp/myfile.pdf']); * ``` */ - async waitForFileChooser( - options: WaitTimeoutOptions = {} - ): Promise { - if (!this.#fileChooserPromises.size) { - await this.#client.send('Page.setInterceptFileChooserDialog', { - enabled: true, - }); - } - + waitForFileChooser(options: WaitTimeoutOptions = {}): Promise { + const needsEnable = this.#fileChooserPromises.size === 0; const {timeout = this.#timeoutSettings.timeout()} = options; const promise = createDeferredPromise({ message: `Waiting for \`FileChooser\` failed: ${timeout}ms exceeded`, timeout, }); this.#fileChooserPromises.add(promise); - return promise.catch(error => { - this.#fileChooserPromises.delete(promise); - throw error; - }); + let enablePromise: Promise | undefined; + if (needsEnable) { + enablePromise = this.#client.send('Page.setInterceptFileChooserDialog', { + enabled: true, + }); + } + return Promise.all([promise, enablePromise]) + .then(([result]) => { + return result; + }) + .catch(error => { + this.#fileChooserPromises.delete(promise); + throw error; + }); } /**