Upstream version 9.38.198.0
[platform/framework/web/crosswalk.git] / src / third_party / WebKit / LayoutTests / w3c / web-platform-tests / custom-elements / registering-custom-elements / definition-construction-algorithm-type-name-lowercased.html
1 <!DOCTYPE html>
2 <html>
3 <head>
4 <title>Custom element type should be converted to lower case</title>
5 <meta name="author" title="Sergey G. Grekhov" href="mailto:sgrekhov@unipro.ru">
6 <meta name="assert" content="Custom element type should be lowercased">
7 <link rel="help" href="http://www.w3.org/TR/custom-elements/#registering-custom-elements">
8 <script src="../../../../resources/testharness.js"></script>
9 <script src="../../../../resources/testharnessreport.js"></script>
10 <script src="../testcommon.js"></script>
11 <link rel="stylesheet" href="../../../../resources/testharness.css">
12 </head>
13 <body>
14 <div id="log"></div>
15 <script>
16 test(function() {
17     var doc = newHTMLDocument();
18     var GeneratedConstructor = doc.registerElement('X-A');
19     var customElement = new GeneratedConstructor();
20
21     assert_equals(customElement.localName, 'x-a', 'Custom element type should be lowercased');
22 }, 'Custom element type should be lowercased. Test constructor');
23
24
25 test(function() {
26     var doc = newHTMLDocument();
27     HTML5_ELEMENTS.forEach(function(tagName) {
28         var obj = doc.createElement(tagName);
29         var name = 'x-a-' + tagName;
30         var proto = Object.create(obj.constructor.prototype);
31         var GeneratedConstructor = doc.registerElement(name, {
32             prototype: proto,
33             extends: tagName.toUpperCase()
34         });
35         var customElement = new GeneratedConstructor();
36
37         assert_equals(customElement.localName, tagName, 'Local name should be lowercased');
38     });
39 }, 'Custom element type should be lowercased. Test constructor of extended HTML element');
40 </script>
41 </body>
42 </html>