Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 <!DOCTYPE html> | 1 <!DOCTYPE html> |
| 2 <title>Custom Elements: Insert a node should try to upgrade</title> | 2 <title>Custom Elements: Insert a node should try to upgrade</title> |
| 3 <script src="../../resources/testharness.js"></script> | 3 <script src="../../resources/testharness.js"></script> |
| 4 <script src="../../resources/testharnessreport.js"></script> | 4 <script src="../../resources/testharnessreport.js"></script> |
| 5 <script src="resources/custom-elements-helpers.js"></script> | 5 <script src="resources/custom-elements-helpers.js"></script> |
| 6 <body> | 6 <body> |
| 7 <script> | 7 <script> |
| 8 'use strict'; | 8 'use strict'; |
| 9 | 9 |
| 10 // Insert a node | 10 // Insert a node |
| 11 // https://dom.spec.whatwg.org/#concept-node-insert | 11 // https://dom.spec.whatwg.org/#concept-node-insert |
| 12 // 6.5.2.1 If inclusiveDescendant is custom, then enqueue a custom element callb ack reaction | |
| 13 // with inclusiveDescendant, callback name "connectedCallback", and an empty arg ument list. | |
| 14 test_with_window(w => { | |
| 15 let element = w.document.createElement('a-a'); | |
| 16 let invocations = []; | |
| 17 let connectedCallback_args; | |
| 18 w.customElements.define('a-a', class extends w.HTMLElement { | |
| 19 constructor() { super(); } | |
|
dominicc (has gone to gerrit)
2016/07/13 06:19:06
You can omit this line; I think an ES6 class gets
| |
| 20 connectedCallback() { | |
| 21 invocations.push(['connected', this]); | |
| 22 connectedCallback_args = arguments; | |
| 23 } | |
| 24 }); | |
| 25 w.document.body.appendChild(element); | |
| 26 assert_true(element.matches(':defined')); | |
| 27 w.document.body.appendChild(element); | |
| 28 assert_equals(invocations.length, 1, 'connectedCallback should be invoked only once'); | |
|
dominicc (has gone to gerrit)
2016/07/13 06:19:05
Could you also assert the length is 1 before line
| |
| 29 assert_array_equals(invocations[0], ['connected', element], 'insierting "custo m" element should enqueue a connectedCallback reaction'); | |
|
dominicc (has gone to gerrit)
2016/07/13 06:19:05
Spelling--inserting
| |
| 30 assert_array_equals(connectedCallback_args, [], 'connectedCallback should be i nvoked with empty argument list'); | |
| 31 }, 'Insert a node that is "custom" should enqueue connectedCallback'); | |
| 32 | |
| 12 // 6.5.2.2. try to upgrade inclusiveDescendant. | 33 // 6.5.2.2. try to upgrade inclusiveDescendant. |
| 13 // Try to upgrade an element | 34 // Try to upgrade an element |
| 14 // https://html.spec.whatwg.org/multipage/scripting.html#concept-try-upgrade | 35 // https://html.spec.whatwg.org/multipage/scripting.html#concept-try-upgrade |
| 15 test_with_window(w => { | 36 test_with_window(w => { |
| 16 let element = w.document.createElement('a-a'); | 37 let element = w.document.createElement('a-a'); |
| 17 | 38 |
| 18 w.customElements.define('a-a', class extends w.HTMLElement { | 39 w.customElements.define('a-a', class extends w.HTMLElement { |
| 19 constructor() { | 40 constructor() { |
| 20 super(); | 41 super(); |
| 21 this.is_upgraded = true; | 42 this.is_upgraded = true; |
| 22 } | 43 } |
| 23 }); | 44 }); |
| 24 assert_false('is_upgraded' in element); | 45 assert_false('is_upgraded' in element); |
| 25 assert_false(element.matches(':defined')); | 46 assert_false(element.matches(':defined')); |
| 26 | 47 |
| 27 w.document.body.appendChild(element); | 48 w.document.body.appendChild(element); |
| 28 assert_true(element.is_upgraded); | 49 assert_true(element.is_upgraded); |
| 29 assert_true(element.matches(':defined')); | 50 assert_true(element.matches(':defined')); |
| 30 }, 'Insert a node should try to upgrade'); | 51 }, 'Insert a node should try to upgrade'); |
| 31 </script> | 52 </script> |
| 32 </body> | 53 </body> |
| OLD | NEW |