mirror of
https://github.com/dart-lang/sdk
synced 2024-09-16 04:06:59 +00:00
b101a7d002
Change-Id: Ib33169c3e0ffc870915c189404074a1dea472546 Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/196548 Reviewed-by: Bob Nystrom <rnystrom@google.com> Commit-Queue: Leaf Petersen <leafp@google.com>
48 lines
1.4 KiB
Dart
48 lines
1.4 KiB
Dart
// 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.
|
|
|
|
// @dart = 2.9
|
|
|
|
library timer_repeat_test;
|
|
|
|
import 'dart:async';
|
|
|
|
import 'package:expect/expect.dart';
|
|
|
|
const Duration TIMEOUT = const Duration(milliseconds: 500);
|
|
const int ITERATIONS = 5;
|
|
|
|
Timer timer;
|
|
Stopwatch stopwatch = new Stopwatch();
|
|
int iteration;
|
|
|
|
// Some browsers (Firefox and IE so far) can trigger too early. Add a safety
|
|
// 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;
|
|
|
|
var completer = new Completer();
|
|
|
|
void timeoutHandler(Timer timer) {
|
|
iteration++;
|
|
Expect.isTrue(iteration <= ITERATIONS);
|
|
if (iteration == ITERATIONS) {
|
|
// When we are done with all of the iterations, we expect a
|
|
// certain amount of time to have passed. Checking the time on
|
|
// each iteration doesn't work because the timeoutHandler runs
|
|
// concurrently with the periodic timer.
|
|
Expect.isTrue(stopwatch.elapsedMilliseconds + safetyMargin >=
|
|
ITERATIONS * TIMEOUT.inMilliseconds);
|
|
timer.cancel();
|
|
completer.complete();
|
|
}
|
|
}
|
|
|
|
main() {
|
|
iteration = 0;
|
|
stopwatch.start();
|
|
timer = new Timer.periodic(TIMEOUT, timeoutHandler);
|
|
return completer.future;
|
|
}
|