Index: test/codegen/corelib/stopwatch_test.dart |
diff --git a/test/codegen/corelib/stopwatch_test.dart b/test/codegen/corelib/stopwatch_test.dart |
new file mode 100644 |
index 0000000000000000000000000000000000000000..28ec48b10ca77d6d937bd51ed1ba3826c164c3e1 |
--- /dev/null |
+++ b/test/codegen/corelib/stopwatch_test.dart |
@@ -0,0 +1,127 @@ |
+// 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 test program for testing stopwatch support. |
+ |
+library stopwatch_test; |
+import "package:expect/expect.dart"; |
+ |
+class StopwatchTest { |
+ static bool checkTicking(Stopwatch sw) { |
+ Expect.isFalse(sw.isRunning); |
+ sw.start(); |
+ Expect.isTrue(sw.isRunning); |
+ for (int i = 0; i < 1000000; i++) { |
+ int.parse(i.toString()); |
+ if (sw.elapsedTicks > 0) { |
+ break; |
+ } |
+ } |
+ return sw.elapsedTicks > 0; |
+ } |
+ |
+ static bool checkStopping(Stopwatch sw) { |
+ sw.stop(); |
+ Expect.isFalse(sw.isRunning); |
+ int v1 = sw.elapsedTicks; |
+ Expect.isTrue(v1 > 0); // Expect a non-zero elapsed time. |
+ Stopwatch sw2 = new Stopwatch(); // Used for verification. |
+ sw2.start(); |
+ Expect.isTrue(sw2.isRunning); |
+ int sw2LastElapsed = 0; |
+ for (int i = 0; i < 100000; i++) { |
+ int.parse(i.toString()); |
+ int v2 = sw.elapsedTicks; |
+ if (v1 != v2) { |
+ return false; |
+ } |
+ // If sw2 elapsed twice then sw must have advanced too if it wasn't |
+ // stopped. |
+ if (sw2LastElapsed > 0 && sw2.elapsedTicks > sw2LastElapsed) { |
+ break; |
+ } |
+ sw2LastElapsed = sw2.elapsedTicks; |
+ } |
+ // The test only makes sense if measureable time elapsed and elapsed time |
+ // on the stopped Stopwatch did not increase. |
+ Expect.isTrue(sw2.elapsedTicks > 0); |
+ return true; |
+ } |
+ |
+ static checkRestart() { |
+ Stopwatch sw = new Stopwatch(); |
+ Expect.isFalse(sw.isRunning); |
+ sw.start(); |
+ Expect.isTrue(sw.isRunning); |
+ for (int i = 0; i < 100000; i++) { |
+ int.parse(i.toString()); |
+ if (sw.elapsedTicks > 0) { |
+ break; |
+ } |
+ } |
+ sw.stop(); |
+ Expect.isFalse(sw.isRunning); |
+ int initial = sw.elapsedTicks; |
+ sw.start(); |
+ Expect.isTrue(sw.isRunning); |
+ for (int i = 0; i < 100000; i++) { |
+ int.parse(i.toString()); |
+ if (sw.elapsedTicks > initial) { |
+ break; |
+ } |
+ } |
+ sw.stop(); |
+ Expect.isFalse(sw.isRunning); |
+ Expect.isTrue(sw.elapsedTicks > initial); |
+ } |
+ |
+ static checkReset() { |
+ Stopwatch sw = new Stopwatch(); |
+ Expect.isFalse(sw.isRunning); |
+ sw.start(); |
+ Expect.isTrue(sw.isRunning); |
+ for (int i = 0; i < 100000; i++) { |
+ int.parse(i.toString()); |
+ if (sw.elapsedTicks > 0) { |
+ break; |
+ } |
+ } |
+ sw.stop(); |
+ Expect.isFalse(sw.isRunning); |
+ sw.reset(); |
+ Expect.isFalse(sw.isRunning); |
+ Expect.equals(0, sw.elapsedTicks); |
+ sw.start(); |
+ Expect.isTrue(sw.isRunning); |
+ for (int i = 0; i < 100000; i++) { |
+ int.parse(i.toString()); |
+ if (sw.elapsedTicks > 0) { |
+ break; |
+ } |
+ } |
+ sw.reset(); |
+ Expect.isTrue(sw.isRunning); |
+ for (int i = 0; i < 100000; i++) { |
+ int.parse(i.toString()); |
+ if (sw.elapsedTicks > 0) { |
+ break; |
+ } |
+ } |
+ sw.stop(); |
+ Expect.isFalse(sw.isRunning); |
+ Expect.isTrue(sw.elapsedTicks > 0); |
+ } |
+ |
+ static testMain() { |
+ Stopwatch sw = new Stopwatch(); |
+ Expect.isTrue(checkTicking(sw)); |
+ Expect.isTrue(checkStopping(sw)); |
+ checkRestart(); |
+ checkReset(); |
+ } |
+} |
+ |
+main() { |
+ StopwatchTest.testMain(); |
+} |