mirror of
https://github.com/microsoft/playwright.git
synced 2024-12-11 12:33:45 +03:00
0a49c3dbb9
This fixes: ``` Run npm audit --omit dev # npm audit report @babel/traverse <7.23.2 Severity: critical Babel vulnerable to arbitrary code execution when compiling specifically crafted malicious code - https://github.com/advisories/GHSA-[6](https://github.com/microsoft/playwright/actions/runs/6535308689/job/17744452034?pr=27631#step:10:7)[7](https://github.com/microsoft/playwright/actions/runs/6535308689/job/17744452034?pr=27631#step:10:8)hx-6x53-jw[9](https://github.com/microsoft/playwright/actions/runs/6535308689/job/17744452034?pr=27631#step:10:10)2 fix available via `npm audit fix` node_modules/@babel/traverse 1 critical severity vulnerability To address all issues, run: npm audit fix Error: Process completed with exit code 1. ```
62 lines
2.1 KiB
TypeScript
62 lines
2.1 KiB
TypeScript
/**
|
|
* Copyright (c) Microsoft Corporation.
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
import { PNG } from 'playwright-core/lib/utilsBundle';
|
|
import { ImageChannel } from 'playwright-core/lib/image_tools/imageChannel';
|
|
|
|
// mulberry32
|
|
export function createRandom(seed) {
|
|
return function() {
|
|
let t = seed += 0x6D2B79F5;
|
|
t = Math.imul(t ^ t >>> 15, t | 1);
|
|
t ^= t + Math.imul(t ^ t >>> 7, t | 61);
|
|
return ((t ^ t >>> 14) >>> 0) / 4294967296;
|
|
};
|
|
}
|
|
|
|
export function randomPNG(width, height, seed) {
|
|
const random = createRandom(seed);
|
|
const png = new PNG({ width, height });
|
|
for (let i = 0; i < height; ++i) {
|
|
for (let j = 0; j < width; ++j) {
|
|
for (let k = 0; k < 4; ++k)
|
|
png.data[(i * width + j) * 4 + k] = (random() * 255) | 0;
|
|
}
|
|
}
|
|
return png;
|
|
}
|
|
|
|
export function assertEqual(value1, value2) {
|
|
if (Math.abs(value1 - value2) >= 1e-3)
|
|
throw new Error(`ERROR: ${value1} is not equal to ${value2}`);
|
|
}
|
|
|
|
// NOTE: this is exact formula from SSIM.js and it DOES NOT include alpha.
|
|
// We use it to better compare with original SSIM implementation.
|
|
export function grayChannel(image: any) {
|
|
const width = image.width;
|
|
const height = image.height;
|
|
const gray = new Uint8Array(image.width * image.height);
|
|
for (let y = 0; y < image.height; ++y) {
|
|
for (let x = 0; x < image.width; ++x) {
|
|
const index = y * image.width + x;
|
|
const offset = index * 4;
|
|
gray[index] = (77 * image.data[offset] + 150 * image.data[offset + 1] + 29 * image.data[offset + 2] + 128) >> 8;
|
|
}
|
|
}
|
|
return new ImageChannel(width, height, gray);
|
|
}
|