UNPKG

flagpole

Version:

Simple and fast DOM integration, headless or headful browser, and REST API testing framework.

74 lines 3.02 kB
"use strict"; var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; Object.defineProperty(exports, "__esModule", { value: true }); const domelement_1 = require("./domelement"); const response_1 = require("./response"); class BrowserResponse extends response_1.GenericResponse { get isBrowser() { return true; } get typeName() { return 'Browser'; } get browser() { return this.scenario.getBrowser(); } get page() { return this.scenario.getBrowser().getPage(); } get type() { return response_1.ResponseType.browser; } find(path) { return __awaiter(this, void 0, void 0, function* () { const response = this; const page = this.scenario.getBrowser().getPage(); if (page !== null) { const el = yield page.$(path); if (el !== null) { return yield domelement_1.DOMElement.create(el, this.context, null, path); } } return null; }); } findAll(path) { return __awaiter(this, void 0, void 0, function* () { const response = this; const page = this.scenario.getBrowser().getPage(); const domElements = []; if (page !== null) { const elements = yield page.$$(path); yield elements.forEach(function (el, i) { return __awaiter(this, void 0, void 0, function* () { const domElement = yield domelement_1.DOMElement.create(el, response.context, `${path} [${i}]`, path); domElements.push(domElement); }); }); } return domElements; }); } evaluate(context, callback) { return __awaiter(this, void 0, void 0, function* () { if (this.page !== null) { const functionName = `flagpole_${Date.now()}`; const jsToInject = `window.${functionName} = ${callback}`; yield this.page.addScriptTag({ content: jsToInject }); return yield this.page.evaluate(functionName => { return window[functionName](); }, functionName); } throw new Error('Cannot evaluate code becuase page is null.'); }); } } exports.BrowserResponse = BrowserResponse; //# sourceMappingURL=browserresponse.js.map