diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
commit | 6bf0a5cb5034a7e684dcc3500e841785237ce2dd (patch) | |
tree | a68f146d7fa01f0134297619fbe7e33db084e0aa /dom/base/test/test_bug515401.html | |
parent | Initial commit. (diff) | |
download | thunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.tar.xz thunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.zip |
Adding upstream version 1:115.7.0.upstream/1%115.7.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/base/test/test_bug515401.html')
-rw-r--r-- | dom/base/test/test_bug515401.html | 141 |
1 files changed, 141 insertions, 0 deletions
diff --git a/dom/base/test/test_bug515401.html b/dom/base/test/test_bug515401.html new file mode 100644 index 0000000000..a9b0751d8f --- /dev/null +++ b/dom/base/test/test_bug515401.html @@ -0,0 +1,141 @@ +<!DOCTYPE HTML> +<html> +<!-- +https://bugzilla.mozilla.org/show_bug.cgi?id=515401 +--> +<head> + <title>Test for Bug 515401</title> + <script src="/tests/SimpleTest/SimpleTest.js"></script> + <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" /> + <base id=basehref href="base/"> + <base id=basehref2> + <base id=basetarget target="def_target"> +</head> +<body> +<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=515401">Mozilla Bug 515401</a> +<a id=a href="dest.html">Simple link</a> +<a id=awtarget target="a_target">Link with target</a> + +<p id="display"></p> +<pre id="test"> +<script class="testbody" type="text/javascript"> + +var a = $('a'); +var awtarget = $('awtarget'); +var head = document.documentElement.firstElementChild; + +// Test targets +is(a.target, "def_target", "using default target"); +is(awtarget.target, "a_target", "specified target"); +$('basetarget').setAttribute("target", "new_def_target"); +is(a.target, "new_def_target", "using new default target"); +is(awtarget.target, "a_target", "still specified target"); +$('basetarget').removeAttribute("target"); +is(a.target, "", "no target"); +is(awtarget.target, "a_target", "yet still specified target"); +newbasetarget = document.createElement('base'); +newbasetarget.target = "new_target_elem"; +head.appendChild(newbasetarget); +is(a.target, "new_target_elem", "new target element"); +is(awtarget.target, "a_target", "yet still specified target"); +newbasetarget.target = "new_target_elem_value"; +is(a.target, "new_target_elem_value", "new target element attribute"); +is(awtarget.target, "a_target", "yet still specified target"); +newbasetarget.target = ""; +is(a.target, "", "new target element no attribute"); +is(awtarget.target, "a_target", "yet still specified target"); + + +// link hrefs +var basehref = $('basehref'); +var basehref2 = $('basehref2'); +var pre = "http://mochi.test:8888/tests/dom/base/test/"; +function verifyBase(base, test) { + if (base == "") { + is(document.baseURI, document.URL, "document base when " + test); + is(a.href, pre + "dest.html", "link href when " + test); + } + else { + is(document.baseURI, pre + base, "document base when " + test); + is(a.href, pre + base + "dest.html", "link href when " + test); + } +} + + +// In document base +verifyBase("base/", "from markup"); + +// Modify existing <base> +basehref.href = "base2/"; +verifyBase("base2/", "modify existing"); +is(basehref.href, pre + "base2/", "HTMLBaseElement.href resolves correctly"); + +// Modify existing <base> to absolute url +basehref.href = "http://www.example.com/foo/bar.html"; +is(document.baseURI, "http://www.example.com/foo/bar.html", "document base when setting absolute url"); +is(a.href, "http://www.example.com/foo/dest.html", "link href when setting absolute url"); +is(basehref.href, "http://www.example.com/foo/bar.html", + "HTMLBaseElement.href resolves correctly when setting absolute url"); + +// Remove href on existing element +basehref.removeAttribute("href"); +verifyBase("", "remove href on existing element"); + +// Create href on existing element +basehref.href = "base3/"; +verifyBase("base3/", "create href on existing element"); + +// Fall back to second after remove attr +basehref2.href = "base4/"; +verifyBase("base3/", "add href on second base"); +basehref.removeAttribute("href"); +verifyBase("base4/", "fall back to second after remove attr"); + +// Set href on existing again +basehref.href = "base5/"; +verifyBase("base5/", "set href on existing again"); + +// Unset href on second +basehref2.removeAttribute("href"); +verifyBase("base5/", "unset href on second"); + +// Insert base with href before existing +var basehref0 = document.createElement("base"); +basehref0.href = "base6/"; +verifyBase("base5/", "nothing modified"); +head.insertBefore(basehref0, head.firstChild); +verifyBase("base6/", "insert base with href before existing"); + +// Insert base as grandchild of head +var basehref3 = document.createElement("base"); +basehref3.href = "base7/"; +var tmp = document.createElement("head"); +tmp.appendChild(basehref3); +head.insertBefore(tmp, head.firstChild); +verifyBase("base7/", "inserted base as grandchild of head at the beginning of head"); +is(basehref3.parentNode.parentNode, head, "base got inserted correctly"); + +// Remove secondary bases +var tmp, tmp2; +for (tmp = head.firstChild; tmp = tmp.nextSibling; tmp) { + if (tmp.localName == "base" && tmp != basehref0) { + tmp2 = tmp.previousSibling; + head.removeChild(tmp); + tmp = tmp2; + } + verifyBase("base7/", "remove unneeded base"); +} + +// Remove head +document.documentElement.removeChild(head); +verifyBase("", "removed head"); + +// Insert base in body +document.body.insertBefore(basehref3, document.body.firstChild); +verifyBase("base7/", "inserted base in body"); + +</script> +</pre> +</body> +</html> + |