UNPKG

@progress/kendo-e2e

Version:

Kendo UI end-to-end test utilities.

198 lines 8.76 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || (function () { var ownKeys = function(o) { ownKeys = Object.getOwnPropertyNames || function (o) { var ar = []; for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k; return ar; }; return ownKeys(o); }; return function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]); __setModuleDefault(result, mod); return result; }; })(); var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } 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) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.snapshotImage = snapshotImage; exports.snapshotViewPort = snapshotViewPort; /* eslint-disable @typescript-eslint/no-explicit-any */ /* eslint-disable @typescript-eslint/explicit-module-boundary-types */ const fs = __importStar(require("fs")); const looks_same_1 = __importDefault(require("looks-same")); const selenium_webdriver_1 = require("selenium-webdriver"); const util_1 = require("util"); const crop_1 = require("./crop"); const scripts_1 = require("./scripts"); const writeFile = (0, util_1.promisify)(fs.writeFile); const exists = (0, util_1.promisify)(fs.exists); const looksSame = (0, util_1.promisify)(looks_same_1.default); const defaults = { hideSelectors: [], offsetY: 0, sleep: 0, tolerance: 0, ignoreCaret: true, timeout: 3000 }; /** * Takes an image snapshot of an element and stores in the specified location. * * The image is compared using [looks-same](https://www.npmjs.com/package/looks-same) before overwriting. * * If `SKIP_IMAGE_UPLOAD_AND_FAIL` environment variable provided, the method throws error and the image writing is skipped. * * @example * await snapshotImage(driver, '#test-area', `${artifactsPath}/column-menu.png`, { * hideSelectors: ['div#demoToolbar'] * }); * * @param driver WebDriver instance * @param selector A selector that matches the element to screenshot. If multiple elements match, only the first will be used. * @param outputPath The path to the screenshot file to be created or updated. * @param options Screenshot options. */ function snapshotImage(driver, selector, outputPath, options) { return __awaiter(this, void 0, void 0, function* () { const { hideSelectors, offsetY, sleep, tolerance, ignoreCaret, timeout } = Object.assign(Object.assign({}, defaults), options); // Wait for element to be present const waitCondition = (driver) => __awaiter(this, void 0, void 0, function* () { try { const element = yield driver.findElement(selenium_webdriver_1.By.css(selector)); return yield element.isDisplayed(); } catch (_a) { return false; } }); yield driver.wait(waitCondition, 10000, `Failed to find element located by ${selector}.`); // Wait until screenshot match expected image const snapshotResult = { same: false }; let same = false; let cropped; try { if (sleep > 0) { yield driver.sleep(sleep); } yield driver.executeScript(scripts_1.hideElements, hideSelectors); const viewport = yield driver.executeScript(scripts_1.setViewport, selector, offsetY); const actualScreenViewport = yield driver.executeScript("return [window.innerWidth, window.innerHeight];"); viewport.width = Math.min(actualScreenViewport[0], viewport.width); viewport.height = Math.min(actualScreenViewport[1], viewport.height); yield driver.wait(() => __awaiter(this, void 0, void 0, function* () { const data = yield driver.takeScreenshot(); const image = Buffer.from(data, 'base64'); cropped = (0, crop_1.crop)(image, viewport); if (yield exists(outputPath)) { const result = yield looksSame(cropped, outputPath, { strict: false, tolerance: tolerance, ignoreCaret: ignoreCaret }); return result.equal; } else { return false; } }), timeout); same = true; } catch (_a) { console.warn(`Actual screenshot does not match ${outputPath}`); } finally { if (!same) { if (!process.env.SKIP_IMAGE_UPLOAD_AND_FAIL) { yield writeFile(outputPath, cropped); } else { // Environment variable SKIP_IMAGE_UPLOAD_AND_FAIL could be set for executions against read-only branches, the test throws error throw new Error(`Snapshot doesn't match reference for ${outputPath}.\nWill not update the image on disk as the SKIP_IMAGE_UPLOAD_AND_FAIL is set.\nAborting!`); } } yield driver.executeScript(scripts_1.restoreElements, hideSelectors); } snapshotResult.same = same; return snapshotResult; }); } /** * Takes an image snapshot of view port. * * The image is compared using [looks-same](https://www.npmjs.com/package/looks-same) before overwriting. * * @example * await snapshotViewPort(driver, `${artifactsPath}/column-menu.png`, { * hideSelectors: ['div#demoToolbar'] * }); * * @param driver WebDriver instance * @param outputPath The path to the screenshot file to be created or updated. * @param options Screenshot options. */ function snapshotViewPort(driver, outputPath, options) { return __awaiter(this, void 0, void 0, function* () { const { hideSelectors, sleep, tolerance, ignoreCaret, timeout } = Object.assign(Object.assign({}, defaults), options); // Wait until screenshot match expected image const snapshotResult = { same: false }; let same = false; let image; try { if (sleep > 0) { yield driver.sleep(sleep); } yield driver.executeScript(scripts_1.hideElements, hideSelectors); yield driver.wait(() => __awaiter(this, void 0, void 0, function* () { const data = yield driver.takeScreenshot(); image = Buffer.from(data, 'base64'); if (yield exists(outputPath)) { const result = yield looksSame(image, outputPath, { strict: false, tolerance: tolerance, ignoreCaret: ignoreCaret }); return result.equal; } else { return false; } }), timeout); same = true; } catch (_a) { console.warn(`Actual screenshot do not match ${outputPath}`); } finally { if (!same) { yield writeFile(outputPath, image); } yield driver.executeScript(scripts_1.restoreElements, hideSelectors); } snapshotResult.same = same; return snapshotResult; }); } //# sourceMappingURL=snapshot-image.js.map