OLD | NEW |
1 <!DOCTYPE html> | 1 <!DOCTYPE html> |
2 <html> | 2 <html> |
3 <head> | 3 <head> |
4 <script src="resources/js-test-pre.js"></script> | 4 <script src="resources/js-test-pre.js"></script> |
5 </head> | 5 </head> |
6 <body> | 6 <body> |
7 <div id="description"></div> | 7 <div id="description"></div> |
8 <div id="console"></div> | 8 <div id="console"></div> |
9 <script> | 9 <script> |
10 description('Test Promise.'); | 10 description('Test Promise.'); |
11 | 11 |
12 window.jsTestIsAsync = true; | 12 window.jsTestIsAsync = true; |
13 var callback; | |
14 var value = { | 13 var value = { |
15 then: function(fulfillCallback, rejectCallback) { | 14 then: function(fulfillCallback, rejectCallback) { |
16 testPassed('value.then is called.'); | 15 testPassed('value.then is called.'); |
17 window.thisValue = this; | 16 window.thisValue = this; |
18 shouldBe('thisValue', 'value'); | 17 shouldBe('thisValue', 'value'); |
19 callback = fulfillCallback; | 18 fulfillCallback('hello'); |
20 } | 19 } |
21 }; | 20 }; |
22 finishJSTest(); | |
23 var promise = new Promise(function(resolve) { resolve(value); }); | 21 var promise = new Promise(function(resolve) { resolve(value); }); |
24 | 22 |
25 promise.then(function(result) { | 23 promise.then(function(result) { |
26 testPassed('fulfilled'); | 24 testPassed('fulfilled'); |
27 window.result = result; | 25 window.result = result; |
28 shouldBeEqualToString('result', 'hello'); | 26 shouldBeEqualToString('result', 'hello'); |
29 finishJSTest(); | 27 finishJSTest(); |
30 }, function() { | 28 }, function() { |
31 testFailed('rejected'); | 29 testFailed('rejected'); |
32 finishJSTest(); | 30 finishJSTest(); |
33 }); | 31 }); |
34 | 32 |
35 debug('The promise is not fulfilled now.'); | 33 debug('The promise is not fulfilled now.'); |
36 | 34 |
37 callback('hello'); | |
38 </script> | 35 </script> |
39 <script src="resources/js-test-post.js"></script> | 36 <script src="resources/js-test-post.js"></script> |
40 </body> | 37 </body> |
41 </html> | 38 </html> |
OLD | NEW |