mirror of
https://github.com/dart-lang/sdk
synced 2024-09-16 04:37:12 +00:00
a2b556b937
Change-Id: Ia5c41dda6503e1fbb8cc6099835d07588425e2ba Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/128310 Commit-Queue: Bob Nystrom <rnystrom@google.com> Auto-Submit: Bob Nystrom <rnystrom@google.com> Reviewed-by: Lasse R.H. Nielsen <lrn@google.com>
38 lines
1.1 KiB
Dart
38 lines
1.1 KiB
Dart
// Copyright (c) 2011, 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 timer_test;
|
|
|
|
import 'dart:async';
|
|
import 'package:expect/expect.dart';
|
|
import 'package:async_helper/async_helper.dart';
|
|
|
|
const ms = const Duration(milliseconds: 1);
|
|
|
|
expectGTE(min, actual, msg) {
|
|
if (actual >= min) return;
|
|
Expect.fail(msg.replaceAll('{0}', "$min").replaceAll('{1}', "$actual"));
|
|
}
|
|
|
|
main() {
|
|
int interval = 20;
|
|
asyncStart();
|
|
var sw = new Stopwatch()..start();
|
|
int nextTick = 1;
|
|
new Timer.periodic(ms * interval, (t) {
|
|
expectGTE(nextTick, t.tick, "tick {1} before expect next tick {0}.");
|
|
int time = sw.elapsedMilliseconds;
|
|
int minTime = interval * t.tick;
|
|
expectGTE(minTime, time, "Actual time {1} before {0} at tick ${t.tick}");
|
|
while (sw.elapsedMilliseconds < time + 3 * interval) {
|
|
// idle.
|
|
}
|
|
nextTick = t.tick + 2; // At least increment by two, probably more.
|
|
if (t.tick > 20) {
|
|
t.cancel();
|
|
asyncEnd();
|
|
}
|
|
});
|
|
}
|