Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(3)

Unified Diff: LayoutTests/accessibility/computed-name.html

Issue 742353004: Implement computedRole and computedName (behind a flag) (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Update webexposed/element-instance-property-listing.html and add some SVG test cases Created 6 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | LayoutTests/accessibility/computed-name-expected.txt » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: LayoutTests/accessibility/computed-name.html
diff --git a/LayoutTests/accessibility/computed-name.html b/LayoutTests/accessibility/computed-name.html
new file mode 100644
index 0000000000000000000000000000000000000000..0edc0e0b61917f741370528a5179794cf855bc92
--- /dev/null
+++ b/LayoutTests/accessibility/computed-name.html
@@ -0,0 +1,299 @@
+<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML//EN">
+<html>
+<head>
+ <script src="../resources/js-test.js"></script>
+</head>
+
+<body data-role="document" aria-label="implicit document name">
+ <div id="test-cases">
+ <div role="alert" aria-label="alert name">This is an alert</div>
+
+ <div role="alertdialog" aria-label="alertdialog name">This is an alertdialog</div>
+
+ <div role="application" aria-label="application name">This is an application</div>
+
+ <div role="article" aria-label="article name">This is an article</div>
+ <article data-role="article" aria-label="implicit article name">This is an article</article>
+
+ <div role="banner" aria-label="banner name">This is a banner</div>
+ <header data-role="banner" aria-label="implicit banner name">This is a banner</header>
+
+ <div role="button">button name</div>
+ <div role="button" aria-label="button name">This is a button</div>
+ <input type="button" value="implicit button name" data-role="button">
+ <button data-role="button">implicit button name</button>
+ <button data-role="button" aria-label="implicit button name">This is a button</button>
+
+ <div role="complementary" data-knownFailure>complementary name</div>
+ <div role="complementary" aria-label="complementary name">This is a complementary</div>
+ <aside data-role="complementary" data-knownFailure>implicit complementary name</aside>
+ <aside data-role="complementary" aria-label="implicit complementary name">This is a complementary</aside>
+
+ <fieldset data-role="group" aria-label="implicit group name">
+ <div role="checkbox">checkbox name</div>
+ <div role="checkbox" aria-label="checkbox name"></div>
+ <label for="check">implicit checkbox name</label>
+ <input type="checkbox" id="check" data-role="checkbox">
+ </fieldset>
+
+ <div role="dialog" aria-label="dialog name"></div>
+ <dialog data-role="dialog" aria-label="implicit dialog name" data-knownFailure>This is a dialog</dialog>
+
+ <div role="directory" data-knownFailure>directory name</div>
+ <div role="directory" aria-label="directory name">This is a directory</div>
+
+ <div role="grid" aria-label="grid name">
+ <div role="row" aria-label="row name">
+ <div role="columnheader" aria-label="columnheader name">
+ This is a columnheader
+ </div>
+ </div>
+ <div role="row" aria-label="row name">
+ <div role="gridcell" aria-label="gridcell name">
+ This is a gridcell
+ </div>
+ </div>
+ </div>
+
+ <div role="combobox" aria-label="combobox name">This is a combobox</div>
+ <input type="text" list="suggestions" data-role="combobox" aria-name="implicit combobox name" data-knownFailure>
+ <datalist id="suggestions">
+ <option value="suggestion1" label="suggestion1">
+ <option value="suggestion2" label="suggestion2">
+ </datalist>
+
+ <div role="definition" aria-label="definition name">This is a definition</div>
+
+ <div role="document" aria-label="document name">This is a document</div>
+
+ <div role="form" aria-label="form name">This is a form</div>
+
+ <div role="group" aria-label="group name">This is a group</div>
+ <details data-role="group" aria-label="implicit group name">
+ <summary>This is a summary</summary>
+ This is a group
+ </details>
+
+ <div role="heading">heading name</div>
+ <div role="heading" aria-label="heading name">This is a heading</div>
+ <h1 data-role="heading">implicit heading name</h1>
+ <h2 data-role="heading">implicit heading name</h2>
+ <h3 data-role="heading">implicit heading name</h3>
+ <h4 data-role="heading">implicit heading name</h4>
+ <h5 data-role="heading">implicit heading name</h5>
+ <h6 data-role="heading">implicit heading name</h6>
+
+ <div role="img" aria-label="img name">This is an img</div>
+ <img src="broken.png" data-role="img" alt="implicit img name">
+
+ <div role="link">link name</div>
+ <div role="link" aria-label="link name">This is a link</div>
+ <a href="#" data-role="link">implicit link name</a>
+ <map name="map">
+ <area shape=rect coords="0, 0, 10, 10" href="#" data-role="link" aria-label="implicit link name">
+ </map>
+
+ <div role="list" aria-label="list name">This is a list</div>
+ <ul data-role="list" aria-label="implicit list name"><li data-role="listitem">implicit listitem name</li></ul>
+ <ol data-role="list" aria-label="implicit list name"><li data-role="listitem">implicit listitem name</li></ol>
+
+ <div role="listbox" aria-label="listbox name">This is a listbox</div>
+ <select data-role="listbox" size="1" aria-label="implicit listbox name">
+ <option value="1">First option</option>
+ <option value="2">Second</option>
+ </select>
+
+ <div role="log" aria-label="log name">This is a log</div>
+
+ <div role="main" aria-label="main name">This is main</div>
+ <main data-role="main" aria-label="implicit main name">This is main</main>
+
+ <div role="marquee" aria-label="marquee name">This is a marquee</div>
+
+ <div role="math" aria-label="math name">This is math</div>
+
+ <div role="menu" aria-label="menu name">This is a menu</div>
+
+ <div role="menubar" aria-label="menubar name">This is a menubar</div>
+
+ <div role="menuitem">menuitem name</div>
+ <div role="menuitem" aria-label="menuitem name">This is a menuitem</div>
+ <menu type="popup">
+ <menuitem command="doSomething" data-role="menuitem" aria-label="implicit menuitem name" data-knownFailure>This is a menuitem</menuitem>
+ </menu>
+
+ <div role="menuitemcheckbox">menuitemcheckbox name</div>
+ <div role="menuitemcheckbox" aria-label="menuitemcheckbox name">This is a menuitemcheckbox</div>
+
+ <div role="menuitemradio">menuitemradio name</div>
+ <div role="menuitemradio" aria-label="menuitemradio name">This is a menuitemradio</div>
+
+ <div role="navigation" aria-label="navigation name">This is a navigation</div>
+ <nav data-role="navigation" aria-label="implicit navigation name">This is a navigation</nav>
+
+ <div role="note" aria-label="note name">This is a note</div>
+
+ <div role="option">option name</div>
+ <div role="option" aria-label="option name">This is an option</div>
+ <select multiple>
+ <option value="1" data-role="option" data-knownFailure>implicit option name</option>
+ <option value="2" data-role="option" data-knownFailure>implicit option name</option>
+ </select>
+
+ <div role="progressbar" aria-label="progressbar name">This is a progressbar</div>
+ <progress data-role="progressbar" value="10" max="100" aria-label="implicit progressbar name">implicit progressbar name</progress>
+
+ <div role="radio">radio name</div>
+ <div role="radio" aria-label="radio name">This is a radiobutton</div>
+ <label for="radio">implicit radio name</label>
+ <input type="radio" data-role="radio" id="radio">
+
+ <div role="radiogroup" aria-label="radiogroup name">This is a radiogroup</div>
+
+ <div role="region" aria-label="region name">This is a region</div>
+ <section data-role="region" aria-label="implicit region name">This is a region</section>
+
+ <div role="scrollbar" aria-label="scrollbar name">This is a scrollbar</div>
+
+ <div role="search" aria-label="search name">This is a search</div>
+
+ <div role="separator" aria-label="separator name">This is a separator</div>
+ <hr data-role="separator" aria-label="implicit separator name">
+
+ <div role="slider" aria-label="slider name">This is a slider</div>
+ <label for="range">implicit slider name</label>
+ <input type="range" data-role="slider" value="5" max="10" id="range" data-knownFailure>
+
+ <div role="spinbutton" aria-label="spinbutton name">This is a spinbutton</div>
+ <label for="number">implicit spinbutton name</label>
+ <input type="number" data-role="spinbutton" data-knownFailure>
+
+ <div role="status" aria-label="status name">This is a status</div>
+ <output data-role="status" aria-label="implicit status name"></output>
+
+ <div role="tablist" aria-label="tablist name">
+ <div role="tab">tab name</div>
+ <div role="tab" aria-label="tab name">This is a tab</div>
+ </div>
+
+ <div role="tabpanel" aria-label="tabpanel name">This is a tabpanel</div>
+
+ <button role="text" data-knownFailure>text name</button>
+
+ <div role="textbox" aria-label="textbox name">This is a textbox</div>
+ <input type="email" data-role="textbox" aria-label="implicit textbox name">
+ <input type="password" data-role="textbox" aria-label="implicit textbox name">
+ <input type="search" data-role="textbox" aria-label="implicit textbox name">
+ <input type="tel" data-role="textbox" aria-label="implicit textbox name">
+ <input type="text" data-role="textbox" aria-label="implicit textbox name">
+ <input type="url" data-role="textbox" aria-label="implicit textbox name">
+
+ <div role="timer" aria-label="timer name">This is a timer</div>
+
+ <div role="toolbar" aria-label="toolbar name">This is a toolbar</div>
+ <menu type="toolbar" data-role="toolbar" aria-label="implicit toolbar name">
+ <menuitem onclick="location='help.html'" label="Help">
+ <menuitem onclick="location='about.html'" label="About">
+ </menu>
+
+ <div role="tooltip" aria-label="tooltip name">This is a tooltip</div>
+ <div role="tooltip" data-knownFailure>tooltip name</div>
+
+ <div role="tree" aria-label="tree name">This is a tree</div>
+
+ <div role="treegrid" aria-label="treegrid name">This is a treegrid</div>
+
+ <div role="treeitem" data-knownFailure>treeitem name</div>
+ <div role="treeitem" aria-label="treeitem name">This is a treeitem</div>
+
+ <!-- also works in SVG -->
+ <svg version="1.1" width="300" height="200" aria-labelledby="svg-title">
+ <title id="svg-title">Green rectangle</title>
+ <a xlink:href="http://example.com" tabindex="0" role="link">
+ <rect width="75" height="50" rx="20" ry="20" fill="#90ee90" stroke="#228b22" stroke-fill="1" />
+ <text x="35" y="30" font-size="1em" text-anchor="middle" fill="#000000">link name</text>
+ </a>
+ </svg>
+
+ <div id="inputs">
+ <input id="c0" data-expectedName="Title0" type="text" title="Title0">
+ <input id="c1" data-expectedName="Label1" type="text" title="Title1">
+ <input id="c2" data-expectedName="AriaLabel2" type="text" title="Title2" aria-label="AriaLabel2">
+ <input id="c3" data-expectedName="LabelledBy3" type="text" title="Title3" aria-label="AriaLabel3"
+ aria-labelledby="lb3">
+
+ <input id="c4" data-expectedName="Placeholder4" type="text" placeholder="Placeholder4">
+ <input id="c5" data-expectedName="Title5" type="text" placeholder="Placeholder5" title="Title5">
+
+ <input id="c6" data-expectedName="LabelledBy6" type="text" title="Title6"
+ aria-label="AriaLabel6" aria-labelledby="lb6"
+ aria-describedby="db6">
+
+ <input id="c7" data-expectedName="Placeholder7" type="text" title="Title7"
+ placeholder="Placeholder7" data-knownFailure>
+ </div>
+
+ <div id="labels">
+ <label for="c1">Label1</label>
+ <label for="c2">Label2</label>
+ <label for="c3">Label3</label>
+
+ <label for="c6">Label6</label>
+
+ <span id="lb3">LabelledBy3</span>
+
+ <span id="lb6">LabelledBy6</span>
+
+ <span id="db6">DescribedBy6</span>
+ </div>
+ </div>
+<script>
+description("");
+
+if (window.testRunner) {
+ testRunner.dumpAsText();
+
+ var roleElements = document.querySelectorAll('[role]');
+ var rolesTested = {};
+ for (var i = 0; i < roleElements.length; i++) {
+ var roleElement = roleElements[i];
+ var name = roleElement.computedName;
+ var role = roleElement.getAttribute('role');
+ if (!roleElement.hasAttribute('data-knownFailure')) {
+ var expectedNameString = '"' + role + ' name"';
+ shouldBe('name', expectedNameString);
+ }
+ var implicitRoleElements = document.querySelectorAll('[data-role=' + role + ']');
+ if (rolesTested[role])
+ continue;
+ for (var j = 0; j < implicitRoleElements.length; j++) {
+ var implicitRoleElement = implicitRoleElements[j];
+ if (!implicitRoleElement.hasAttribute('data-knownFailure')) {
+ var expectedNameString = '"implicit ' + role + ' name"';
+ shouldBe('implicitRoleElement.computedName', expectedNameString);
+ }
+ }
+ rolesTested[role] = true;
+ }
+
+ var svgElement = document.querySelector('svg');
+ var expectedSvgName = '"Green rectangle"';
+ shouldBe('svgElement.computedName', expectedSvgName);
+ var svgAElement = document.querySelector('svg a');
+ var expectedSvgAName = '"link name"';
+ shouldBe('svgAElement.computedName', expectedSvgAName);
+
+ var inputs = document.querySelector('#inputs').children;
+ for (var i = 0; i < inputs.length; i++) {
+ var input = inputs[i];
+ if (input.hasAttribute('data-knownFailure'))
+ continue;
+ var expectedNameString = '"' + input.getAttribute('data-expectedName') + '"';
+ shouldBe('input.computedName', expectedNameString);
+ }
+ document.querySelector('#test-cases').style.display = 'none';
+}
+</script>
+
+</body>
+</html>
« no previous file with comments | « no previous file | LayoutTests/accessibility/computed-name-expected.txt » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698