Skip to content

Commit

Permalink
chore(docs): add profile time upfront estimation
Browse files Browse the repository at this point in the history
  • Loading branch information
j-mendez committed Sep 30, 2023
1 parent 732e849 commit d87ec81
Show file tree
Hide file tree
Showing 9 changed files with 352 additions and 12 deletions.
25 changes: 22 additions & 3 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ The blazing fast and accurate web accessibility engine.
Install your browser automation lib [playwright](https://github.com/microsoft/playwright) or [puppeteer](https://github.com/puppeteer/puppeteer).

```sh
# yarn add puppeteer or yarn add playwright
# npm i puppeteer or npm i playwright
npm install kayle --save
```

Expand All @@ -21,11 +21,15 @@ const page = await browser.newPage();
const results = await kayle({
page,
browser,
runners: ["htmlcs"] // options are "htmlcs", "axe", and "ace". The order is from fastest to slowest. Defaults to htmlcs.
origin: "https://a11ywatch.com",
// html: "<html>...</html>"
});
```

It is recommended to use `htmlcs` as the runner or simply not declare a runner for the default.
We did a massive rewrite on htmlcs and it is extremely fast and stable.

When passing raw `html` try to also include the `origin` or the url, this sets `window.origin` and helps scripts that rely on it to work correctly or else relatives scripts will not work since the relative path does not exist on the locale machine.

If you need to run a full site-wide crawl import `autoKayle`.
Expand All @@ -44,7 +48,6 @@ const page = await browser.newPage();
const results = await autoKayle({
page,
browser,
runners: ["htmlcs", "axe"],
includeWarnings: true,
origin: "https://a11ywatch.com",
waitUntil: "domcontentloaded",
Expand All @@ -54,6 +57,23 @@ const results = await autoKayle({
});
```

```sh
# Output of time between runners with a realistic run - Rust/WASM is in the making and not yet ready.
# Measurement is only calculated from the runner and not the extra latency to get the page initially. View the `innate` test to see more detals.

# puppeteer - speed is stable across most versions
# Rust/WASM 18.43487498164177
# FAST_HTMLCS 29.915208011865616
# FAST_AXE 162.87204200029373
# ACE 512.5237080156803

# playwright - the speed depends on the version
# Rust/WASM TIME 17.60895800590515
# FAST_HTMLCS TIME 33.50962498784065
# FAST_AXE TIME 203.2565419971943
# ACE TIME 905.6748749911785
```

## Clips

You can include base64 images with the audits to get a visual of the exact location of the issue.
Expand All @@ -62,7 +82,6 @@ You can include base64 images with the audits to get a visual of the exact locat
const results = await kayle({
page,
browser,
runners: ["axe"],
includeWarnings: true,
origin: "https://www.drake.com",
waitUntil: "domcontentloaded",
Expand Down
3 changes: 2 additions & 1 deletion kayle/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "kayle",
"version": "0.7.10",
"version": "0.7.11",
"description": "Extremely fast and accurate accessibility engine built for any headless tool like playwright or puppeteer.",
"main": "./build/index.js",
"keywords": [
Expand Down Expand Up @@ -47,6 +47,7 @@
"test:playwright:axe": "npm run compile:test && npx playwright test ./tests/basic-axe-playwright.spec.ts",
"test:playwright:htmlcs": "npm run compile:test && npx playwright test ./tests/basic-htmlcs-playwright.spec",
"test:playwright:clips": "npm run compile:test && npx playwright test ./tests/clips-playwright.spec.ts",
"test:playwright:innate": "npm run compile:test && npx playwright test ./tests/innate-playwright.spec.ts",
"test:puppeteer:wasm": "npm run compile:test && node _tests/tests/wasm.js",
"test:puppeteer:automa": "npm run compile:test && node _tests/tests/automa.js",
"test:puppeteer:extension": "npm run compile:test && yarn build:extension && node _tests/tests/extension.js",
Expand Down
66 changes: 66 additions & 0 deletions kayle/tests/innate-playwright.spec.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
import { innateBuilder, kayle } from "kayle";
import { drakeMock } from "./mocks/html-mock";
import { performance } from "perf_hooks";
import { test } from "@playwright/test";
import { _audit_not_ready } from "kayle_innate";

test("kayle_innate, fast_htmlcs, fast_axecore, and ace audit drakeMock profiling compare", async ({
page,
browser,
}, testInfo) => {
if (process.env.LOG_ENABLED) {
page.on("console", (msg) => console.log("PAGE LOG:", msg.text()));
}
const { html, css } = await innateBuilder({
page,
browser,
runners: ["htmlcs"],
includeWarnings: true,
origin: "https://www.drake.com",
html: drakeMock,
});
const startTime = performance.now();
// 8 - after building end engine optimized most likely will be at 12 ms
await _audit_not_ready(html, css);
const nextTime = performance.now() - startTime;
console.log("Rust/WASM TIME ", nextTime);

const st = performance.now();
await kayle({
page,
browser,
runners: ["htmlcs"],
includeWarnings: true,
origin: "https://www.drake.com",
html: drakeMock,
noIntercept: true,
});
const nt = performance.now() - st;
console.log("FAST_HTMLCS TIME", nt);

const s = performance.now();
await kayle({
page,
browser,
runners: ["axe"],
includeWarnings: true,
origin: "https://www.drake.com",
html: drakeMock,
noIntercept: true,
});
const n = performance.now() - s;
console.log("FAST_AXE TIME", n);

const a = performance.now();
await kayle({
page,
browser,
runners: ["ace"],
includeWarnings: true,
origin: "https://www.drake.com",
html: drakeMock,
noIntercept: true,
});
const an = performance.now() - a;
console.log("ACE TIME", an);
});
33 changes: 29 additions & 4 deletions kayle/tests/innate.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import puppeteer from "puppeteer";
import { innateBuilder, kayle } from "kayle";
import { drakeMock } from "./mocks/html-mock";
import { performance } from "perf_hooks";
import { audit } from "kayle_innate";
import { _audit_not_ready } from "kayle_innate";

// setup test for rust wasm auditing
(async () => {
Expand All @@ -21,12 +21,11 @@ import { audit } from "kayle_innate";
});
const startTime = performance.now();
// 8 - after building end engine optimized most likely will be at 12 ms
await audit(html, css);
await _audit_not_ready(html, css);
const nextTime = performance.now() - startTime;
console.log("Rust/WASM TIME ", nextTime);

const st = performance.now();
// 28 ms
await kayle({
page,
browser,
Expand All @@ -37,7 +36,33 @@ import { audit } from "kayle_innate";
noIntercept: true,
});
const nt = performance.now() - st;
console.log("JS TIME", nt);
console.log("FAST_HTMLCS TIME", nt);

const s = performance.now();
await kayle({
page,
browser,
runners: ["axe"],
includeWarnings: true,
origin: "https://www.drake.com",
html: drakeMock,
noIntercept: true,
});
const n = performance.now() - s;
console.log("FAST_AXE TIME", n);

const a = performance.now();
await kayle({
page,
browser,
runners: ["ace"],
includeWarnings: true,
origin: "https://www.drake.com",
html: drakeMock,
noIntercept: true,
});
const an = performance.now() - a;
console.log("ACE TIME", an);

await browser.close();
})();
227 changes: 227 additions & 0 deletions kayle/tests/mocks/large-mock.ts

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion kayle_innate/Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion kayle_innate/Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[package]
name = "kayle_innate"
version = "0.0.19"
version = "0.0.20"
authors = ["j-mendez"]
edition = "2018"
license = "MIT"
Expand Down
2 changes: 1 addition & 1 deletion kayle_innate/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -31,4 +31,4 @@ In order to test the accessibility parser in Rust run.

1. Port expensive functions to wasm with preloading capabilities injection into browsers.
1. Reborn the accessibility testing in rust.
1. Write a web accessibility engine in Rust/Wasm.
1. Write a web accessibility engine in Rust/Wasm.
4 changes: 3 additions & 1 deletion kayle_innate/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -188,8 +188,10 @@ pub fn parse_accessibility_tree(

#[wasm_bindgen]
/// audit a web page passing the html and css rules.
pub fn audit(html: &str, _css_rules: &str) {
pub fn _audit_not_ready(html: &str, _css_rules: &str) {
let _tree = parse_accessibility_tree(&html);
let _css_nodes = parse_css(_css_rules);
// reference the css model when in the tree to get style information
}

/// parse css tree to maps
Expand Down

0 comments on commit d87ec81

Please sign in to comment.