mirror of
https://github.com/puppeteer/puppeteer
synced 2024-06-14 14:02:48 +00:00
127 lines
2.7 KiB
TypeScript
127 lines
2.7 KiB
TypeScript
/**
|
|
* Copyright 2018 Google Inc. All rights reserved.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
/**
|
|
* @deprecated Do not use.
|
|
*
|
|
* @public
|
|
*/
|
|
export class CustomError extends Error {
|
|
/**
|
|
* @internal
|
|
*/
|
|
constructor(message?: string) {
|
|
super(message);
|
|
this.name = this.constructor.name;
|
|
}
|
|
|
|
/**
|
|
* @internal
|
|
*/
|
|
get [Symbol.toStringTag](): string {
|
|
return this.constructor.name;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* TimeoutError is emitted whenever certain operations are terminated due to
|
|
* timeout.
|
|
*
|
|
* @remarks
|
|
* Example operations are {@link Page.waitForSelector | page.waitForSelector} or
|
|
* {@link PuppeteerNode.launch | puppeteer.launch}.
|
|
*
|
|
* @public
|
|
*/
|
|
export class TimeoutError extends CustomError {}
|
|
|
|
/**
|
|
* ProtocolError is emitted whenever there is an error from the protocol.
|
|
*
|
|
* @public
|
|
*/
|
|
export class ProtocolError extends CustomError {
|
|
#code?: number;
|
|
#originalMessage = '';
|
|
|
|
set code(code: number | undefined) {
|
|
this.#code = code;
|
|
}
|
|
/**
|
|
* @readonly
|
|
* @public
|
|
*/
|
|
get code(): number | undefined {
|
|
return this.#code;
|
|
}
|
|
|
|
set originalMessage(originalMessage: string) {
|
|
this.#originalMessage = originalMessage;
|
|
}
|
|
/**
|
|
* @readonly
|
|
* @public
|
|
*/
|
|
get originalMessage(): string {
|
|
return this.#originalMessage;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @internal
|
|
*/
|
|
export class TargetCloseError extends ProtocolError {}
|
|
|
|
/**
|
|
* @deprecated Do not use.
|
|
*
|
|
* @public
|
|
*/
|
|
export interface PuppeteerErrors {
|
|
TimeoutError: typeof TimeoutError;
|
|
ProtocolError: typeof ProtocolError;
|
|
}
|
|
|
|
/**
|
|
* @deprecated Import error classes directly.
|
|
*
|
|
* Puppeteer methods might throw errors if they are unable to fulfill a request.
|
|
* For example, `page.waitForSelector(selector[, options])` might fail if the
|
|
* selector doesn't match any nodes during the given timeframe.
|
|
*
|
|
* For certain types of errors Puppeteer uses specific error classes. These
|
|
* classes are available via `puppeteer.errors`.
|
|
*
|
|
* @example
|
|
* An example of handling a timeout error:
|
|
*
|
|
* ```ts
|
|
* try {
|
|
* await page.waitForSelector('.foo');
|
|
* } catch (e) {
|
|
* if (e instanceof TimeoutError) {
|
|
* // Do something if this is a timeout.
|
|
* }
|
|
* }
|
|
* ```
|
|
*
|
|
* @public
|
|
*/
|
|
export const errors: PuppeteerErrors = Object.freeze({
|
|
TimeoutError,
|
|
ProtocolError,
|
|
});
|