Merge Chromium + Blink git repositories
[chromium-blink-merge.git] / third_party / WebKit / LayoutTests / fast / dom / Element / setAttributeNode-case-insensitivity.html
blob700417ebbffdbf8c1566d76eae6e2fcc3354d5e1
1 <!DOCTYPE html>
2 <html>
3 <head>
4 <script src="../../../resources/js-test.js"></script>
5 <script>
6 var oldStyleAttr;
7 var resultantAttr;
9 function runTest()
11 description("This test verifies that the setAttributeNode() API checks for existing attributes case-insensitively. Thus the value of an existing attribute with the same name but in a different case should get replaced by the new value specified via the setAttributeNode() method.");
13 var test = document.getElementById("test");
14 var newStyleAttr = document.createAttribute("STYLE");
15 newStyleAttr.value = "background-color: green";
16 oldStyleAttr = test.getAttributeNode("style");
17 resultantAttr = test.setAttributeNode(newStyleAttr);
18 if (window.testRunner) {
19 shouldBe("test.getAttribute('style')", "test.getAttribute('STYLE')");
20 shouldBe("test.getAttributeNode('style').value", "test.getAttributeNode('STYLE').value");
21 shouldBe("resultantAttr", "oldStyleAttr");
22 shouldBeNull("oldStyleAttr.ownerElement");
25 debug("Verifying that attributes with the same name but different namespaces are treated as unique entities. For the following test two different attribute values should be returned.");
26 var newAttr1 = document.createAttributeNS("ns1", "newattr");
27 newAttr1.prefix = "prefix1";
28 newAttr1.value = "newattr1";
29 test.setAttributeNode(newAttr1);
30 var newAttr2 = document.createAttributeNS("ns2", "newattr");
31 newAttr2.prefix = "prefix2";
32 newAttr2.value = "newattr2";
33 test.setAttributeNode(newAttr2);
34 if (window.testRunner) {
35 shouldBe("test.getAttributeNodeNS('ns1', 'newattr').value", "'newattr1'");
36 shouldBe("test.getAttributeNodeNS('ns2', 'newattr').value", "'newattr2'");
39 debug("Verifying that attributes with same name but different case and having same namespaces are treated as same. In the following test the new attribute should overwrite the value of the existing one.");
40 var newAttr3 = document.createAttributeNS("ns1", "NEWATTR");
41 newAttr3.prefix = "prefix2";
42 newAttr3.value = "newattr3";
43 test.setAttributeNode(newAttr3);
45 if (window.testRunner) {
46 shouldBe("test.getAttributeNodeNS('ns1', 'newattr').value", "'newattr3'");
48 isSuccessfullyParsed();
49 test.style.display = 'none';
53 </script>
54 </head>
55 <body onload="runTest()">
56 <div>Test for Bugzilla bug:<a href="https://bugs.webkit.org/show_bug.cgi?id=90341"> 90341:</a> createAttribute/setAttributeNode does not properly normalize case.</div>
57 <div id="test" style="background-color: red">&nbsp;</div>
58 <div id="description"></div>
59 <div id="console"></div>
60 </body>
61 </html>