summaryrefslogtreecommitdiffstats
path: root/dom/svg/test/test_pointer-events-6.xhtml
blob: e6e40aedb1b4fd72b818741f136abc46555dab2c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
<html xmlns="http://www.w3.org/1999/xhtml">
<!--
https://bugzilla.mozilla.org/show_bug.cgi?id=500174
-->
<head>
  <title>Test pointer events for clip-path on non-SVG elements</title>
  <script src="/tests/SimpleTest/SimpleTest.js"></script>
  <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" />
</head>
<body onload="run()">
<script class="testbody" type="text/javascript">
<![CDATA[

SimpleTest.waitForExplicitFinish();

function run() {
  var div = document.getElementById("div");
  // Get the coords of the origin of the SVG canvas:
  var originX = div.offsetLeft;
  var originY = div.offsetTop;
  var elementFromPoint;

  elementFromPoint = document.elementFromPoint(originX + 18, originY + 30);
  isnot(elementFromPoint, div, "Outside left edge of clipped area");

  elementFromPoint = document.elementFromPoint(originX + 22, originY + 30);
  is(elementFromPoint, div, "Inside left edge of clipped area");

  elementFromPoint = document.elementFromPoint(originX + 30, originY + 18);
  isnot(elementFromPoint, div, "Outside top edge of clipped area");

  elementFromPoint = document.elementFromPoint(originX + 30, originY + 22);
  is(elementFromPoint, div, "Inside top edge of clipped area");

  elementFromPoint = document.elementFromPoint(originX + 42, originY + 30);
  isnot(elementFromPoint, div, "Outside right edge of clipped area");

  elementFromPoint = document.elementFromPoint(originX + 38, originY + 30);
  is(elementFromPoint, div, "Inside right edge of clipped area");

  elementFromPoint = document.elementFromPoint(originX + 30, originY + 42);
  isnot(elementFromPoint, div, "Outside bottom edge of clipped area");

  elementFromPoint = document.elementFromPoint(originX + 30, originY + 38);
  is(elementFromPoint, div, "Inside bottom edge of clipped area");

  SimpleTest.finish();
}

]]>
</script>
<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=500174">Mozilla Bug 500174</a>
<p id="display"></p>
<div id="content">

  <svg xmlns="http://www.w3.org/2000/svg" width="100%" height="100%" id="svg">
    <defs>
      <clipPath id="clip">
        <rect x="20" y="20" width="20" height="20"/>
      </clipPath>
    </defs>
  </svg>
  <div id="div" style="width:100px; height:100px; clip-path:url(#clip)"></div>

</div>
<pre id="test">
</pre>
</body>
</html>