| Index: tests/lib_strong/async/multiple_timer_test.dart
|
| diff --git a/tests/lib_strong/async/multiple_timer_test.dart b/tests/lib_strong/async/multiple_timer_test.dart
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..00580b99b4605594efdf0e713bacf4849061e0d7
|
| --- /dev/null
|
| +++ b/tests/lib_strong/async/multiple_timer_test.dart
|
| @@ -0,0 +1,74 @@
|
| +// Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
|
| +// for details. All rights reserved. Use of this source code is governed by a
|
| +// BSD-style license that can be found in the LICENSE file.
|
| +
|
| +library multiple_timer_test;
|
| +
|
| +import 'dart:async';
|
| +import 'package:unittest/unittest.dart';
|
| +
|
| +const Duration TIMEOUT1 = const Duration(seconds: 1);
|
| +const Duration TIMEOUT2 = const Duration(seconds: 2);
|
| +const Duration TIMEOUT3 = const Duration(milliseconds: 500);
|
| +const Duration TIMEOUT4 = const Duration(milliseconds: 1500);
|
| +
|
| +// The stopwatch is more precise than the Timer.
|
| +// Some browsers (Firefox and IE so far) can trigger too early. So we add more
|
| +// margin. We use identical(1, 1.0) as an easy way to know if the test is
|
| +// compiled by dart2js.
|
| +int get safetyMargin => identical(1, 1.0) ? 100 : 0;
|
| +
|
| +main() {
|
| + test("multiple timer test", () {
|
| + Stopwatch _stopwatch1 = new Stopwatch();
|
| + Stopwatch _stopwatch2 = new Stopwatch();
|
| + Stopwatch _stopwatch3 = new Stopwatch();
|
| + Stopwatch _stopwatch4 = new Stopwatch();
|
| + List<int> _order;
|
| + int _message;
|
| +
|
| + void timeoutHandler1() {
|
| + expect(_stopwatch1.elapsedMilliseconds + safetyMargin,
|
| + greaterThanOrEqualTo(TIMEOUT1.inMilliseconds));
|
| + expect(_order[_message], 0);
|
| + _message++;
|
| + }
|
| +
|
| + void timeoutHandler2() {
|
| + expect(_stopwatch2.elapsedMilliseconds + safetyMargin,
|
| + greaterThanOrEqualTo(TIMEOUT2.inMilliseconds));
|
| + expect(_order[_message], 1);
|
| + _message++;
|
| + }
|
| +
|
| + void timeoutHandler3() {
|
| + expect(_stopwatch3.elapsedMilliseconds + safetyMargin,
|
| + greaterThanOrEqualTo(TIMEOUT3.inMilliseconds));
|
| + expect(_order[_message], 2);
|
| + _message++;
|
| + }
|
| +
|
| + void timeoutHandler4() {
|
| + expect(_stopwatch4.elapsedMilliseconds + safetyMargin,
|
| + greaterThanOrEqualTo(TIMEOUT4.inMilliseconds));
|
| + expect(_order[_message], 3);
|
| + _message++;
|
| + }
|
| +
|
| + _order = new List<int>(4);
|
| + _order[0] = 2;
|
| + _order[1] = 0;
|
| + _order[2] = 3;
|
| + _order[3] = 1;
|
| + _message = 0;
|
| +
|
| + _stopwatch1.start();
|
| + new Timer(TIMEOUT1, expectAsync(timeoutHandler1));
|
| + _stopwatch2.start();
|
| + new Timer(TIMEOUT2, expectAsync(timeoutHandler2));
|
| + _stopwatch3.start();
|
| + new Timer(TIMEOUT3, expectAsync(timeoutHandler3));
|
| + _stopwatch4.start();
|
| + new Timer(TIMEOUT4, expectAsync(timeoutHandler4));
|
| + });
|
| +}
|
|
|