| OLD | NEW |
| 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file |
| 2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
| 3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
| 4 | 4 |
| 5 library multiple_timer_test; | 5 library multiple_timer_test; |
| 6 | 6 |
| 7 import 'dart:isolate'; | 7 import 'dart:isolate'; |
| 8 import 'dart:async'; | 8 import 'dart:async'; |
| 9 import 'package:unittest/unittest.dart'; | 9 import 'package:unittest/unittest.dart'; |
| 10 | 10 |
| 11 const Duration TIMEOUT = const Duration(milliseconds: 100); | 11 const Duration TIMEOUT = const Duration(milliseconds: 100); |
| 12 | 12 |
| 13 // Some browsers (Firefox and IE so far) can trigger too early. Add a safety | 13 // Some browsers (Firefox and IE so far) can trigger too early. Add a safety |
| 14 // margin. We use identical(1, 1.0) as an easy way to know if the test is | 14 // margin. We use identical(1, 1.0) as an easy way to know if the test is |
| 15 // compiled by dart2js. | 15 // compiled by dart2js. |
| 16 int get safetyMargin => identical(1, 1.0) ? 100 : 0; | 16 int get safetyMargin => identical(1, 1.0) ? 100 : 0; |
| 17 | 17 |
| 18 createTimer(replyTo) { | 18 createTimer(replyTo) { |
| 19 new Timer(TIMEOUT, () { | 19 new Timer(TIMEOUT, () { |
| 20 replyTo.send("timer_fired"); | 20 replyTo.send("timer_fired"); |
| 21 }); | 21 }); |
| 22 } | 22 } |
| 23 | 23 |
| 24 main() { | 24 main() { |
| 25 test("timer in isolate", () { | 25 test("timer in isolate", () { |
| 26 int startTime; | 26 Stopwatch stopwatch = new Stopwatch(); |
| 27 int endTime; | |
| 28 | |
| 29 ReceivePort port = new ReceivePort(); | 27 ReceivePort port = new ReceivePort(); |
| 30 | 28 |
| 31 port.first.then(expectAsync((msg) { | 29 port.first.then(expectAsync((msg) { |
| 32 expect("timer_fired", msg); | 30 expect("timer_fired", msg); |
| 33 int endTime = (new DateTime.now()).millisecondsSinceEpoch; | 31 expect(stopwatch.elapsedMilliseconds + safetyMargin, |
| 34 expect(endTime - startTime + safetyMargin, greaterThanOrEqualTo(TIMEOUT.in
Milliseconds)); | 32 greaterThanOrEqualTo(TIMEOUT.inMilliseconds)); |
| 35 })); | 33 })); |
| 36 | 34 |
| 37 startTime = (new DateTime.now()).millisecondsSinceEpoch; | 35 stopwatch.start(); |
| 38 var remote = Isolate.spawn(createTimer, port.sendPort); | 36 var remote = Isolate.spawn(createTimer, port.sendPort); |
| 39 }); | 37 }); |
| 40 } | 38 } |
| OLD | NEW |