testcafe
Version:
Automated browser testing for the modern web development stack.
73 lines • 11.6 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.safeFailRequest = exports.safeContinueRequest = exports.safeFulfillRequest = exports.safeContinueResponse = exports.connectionResetGuard = void 0;
const debug_loggers_1 = require("../../utils/debug-loggers");
const cdp_1 = require("../utils/cdp");
const IGNORED_ERROR_CODES = {
// In some cases (a request was aborted, any page that initiated the request doesn't exist, etc.)
// Chrome Debug Protocol doesn't allow to continue request pipeline
// and raises the "Invalid InterceptionId" error.
INVALID_INTERCEPTION_ID: -32602,
// The "Session not found" error can occur in iframes for unclear reasons.
SESSION_WITH_GIVEN_ID_NOT_FOUND: -32001,
};
//The "WebSocket connection closed" error occurs on closeWindow in multiple windows mode
const IGNORED_ERROR_MESSAGES = ['WebSocket connection closed'];
async function connectionResetGuard(handleRequestFn, handleErrorFn) {
var _a;
try {
await handleRequestFn();
}
catch (err) {
if (Object.values(IGNORED_ERROR_CODES).includes((_a = err === null || err === void 0 ? void 0 : err.response) === null || _a === void 0 ? void 0 : _a.code) || IGNORED_ERROR_MESSAGES.includes(err.message))
return;
handleErrorFn(err);
throw err;
}
}
exports.connectionResetGuard = connectionResetGuard;
async function safeContinueResponse(client, data, sessionId) {
const isPausedEvent = (0, cdp_1.isRequestPausedEvent)(data);
await connectionResetGuard(async () => {
const param = isPausedEvent
? { requestId: data.requestId }
: data;
// @ts-ignore
await client.Fetch.continueResponse(param, sessionId);
}, err => {
const formatter = isPausedEvent ? '%r' : '%s';
(0, debug_loggers_1.requestPipelineLogger)(`Fetch.continueResponse. Unhandled error %s during processing ${formatter}`, err, data);
});
}
exports.safeContinueResponse = safeContinueResponse;
async function safeFulfillRequest(client, fulfillInfo, sessionId) {
await connectionResetGuard(async () => {
// @ts-ignore
await client.Fetch.fulfillRequest(fulfillInfo, sessionId);
}, err => {
(0, debug_loggers_1.requestPipelineLogger)(`Fetch.fulfillRequest. Unhandled error %s during processing %s`, err, fulfillInfo.requestId);
});
}
exports.safeFulfillRequest = safeFulfillRequest;
async function safeContinueRequest(client, event, sessionId, continueRequestArgs) {
const { postData, method, url, headers } = continueRequestArgs || {};
await connectionResetGuard(async () => {
// @ts-ignore
await client.Fetch.continueRequest({ requestId: event.requestId, postData, method, url, headers }, sessionId);
}, err => {
(0, debug_loggers_1.requestPipelineLogger)(`Fetch.continueRequest. Unhandled error %s during processing %r`, err, event);
});
}
exports.safeContinueRequest = safeContinueRequest;
async function safeFailRequest(client, event, errorReason = 'Aborted') {
await connectionResetGuard(async () => {
await client.Fetch.failRequest({
requestId: event.requestId,
errorReason,
});
}, err => {
(0, debug_loggers_1.requestPipelineLogger)(`Fetch.failRequest. Unhandled error %s during processing %s`, err, event.requestId);
});
}
exports.safeFailRequest = safeFailRequest;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"safe-api.js","sourceRoot":"","sources":["../../../src/native-automation/request-pipeline/safe-api.ts"],"names":[],"mappings":";;;AACA,6DAAkE;AAMlE,sCAAoD;AAGpD,MAAM,mBAAmB,GAAG;IACxB,iGAAiG;IACjG,mEAAmE;IACnE,iDAAiD;IACjD,uBAAuB,EAAU,CAAC,KAAK;IACvC,0EAA0E;IAC1E,+BAA+B,EAAE,CAAC,KAAK;CAC1C,CAAC;AACF,wFAAwF;AACxF,MAAM,sBAAsB,GAAG,CAAC,6BAA6B,CAAC,CAAC;AAExD,KAAK,UAAU,oBAAoB,CAAE,eAAoC,EAAE,aAAiC;;IAC/G,IAAI;QACA,MAAM,eAAe,EAAE,CAAC;KAC3B;IACD,OAAO,GAAQ,EAAE;QACb,IAAI,MAAM,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC,QAAQ,CAAC,MAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,QAAQ,0CAAE,IAAI,CAAC,IAAI,sBAAsB,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC;YAChH,OAAO;QAEX,aAAa,CAAC,GAAG,CAAC,CAAC;QAEnB,MAAM,GAAG,CAAC;KACb;AACL,CAAC;AAZD,oDAYC;AAEM,KAAK,UAAU,oBAAoB,CAAE,MAAmB,EAAE,IAAkD,EAAE,SAAoB;IACrI,MAAM,aAAa,GAAG,IAAA,0BAAoB,EAAC,IAAI,CAAC,CAAC;IAEjD,MAAM,oBAAoB,CAAC,KAAK,IAAI,EAAE;QAClC,MAAM,KAAK,GAAG,aAAa;YACvB,CAAC,CAAC,EAAE,SAAS,EAAE,IAAI,CAAC,SAAS,EAAE;YAC/B,CAAC,CAAC,IAAI,CAAC;QAEX,aAAa;QACb,MAAM,MAAM,CAAC,KAAK,CAAC,gBAAgB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;IAC1D,CAAC,EAAE,GAAG,CAAC,EAAE;QACL,MAAM,SAAS,GAAG,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;QAE9C,IAAA,qCAAqB,EAAC,gEAAgE,SAAS,EAAE,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;IAClH,CAAC,CAAC,CAAC;AACP,CAAC;AAfD,oDAeC;AAEM,KAAK,UAAU,kBAAkB,CAAE,MAAmB,EAAE,WAAkC,EAAE,SAAoB;IACnH,MAAM,oBAAoB,CAAC,KAAK,IAAI,EAAE;QAClC,aAAa;QACb,MAAM,MAAM,CAAC,KAAK,CAAC,cAAc,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;IAC9D,CAAC,EAAE,GAAG,CAAC,EAAE;QACL,IAAA,qCAAqB,EAAC,+DAA+D,EAAE,GAAG,EAAE,WAAW,CAAC,SAAS,CAAC,CAAC;IACvH,CAAC,CAAC,CAAC;AACP,CAAC;AAPD,gDAOC;AAEM,KAAK,UAAU,mBAAmB,CAAE,MAAmB,EAAE,KAAyB,EAAE,SAAoB,EAAE,mBAAyC;IACtJ,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,mBAAmB,IAAI,EAAE,CAAC;IAErE,MAAM,oBAAoB,CAAC,KAAK,IAAI,EAAE;QAClC,aAAa;QACb,MAAM,MAAM,CAAC,KAAK,CAAC,eAAe,CAAC,EAAE,SAAS,EAAE,KAAK,CAAC,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,EAAE,OAAO,EAAE,EAAE,SAAS,CAAC,CAAC;IAClH,CAAC,EAAE,GAAG,CAAC,EAAE;QACL,IAAA,qCAAqB,EAAC,gEAAgE,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC;IACxG,CAAC,CAAC,CAAC;AACP,CAAC;AATD,kDASC;AAEM,KAAK,UAAU,eAAe,CAAE,MAAmB,EAAE,KAAyB,EAAE,cAA2B,SAAS;IACvH,MAAM,oBAAoB,CAAC,KAAK,IAAI,EAAE;QAClC,MAAM,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC;YAC3B,SAAS,EAAE,KAAK,CAAC,SAAS;YAC1B,WAAW;SACd,CAAC,CAAC;IACP,CAAC,EAAE,GAAG,CAAC,EAAE;QACL,IAAA,qCAAqB,EAAC,4DAA4D,EAAE,GAAG,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;IAC9G,CAAC,CAAC,CAAC;AACP,CAAC;AATD,0CASC","sourcesContent":["import { ProtocolApi } from 'chrome-remote-interface';\nimport { requestPipelineLogger } from '../../utils/debug-loggers';\nimport Protocol from 'devtools-protocol';\nimport RequestPausedEvent = Protocol.Fetch.RequestPausedEvent;\nimport FulfillRequestRequest = Protocol.Fetch.FulfillRequestRequest;\nimport ContinueResponseRequest = Protocol.Fetch.ContinueResponseRequest;\nimport ErrorReason = Protocol.Network.ErrorReason;\nimport { isRequestPausedEvent } from '../utils/cdp';\nimport { ContinueRequestArgs, SessionId } from '../types';\n\nconst IGNORED_ERROR_CODES = {\n    // In some cases (a request was aborted, any page that initiated the request doesn't exist, etc.)\n    // Chrome Debug Protocol doesn't allow to continue request pipeline\n    // and raises the \"Invalid InterceptionId\" error.\n    INVALID_INTERCEPTION_ID:         -32602,\n    // The \"Session not found\" error can occur in iframes for unclear reasons.\n    SESSION_WITH_GIVEN_ID_NOT_FOUND: -32001,\n};\n//The \"WebSocket connection closed\" error occurs on closeWindow in multiple windows mode\nconst IGNORED_ERROR_MESSAGES = ['WebSocket connection closed'];\n\nexport async function connectionResetGuard (handleRequestFn: () => Promise<void>, handleErrorFn: (err: any) => void): Promise<void> {\n    try {\n        await handleRequestFn();\n    }\n    catch (err: any) {\n        if (Object.values(IGNORED_ERROR_CODES).includes(err?.response?.code) || IGNORED_ERROR_MESSAGES.includes(err.message))\n            return;\n\n        handleErrorFn(err);\n\n        throw err;\n    }\n}\n\nexport async function safeContinueResponse (client: ProtocolApi, data: RequestPausedEvent | ContinueResponseRequest, sessionId: SessionId): Promise<void> {\n    const isPausedEvent = isRequestPausedEvent(data);\n\n    await connectionResetGuard(async () => {\n        const param = isPausedEvent\n            ? { requestId: data.requestId }\n            : data;\n\n        // @ts-ignore\n        await client.Fetch.continueResponse(param, sessionId);\n    }, err => {\n        const formatter = isPausedEvent ? '%r' : '%s';\n\n        requestPipelineLogger(`Fetch.continueResponse. Unhandled error %s during processing ${formatter}`, err, data);\n    });\n}\n\nexport async function safeFulfillRequest (client: ProtocolApi, fulfillInfo: FulfillRequestRequest, sessionId: SessionId): Promise<void> {\n    await connectionResetGuard(async () => {\n        // @ts-ignore\n        await client.Fetch.fulfillRequest(fulfillInfo, sessionId);\n    }, err => {\n        requestPipelineLogger(`Fetch.fulfillRequest. Unhandled error %s during processing %s`, err, fulfillInfo.requestId);\n    });\n}\n\nexport async function safeContinueRequest (client: ProtocolApi, event: RequestPausedEvent, sessionId: SessionId, continueRequestArgs?: ContinueRequestArgs): Promise<void> {\n    const { postData, method, url, headers } = continueRequestArgs || {};\n\n    await connectionResetGuard(async () => {\n        // @ts-ignore\n        await client.Fetch.continueRequest({ requestId: event.requestId, postData, method, url, headers }, sessionId);\n    }, err => {\n        requestPipelineLogger(`Fetch.continueRequest. Unhandled error %s during processing %r`, err, event);\n    });\n}\n\nexport async function safeFailRequest (client: ProtocolApi, event: RequestPausedEvent, errorReason: ErrorReason = 'Aborted'): Promise<void> {\n    await connectionResetGuard(async () => {\n        await client.Fetch.failRequest({\n            requestId: event.requestId,\n            errorReason,\n        });\n    }, err => {\n        requestPipelineLogger(`Fetch.failRequest. Unhandled error %s during processing %s`, err, event.requestId);\n    });\n}\n"]}