OLD | NEW |
1 <!DOCTYPE html> | 1 <!DOCTYPE html> |
2 <!-- | 2 <!-- |
3 Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 3 Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file |
4 for details. All rights reserved. Use of this source code is governed by a | 4 for details. All rights reserved. Use of this source code is governed by a |
5 BSD-style license that can be found in the LICENSE file. | 5 BSD-style license that can be found in the LICENSE file. |
6 --> | 6 --> |
7 <html lang="en"> | 7 <html lang="en"> |
8 <head> | 8 <head> |
9 <!-- | 9 <!-- |
10 This test runs the TodoMVC app, adds a few todos, marks some as done | 10 This test runs the TodoMVC app, adds a few todos, marks some as done |
(...skipping 17 matching lines...) Expand all Loading... |
28 main() { | 28 main() { |
29 Timer.run(() { | 29 Timer.run(() { |
30 useShadowDom = false; | 30 useShadowDom = false; |
31 app.todos.add(new Todo('one (unchecked)')); | 31 app.todos.add(new Todo('one (unchecked)')); |
32 app.todos.add(new Todo('two (unchecked)')); | 32 app.todos.add(new Todo('two (unchecked)')); |
33 app.todos.add(new Todo('three (checked)')..done = true); | 33 app.todos.add(new Todo('three (checked)')..done = true); |
34 app.todos.add(new Todo('four (checked)')); | 34 app.todos.add(new Todo('four (checked)')); |
35 deliverChangesSync(); | 35 deliverChangesSync(); |
36 | 36 |
37 // To ensure we click in the correct place, we calculate x, y offset where | 37 // To ensure we click in the correct place, we calculate x, y offset where |
38 // we want to click based on the coordinates given by DumpRenderTree, and | 38 // we want to click based on the coordinates given by content shell, and |
39 // then adapt those offset in the current window. This makes is possible to | 39 // then adapt those offset in the current window. This makes is possible to |
40 // debug the application in Dartium reliably. | 40 // debug the application in Dartium reliably. |
41 | 41 |
42 var bounding = document.body.getBoundingClientRect(); | 42 var bounding = document.body.getBoundingClientRect(); |
43 // The x, y location of body in the DumpRenderTree output was: (117, 130) | 43 // The x, y location of body in the content shell output was: (117, 130) |
44 // and location of the node we want to click was: (119, 398) | 44 // and location of the node we want to click was: (119, 398) |
45 int x = bounding.left.toInt() + (119 - 117); | 45 int x = bounding.left.toInt() + (119 - 117); |
46 int y = bounding.top.toInt() + (398 - 130); | 46 int y = bounding.top.toInt() + (398 - 130); |
47 var node = document.elementFromPoint(x, y); | 47 var node = document.elementFromPoint(x, y); |
48 expect(node is InputElement, isTrue, | 48 expect(node is InputElement, isTrue, |
49 reason: '$x, $y points to a checkbox'); | 49 reason: '$x, $y points to a checkbox'); |
50 expect(node.checked, isFalse, reason: 'element is unchecked'); | 50 expect(node.checked, isFalse, reason: 'element is unchecked'); |
51 Element parent = node.parent; | 51 Element parent = node.parent; |
52 expect(parent.query('label').text, equals('four (checked)')); | 52 expect(parent.query('label').text, equals('four (checked)')); |
53 node.dispatchEvent(new MouseEvent('click', detail: 1)); | 53 node.dispatchEvent(new MouseEvent('click', detail: 1)); |
54 expect(node.checked, isTrue, reason: 'element is checked'); | 54 expect(node.checked, isTrue, reason: 'element is checked'); |
55 | 55 |
56 // Ideally the test above would work also with shadow DOM (pending that | 56 // Ideally the test above would work also with shadow DOM (pending that |
57 // 'elementFromPoint' is fixed to return also nodes under the shadow DOM). | 57 // 'elementFromPoint' is fixed to return also nodes under the shadow DOM). |
58 // The next extra check is only valid when polyfilling the shadow DOM: | 58 // The next extra check is only valid when polyfilling the shadow DOM: |
59 expect(node, same(document.queryAll('input[type=checkbox]')[4])); | 59 expect(node, same(document.queryAll('input[type=checkbox]')[4])); |
60 | 60 |
61 window.postMessage('done', '*'); | 61 window.postMessage('done', '*'); |
62 }); | 62 }); |
63 } | 63 } |
64 </script> | 64 </script> |
65 </body> | 65 </body> |
66 </html> | 66 </html> |
OLD | NEW |