summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/html/semantics/interactive-elements/the-summary-element/anchor-with-inline-element.html
blob: 6910a5de93c7897f4e3fb1e5122a87cd001d10ad (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
70
71
72
73
74
75
76
77
<!DOCTYPE html>
<meta charset="utf-8">
<title>summary element: clicking on anchor containing inline element</title>
<link rel="author" title="Yu Han" href="mailto:yuzhehan@chromium.org">
<link rel="help" href="https://html.spec.whatwg.org/C/#the-summary-element">
<link rel="help" href="https://html.spec.whatwg.org/multipage/text-level-semantics.html#the-a-element">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>

<details id="details_i">
  <summary>Anchor text is wrapped with &lt;i&gt; tag <a href="#with_i_tag"><i id="with_i">permalink</i></a></summary>
  <p>asdf</p>
</details>

<details id="details_span">
  <summary>This one uses &lt;span&gt;. <a href="#with_span_tag"><span id="with_span">permalink</span></a></summary>
  <p>asdf</p>
</details>

<details id="details_svg">
  <summary>
    <svg style="width: 100px;" viewBox="0 0 100 100" xmlns="http://www.w3.org/2000/svg">
      <a href="#inside_svg_w_circle">
        <circle id="svg_circle" cx="50" cy="40" r="35"/>
      </a>
      <a href="#inside_svg_w_text">
        <text id="svg_text" x="50" y="90" text-anchor="middle">
          &lt;circle&gt;
        </text>
      </a>
    </svg>
  </summary>
  <p>asdf</p>
</details>

<script>
function testClickingOnInlineElement(detailsId, targetId, expected, testName) {
  const details = document.getElementById(detailsId);
  const target = document.getElementById(targetId);
  const test = async_test(testName);

  const promise = new Promise((resolve, reject) => {
    window.onhashchange = test.step_func_done(() => {
      assert_false(details.open);
      assert_equals(location.hash, expected);
      resolve();
    });
  });

  if (target.click) {
    target.click();
  }
  else {
    // svg element don't have click method
    target.dispatchEvent(new MouseEvent('click', {
      view: window,
      bubbles: true,
      cancelable: true
    }));
  }
  return promise;
};

async function testAll() {
  try {
    await testClickingOnInlineElement("details_i", "with_i", "#with_i_tag", "Expected <a> containing <i> to navigate");
    await testClickingOnInlineElement("details_span", "with_span", "#with_span_tag", "Expected <a> containing <span> to navigate");
    await testClickingOnInlineElement("details_svg", "svg_circle", "#inside_svg_w_circle", "Expected <a>, inside svg, containing <circle> to navigate");
    await testClickingOnInlineElement("details_svg", "svg_text", "#inside_svg_w_text", "Expected <a>, inside svg, containing <text> to navigate");
  } catch (exception) {
    assert_unreached("should NOT-THROW exception");
  }
};

var allTests = async_test("Clicking on anchor with embedded inline element should navigate instead of opening details");
testAll().then(()=>{ allTests.done(); });
</script>