chromium/third_party/blink/web_tests/svg/custom/svg-getelementid.xhtml

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<script src="../../resources/js-test.js"/>
</head>
<body>

<div id="console"/>

<div id="foo"/>
<div id="bar"/>

<svg id="svg-root" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
  <g id="test-body-content">
    <defs>
      <rect id="rect"/>
    </defs>
    <svg id="svgTree1">
      <rect id="subElem1"/>
    </svg>
    <svg>
      <rect id="subElem2"/>
    </svg>
    <svg id="svgTree3">
      <use xlink:href="#rect"/>
    </svg>
    <svg id="svgTree4">
      <rect id="foo"/>
    </svg>
    <svg id="svgTree5">
      <rect id="bar"/>
      <rect id="bar"/>
    </svg>
    <rect id="siblingElem1"/>
    <foreignObject id="foreign">
      <div id="nonsvg"/>
    </foreignObject>
  </g>
</svg>

<div id="foo"/>

<script><![CDATA[
  if (window.testRunner)
    testRunner.dumpAsText();
  var svgTree1 = document.getElementById("svgTree1");

  // Test support for "getElementById" on svgTree1
  var subElem1 = svgTree1.getElementById("subElem1");
  shouldBeTrue("null != subElem1");
  shouldBe(subElem1.id, "subElem1");

  // Test that "getElementById" on svgTree1 can't access children in other subtrees
  shouldBeTrue("null == svgTree1.getElementById('subElem2')");

  // Test that "getElementById" on svgTree1 can't access elements that are not its children
  shouldBeTrue("null == svgTree1.getElementById('siblingElem1')");

  // Test that an element outside of the subtree referenced through <use> is not found
  var svgTree3 = document.getElementById("svgTree3");
  shouldBeTrue("null == svgTree3.getElementById('rect')");

  // Test that the <svg> being searched on is not found itself
  shouldBeTrue("null == svgTree3.getElementById('svgTree3')");

  // Test that search in svg returns the id from the subtree, not the div with the same id
  var root = document.getElementById("svg-root");
  var svgTree4 = document.getElementById("svgTree4");
  shouldBeTrue("svgTree4.firstChild.nextSibling == root.getElementById('foo')");

  // Test that search in svg subtree returns the first of the duplicates, not the div with the same id
  var svgTree5 = document.getElementById("svgTree5");
  var bar = root.getElementById("bar");
  shouldBeTrue("svgTree5.firstChild.nextSibling == bar");

  // Test that search in svg subtree returns the first of the duplicates
  shouldBeTrue("svgTree5.firstChild.nextSibling == svgTree5.getElementById('bar')");

  // Test that non SVG content can be found in the svg subtree
  var nonsvg = root.getElementById("nonsvg");
  var foreign = root.getElementById("foreign");
  shouldBeTrue("foreign.firstChild.nextSibling == nonsvg");

  // Test that SVG element can find child elements when svg is not part of document yet
  var orphanSvg = document.createElementNS('http://www.w3.org/2000/svg', 'svg');
  var childSvg = document.createElementNS('http://www.w3.org/2000/svg', 'g');
  orphanSvg.appendChild(childSvg)
  childSvg.id = 'fooSvg2'
  shouldBeTrue("childSvg == orphanSvg.getElementById('fooSvg2')");
]]></script>

</body>
</html>