tag | 8114045d0319def0c7d3eec2c463059eae6c5e33 | |
---|---|---|
tagger | Bob Nystrom <robert@stuffwithstuff.com> | Fri Jul 13 17:02:34 2018 -0700 |
object | b703d0c4fed4c57ac4d2c0637b2b34474d22e14a |
1.0.1
commit | b703d0c4fed4c57ac4d2c0637b2b34474d22e14a | [log] [tgz] |
---|---|---|
author | Bob Nystrom <robert@stuffwithstuff.com> | Fri Jul 13 16:52:21 2018 -0700 |
committer | GitHub <noreply@github.com> | Fri Jul 13 16:52:21 2018 -0700 |
tree | 7919efcca1bbe7880978cdda999592fc6f46e82e | |
parent | 0e339e44b00511a6734c8f4a982f9f2c4984a7c6 [diff] | |
parent | f3fcaf94ca126506054d98071e179f57ca186c48 [diff] |
Merge pull request #6 from dart-lang/fix-dart-2 Fix to use lowercase Dart 2 core library constant names.
This package provides a Clock
class which encapsulates the notion of the “current time” and provides easy access to points relative to the current time. Different Clock
s can have a different notion of the current time, and the default top-level clock
's notion can be swapped out to reliably test timing-dependent code.
For example, you can use clock
in your libraries like this:
// run_with_timing.dart import 'package:clock/clock.dart'; /// Runs [callback] and prints how long it took. T runWithTiming<T>(T callback()) { var stopwatch = clock.stopwatch()..start(); var result = callback(); print("It took ${stopwatch.elapsed}!"); return result; }
...and then test your code using the fake_async
package, which automatically overrides the current clock:
// run_with_timing_test.dart import 'run_with_timing.dart'; import 'package:fake_async/fake_async.dart'; import 'package:test/test.dart'; void main() { test("runWithTiming() prints the elapsed time", () { new FakeAsync().run((async) { expect(() { runWithTiming(() { async.elapse(new Duration(seconds: 10)); }); }, prints("It took 0:00:10.000000!")); }); }); }