OLD | NEW |
1 <!DOCTYPE html> | 1 <!DOCTYPE html> |
2 <script src="../resources/testharness.js"></script> | 2 <script src="../resources/testharness.js"></script> |
3 <script src="../resources/testharnessreport.js"></script> | 3 <script src="../resources/testharnessreport.js"></script> |
4 <script src="../resources/mojo-helpers.js"></script> | 4 <script src="../resources/mojo-helpers.js"></script> |
5 <script src="resources/vibration-helpers.js"></script> | 5 <script src="resources/vibration-helpers.js"></script> |
6 <script> | 6 <script> |
7 | 7 |
8 'use strict'; | 8 'use strict'; |
9 | 9 |
10 if (!window.testRunner) | 10 if (!window.testRunner) |
11 debug('This test cannot be run without the TestRunner'); | 11 debug('This test cannot be run without the TestRunner'); |
12 | 12 |
13 // TODO(leonhsl): Add more test cases http://crbug.com/701288 | 13 // TODO(leonhsl): Add more test cases http://crbug.com/701288 |
14 | 14 |
15 vibration_test(vibration => { | 15 vibration_test(vibration => { |
16 let mockForSubFrame = new vibration.MockVibrationManager; | |
17 let promise = new Promise(resolve => { | 16 let promise = new Promise(resolve => { |
18 let iframe = document.createElement('iframe'); | 17 let iframe = document.createElement('iframe'); |
19 iframe.src = 'resources/vibrate-from-iframe.html'; | 18 iframe.src = 'resources/vibrate-from-iframe.html'; |
20 iframe.onload = () => { | |
21 iframe.contentWindow.gin.define( | |
22 'Mojo Service Registry', ['content/public/renderer/frame_interfaces'], | |
23 (frameInterfaces) => { | |
24 frameInterfaces.addInterfaceOverrideForTesting( | |
25 vibration.VibrationManager.name, handle => { | |
26 mockForSubFrame.bindingSet.addBinding( | |
27 mockForSubFrame, handle); | |
28 }); | |
29 iframe.contentWindow.postMessage('Ready', '*'); | |
30 }); | |
31 }; | |
32 | 19 |
33 document.body.appendChild(iframe); | 20 document.body.appendChild(iframe); |
34 | 21 |
35 window.onmessage = msg => { | 22 window.onmessage = msg => { |
36 if (msg.data === 'Vibrate') { | 23 if (msg.data === 'Vibrate') { |
37 // Navigate the sub frame. | 24 // Navigate the sub frame. |
38 iframe.src = 'about:blank'; | 25 iframe.src = 'about:blank'; |
39 } else if (msg.data === 'Cancel') { | 26 } else if (msg.data === 'Cancel') { |
40 // Cancel is triggered by sub frame navigation on above. | 27 // Cancel is triggered by sub frame navigation on above. |
41 resolve(msg.data); | 28 resolve(msg.data); |
42 } | 29 } |
43 }; | 30 }; |
44 }); | 31 }); |
45 | 32 |
46 return promise.then(msgData => { | 33 return promise.then(msgData => { |
47 assert_equals(msgData, 'Cancel'); | 34 assert_equals(msgData, 'Cancel'); |
48 assert_equals(mockForSubFrame.getDuration(), 1234); | 35 assert_equals(vibration.mockVibrationManager.getDuration(), 1234); |
49 assert_true(mockForSubFrame.isCancelled()); | 36 assert_true(vibration.mockVibrationManager.isCancelled()); |
50 }); | 37 }); |
51 }, 'Iframe reload cancels vibration started by it before.'); | 38 }, 'Iframe reload cancels vibration started by it before.'); |
52 | 39 |
53 vibration_test(vibration => { | 40 vibration_test(vibration => { |
54 let mockForSubFrame = new vibration.MockVibrationManager; | |
55 let promise = new Promise(resolve => { | 41 let promise = new Promise(resolve => { |
56 let iframe = document.createElement('iframe'); | 42 let iframe = document.createElement('iframe'); |
57 iframe.src = 'resources/vibrate-from-iframe.html'; | 43 iframe.src = 'resources/vibrate-from-iframe.html'; |
58 iframe.onload = () => { | |
59 iframe.contentWindow.gin.define( | |
60 'Mojo Service Registry', ['content/public/renderer/frame_interfaces'], | |
61 (frameInterfaces) => { | |
62 frameInterfaces.addInterfaceOverrideForTesting( | |
63 vibration.VibrationManager.name, handle => { | |
64 mockForSubFrame.bindingSet.addBinding( | |
65 mockForSubFrame, handle); | |
66 }); | |
67 iframe.contentWindow.postMessage('Ready', '*'); | |
68 }); | |
69 }; | |
70 | |
71 document.body.appendChild(iframe); | 44 document.body.appendChild(iframe); |
72 | 45 |
73 window.onmessage = msg => { | 46 window.onmessage = msg => { |
74 if (msg.data === 'Vibrate') { | 47 if (msg.data === 'Vibrate') { |
75 // Destroy the sub frame. | 48 // Destroy the sub frame. |
76 document.body.removeChild(iframe); | 49 document.body.removeChild(iframe); |
77 } else if (msg.data === 'Cancel') { | 50 } else if (msg.data === 'Cancel') { |
78 // Cancel is triggered by sub frame destroy on above. | 51 // Cancel is triggered by sub frame destroy on above. |
79 resolve(msg.data); | 52 resolve(msg.data); |
80 } | 53 } |
81 }; | 54 }; |
82 }); | 55 }); |
83 | 56 |
84 return promise.then(msgData => { | 57 return promise.then(msgData => { |
85 assert_equals(msgData, 'Cancel'); | 58 assert_equals(msgData, 'Cancel'); |
86 assert_equals(mockForSubFrame.getDuration(), 1234); | 59 assert_equals(vibration.mockVibrationManager.getDuration(), 1234); |
87 assert_true(mockForSubFrame.isCancelled()); | 60 assert_true(vibration.mockVibrationManager.isCancelled()); |
88 }); | 61 }); |
89 }, 'Iframe destroy cancels vibration started by it before.'); | 62 }, 'Iframe destroy cancels vibration started by it before.'); |
90 | 63 |
91 </script> | 64 </script> |
OLD | NEW |