accessible/tests/mochitest/relations/test_ui_modalprompt.html
author Timothy Guan-tin Chien <timdream@gmail.com>
Fri, 04 Jan 2019 19:29:34 +0000
changeset 509682 92f9e0296e6270f507f6b36aa7038b6d03ba2a04
parent 497926 edc4ae8f78e2fb02647d7cd85cb19830a17dcd1d
child 528459 0d9b9b96f5475adbed73922da696aeff7cbbaed3
permissions -rw-r--r--
Bug 1512048 - Convert tabmodalprompt binding to JSM module r=Gijs This converts the tabmodalprompt binding to a class, to be constructed along side with the element by TabModalPromptBox. TabModalPromptBox will keep the instances in a map and pass it to the callers, instead of the element. The tests and callers can access the class instance by passing the element reference to the map. Differential Revision: https://phabricator.services.mozilla.com/D15505

<html>

<head>
  <title>Modal prompts</title>
  <link rel="stylesheet" type="text/css"
        href="chrome://mochikit/content/tests/SimpleTest/test.css" />

  <script type="application/javascript"
          src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js"></script>
  <script type="application/javascript"
          src="chrome://mochikit/content/tests/SimpleTest/EventUtils.js"></script>

  <script type="application/javascript"
          src="../common.js"></script>
  <script type="application/javascript"
          src="../relations.js"></script>
  <script type="application/javascript"
          src="../role.js"></script>
  <script type="application/javascript"
          src="../events.js"></script>
  <script type="application/javascript"
          src="../browser.js"></script>

  <script type="application/javascript">
    function hasTabModalPrompts() {
      try {
        return SpecialPowers.getBoolPref("prompts.tab_modal.enabled");
      } catch (ex) {
        return false;
      }
    }

    function showAlert() {
      this.eventSeq = [
        {
          type: EVENT_SHOW,
          match(aEvent) {
            return aEvent.accessible.role == ROLE_DIALOG;
          },
        },
      ];

      this.invoke = function showAlert_invoke() {
        window.setTimeout(
          function() {
            currentTabDocument().defaultView.alert("hello");
          }, 0);
      };

      this.check = function showAlert_finalCheck(aEvent) {
        var dialog = aEvent.accessible.DOMNode;
        var info = dialog.querySelector(".tabmodalprompt-infoBody");
        testRelation(info, RELATION_DESCRIPTION_FOR, dialog);
        testRelation(dialog, RELATION_DESCRIBED_BY, info);
      };

      this.getID = function showAlert_getID() {
        return "show alert";
      };
    }

    // gA11yEventDumpToConsole = true; // debug

    var gQueue = null;
    function doTests() {
      gQueue = new eventQueue();
      gQueue.push(new showAlert());
      gQueue.onFinish = function() {
        synthesizeKey("VK_RETURN", {}, browserWindow());
        closeBrowserWindow();
      };
      gQueue.invoke(); // will call SimpleTest.finish()
    }

    if (!hasTabModalPrompts()) {
      todo(false, "Test disabled when tab modal prompts are not enabled.");
    } else {
      SimpleTest.waitForExplicitFinish();
      openBrowserWindow(doTests);
    }
  </script>

</head>

<body id="body">

  <a target="_blank"
     href="https://bugzilla.mozilla.org/show_bug.cgi?id=661293"
     title="The tabmodalprompt dialog's prompt label doesn't get the text properly associated for accessibility">
    Mozilla Bug 661293
  </a>
  <br>
  <p id="display"></p>
  <div id="content" style="display: none"></div>
  <pre id="test">
  </pre>

</body>
</html>