chromium/third_party/blink/web_tests/http/tests/devtools/elements/elements-css-path.js

// Copyright 2017 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

import {TestRunner} from 'test_runner';
import {ElementsTestRunner} from 'elements_test_runner';

import * as ElementsModule from 'devtools/panels/elements/elements.js';

(async function() {
  TestRunner.addResult(`Tests DOMNode.cssPath()\n`);
  await TestRunner.showPanel('elements');
  await TestRunner.loadHTML(`
      <!DOCTYPE html>
      <article></article>
      <article></article>
      <input type="number">

      <!-- Comment node -->

      <div id="ids">
          <!-- Comment node -->

          <div></div>
          <div id="inner-id"></div>
          <div id="__proto__"></div>
          <div id="#&quot;ridiculous&quot;.id"></div>
          <div id="'quoted.value'"></div>
          <div id=".foo.bar"></div>
          <div id="-"></div>
          <div id="-a"></div>
          <div id="-0"></div>
          <div id="7"></div>
          <div id="&#x438;&#x434;">&#x438;&#x434;</div>
          <div id="#"></div>
          <div id="#foo"></div>
          <div id="##"></div>
          <div id="#.#.#"></div>
          <div id="_"></div>
          <div id="{}"></div>
          <div id=".fake-class"></div>
          <div id="foo.bar"></div>
          <div id=":hover"></div>
          <div id=":hover:focus:active"></div>
          <div id="[attr=value]"></div>
          <div id="f/o/o"></div>
          <div id="f\o\o"></div>
          <div id="f*o*o"></div>
          <div id="f!o!o"></div>
          <div id="f'o'o"></div>
          <div id="f~o~o"></div>
          <div id="f+o+o"></div>
          <input type="text" id="input-id">
          <input type="text">
          <input type="something-invalid-'-&quot;-and-weird">
          <p></p>
      </div>

      <div id="classes">
          <!-- Comment node 1 -->
          <div class="foo bar"></div>
          <!-- Comment node 2 -->
          <div class=" foo foo "></div>
          <div class=".foo"></div>
          <div class=".foo.bar"></div>
          <div class="-"></div>
          <div class="-a"></div>
          <div class="-0"></div>
          <div class="--a"></div>
          <div class="---a"></div>
          <div class="7"></div>
          <div class="&#x43A;&#x43B;&#x430;&#x441;&#x441;">&#x43A;&#x43B;&#x430;&#x441;&#x441;</div>
          <div class="__proto__"></div>
          <div class="__proto__ foo"></div>
          <div class="#"></div>
          <div class="#foo"></div>
          <div class="##"></div>
          <div class="#.#.#"></div>
          <div class="_"></div>
          <div class="{}"></div>
          <div class=":hover"></div>
          <div class=":hover:focus:active"></div>
          <div class="[attr=value]"></div>
          <div class="f/o/o"></div>
          <div class="f\o\o"></div>
          <div class="f*o*o"></div>
          <div class="f!o!o"></div>
          <div class="f'o'o"></div>
          <div class="f~o~o"></div>
          <div class="f+o+o"></div>
          <span class="bar"></span>
          <div id="id-with-class" class="moo"></div>
          <input type="text" class="input-class-one">
          <input type="text" class="input-class-two">
          <!-- Comment node 3 -->
      </div>

      <div id="non-unique-classes">
        <!-- Comment node 1 -->
        <span class="c1"></span>
        <!-- Comment node 2 -->
        <span class="c1"></span>
        <!-- Comment node 3 -->
        <span class="c1 c2"></span>
        <!-- Comment node 4 -->
        <span class="c1 c2 c3"></span>
        <!-- Comment node 5 -->
        <span></span>
        <!-- Comment node 6 -->
        <div class="c1"></div>
        <!-- Comment node 7 -->
        <div class="c1 c2"></div>
        <!-- Comment node 8 -->
        <div class="c3 c2"></div>
        <!-- Comment node 9 -->
        <div class="c3 c4"></div>
        <!-- Comment node 10 -->
        <div class="c1 c4"></div>
        <!-- Comment node 11 -->
        <input type="text" class="input-class">
        <input type="text" class="input-class">
        <div></div>
      </div>
    `);
  await TestRunner.evaluateInPagePromise(`
      function matchingElements(selector) {
        return document.querySelectorAll(selector).length;
      }
  `);

  var nodeQueue = [];
  ElementsTestRunner.expandElementsTree(enqueueNodes);

  function enqueueNodes() {
    enqueueNode('', ElementsTestRunner.getDocumentElement());
    dumpNodeData();
  }

  function dumpNodeData() {
    var entry = nodeQueue.shift();
    if (!entry) {
      TestRunner.completeTest();
      return;
    }
    var cssPath = ElementsModule.DOMPath.cssPath(entry.node, true);
    var result = entry.prefix + cssPath;
    TestRunner.addResult(result.replace(/\n/g, '\\n'));
    TestRunner.evaluateInPage('matchingElements(' + JSON.stringify(cssPath) + ')', callback);

    function callback(result) {
      TestRunner.assertEquals(1, result);
      dumpNodeData();
    }
  }

  function enqueueNode(prefix, node) {
    if (node.nodeType() === Node.ELEMENT_NODE)
      nodeQueue.push({prefix: prefix, node: node});
    var children = node.children();
    for (var i = 0; children && i < children.length; ++i)
      enqueueNode(prefix + '  ', children[i]);
  }
})();