Skip to content

Commit

Permalink
R18 add test (#803)
Browse files Browse the repository at this point in the history
* Bump actions/create-release from 1 to 1.1.4 (#802)

Bumps [actions/create-release](https://github.com/actions/create-release) from 1 to 1.1.4.
- [Release notes](https://github.com/actions/create-release/releases)
- [Commits](actions/create-release@v1...v1.1.4)

Signed-off-by: dependabot[bot] <[email protected]>

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* SIA R18: Added test

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: Jean-Yves Moyen <[email protected]>
  • Loading branch information
3 people committed Jun 17, 2021
1 parent 5208e2d commit e592aba
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 23 deletions.
45 changes: 22 additions & 23 deletions packages/alfa-rules/test/sia-r18/rule.spec.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import { h } from "@siteimprove/alfa-dom";
import { test } from "@siteimprove/alfa-test";

import { Document } from "@siteimprove/alfa-dom";

import R18, { Outcomes } from "../../src/sia-r18/rule";

import { evaluate } from "../common/evaluate";
Expand All @@ -9,7 +10,7 @@ import { passed, failed, inapplicable } from "../common/outcome";
test(`evaluate() passes a button with aria-pressed state`, async (t) => {
const target = <button aria-pressed="false">My button</button>;

const document = h.document([target]);
const document = Document.of([target]);

t.deepEqual(await evaluate(R18, { document }), [
passed(R18, target.attribute("aria-pressed").get(), {
Expand All @@ -18,14 +19,14 @@ test(`evaluate() passes a button with aria-pressed state`, async (t) => {
]);
});

test(`evaluate() passes a div element with button role, and an aria-pressed state`, async (t) => {
test(`evaluate() passes a div element with button role, whose has aria-pressed state`, async (t) => {
const target = (
<div role="button" aria-pressed="false">
My button
</div>
);

const document = h.document([target]);
const document = Document.of([target]);

t.deepEqual(await evaluate(R18, { document }), [
passed(R18, target.attribute("aria-pressed").get(), {
Expand All @@ -37,7 +38,7 @@ test(`evaluate() passes a div element with button role, and an aria-pressed stat
test(`evaluate() passes a div element with aria busy state`, async (t) => {
const target = <div aria-busy="true">My busy div</div>;

const document = h.document([target]);
const document = Document.of([target]);

t.deepEqual(await evaluate(R18, { document }), [
passed(R18, target.attribute("aria-busy").get(), {
Expand All @@ -46,14 +47,14 @@ test(`evaluate() passes a div element with aria busy state`, async (t) => {
]);
});

test(`evaluate() passes a div element with button role, and an aria-label attribute`, async (t) => {
test(`evaluate() passes a div element with button role, whose has aria-label state`, async (t) => {
const target = (
<div role="button" aria-label="OK">
</div>
);

const document = h.document([target]);
const document = Document.of([target]);

t.deepEqual(await evaluate(R18, { document }), [
passed(R18, target.attribute("aria-label").get(), {
Expand All @@ -62,14 +63,14 @@ test(`evaluate() passes a div element with button role, and an aria-label attrib
]);
});

test(`evaluate() passes a div element with checkbox role, and an aria-checked state`, async (t) => {
test(`evaluate() passes a div element with checkbox role, whose has aria-checked state`, async (t) => {
const target = (
<div role="checkbox" aria-checked="false">
My checkbox
</div>
);

const document = h.document([target]);
const document = Document.of([target]);

t.deepEqual(await evaluate(R18, { document }), [
passed(R18, target.attribute("aria-checked").get(), {
Expand All @@ -78,14 +79,14 @@ test(`evaluate() passes a div element with checkbox role, and an aria-checked st
]);
});

test(`evaluate() passes a div element with checkbox role, and an aria-controls state`, async (t) => {
test(`evaluate() passes a div element with checkbox role, whose has aria-controls state`, async (t) => {
const target = (
<div role="combobox" aria-controls="id1" aria-expanded="false">
My combobox
</div>
);

const document = h.document([target]);
const document = Document.of([target]);

t.deepEqual(await evaluate(R18, { document }), [
passed(R18, target.attribute("aria-controls").get(), {
Expand All @@ -97,15 +98,14 @@ test(`evaluate() passes a div element with checkbox role, and an aria-controls s
]);
});

test(`evaluate() passes a div element with checkbox role, and both
aria-controls and aria-expanded states`, async (t) => {
test(`evaluate() passes a div element with checkbox role, whose has aria-controls and aria-expanded state`, async (t) => {
const target = (
<div role="combobox" aria-controls="id1" aria-expanded="false">
My combobox
</div>
);

const document = h.document([target]);
const document = Document.of([target]);

t.deepEqual(await evaluate(R18, { document }), [
passed(R18, target.attribute("aria-controls").get(), {
Expand All @@ -117,15 +117,14 @@ test(`evaluate() passes a div element with checkbox role, and both
]);
});

test(`evaluate() passes a div element with checkbox role, with both
aria-expanded and empty aria-controls state`, async (t) => {
test(`evaluate() passes a div element with checkbox role, whose has aria-expanded and aria-controls (empty) state`, async (t) => {
const target = (
<div role="combobox" aria-expanded="false" aria-controls="">
My combobox
</div>
);

const document = h.document([target]);
const document = Document.of([target]);

t.deepEqual(await evaluate(R18, { document }), [
passed(R18, target.attribute("aria-expanded").get(), {
Expand All @@ -137,14 +136,14 @@ test(`evaluate() passes a div element with checkbox role, with both
]);
});

test(`evaluate() passes a button element with none role and aria-pressed`, async (t) => {
test(`evaluate() passes a button element with none role and aria pressed`, async (t) => {
const target = (
<button role="none" aria-pressed="false">
ACT rules are cool!
</button>
);

const document = h.document([target]);
const document = Document.of([target]);

t.deepEqual(await evaluate(R18, { document }), [
passed(R18, target.attribute("aria-pressed").get(), {
Expand All @@ -153,10 +152,10 @@ test(`evaluate() passes a button element with none role and aria-pressed`, async
]);
});

test(`evaluate() fails a button with aria-sort state, and no property`, async (t) => {
test(`evaluate() fails a button with aria-sort state, but it doesn't have any property`, async (t) => {
const target = <button aria-sort="">Sort by year</button>;

const document = h.document([target]);
const document = Document.of([target]);

t.deepEqual(await evaluate(R18, { document }), [
failed(R18, target.attribute("aria-sort").get(), {
Expand All @@ -165,10 +164,10 @@ test(`evaluate() fails a button with aria-sort state, and no property`, async (t
]);
});

test(`evaluate() is inapplicable for a div element with no aria attribute`, async (t) => {
test(`evaluate() is inapplicable for a div element with no aria state / property`, async (t) => {
const target = <div role="region">A region of content</div>;

const document = h.document([target]);
const document = Document.of([target]);

t.deepEqual(await evaluate(R18, { document }), [inapplicable(R18)]);
});
1 change: 1 addition & 0 deletions packages/alfa-rules/tsconfig.json
Original file line number Diff line number Diff line change
Expand Up @@ -173,6 +173,7 @@
"test/sia-r15/rule.spec.tsx",
"test/sia-r16/rule.spec.tsx",
"test/sia-r17/rule.spec.tsx",
"test/sia-r18/rule.spec.tsx",
"test/sia-r21/rule.spec.tsx",
"test/sia-r24/rule.spec.tsx",
"test/sia-r38/rule.spec.tsx",
Expand Down

0 comments on commit e592aba

Please sign in to comment.