Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(13)

Side by Side Diff: tests/standalone/io/test_runner_test.dart

Issue 10252020: test rename overhaul: step 12 - standalone (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 8 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « tests/standalone/io/test_extension_test.dart ('k') | tests/standalone/io/testing_server.dart » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 #import("dart:io"); 5 #import("dart:io");
6 #import("../../../../tools/testing/dart/test_runner.dart"); 6 #import("../../../tools/testing/dart/test_runner.dart");
7 #import("../../../../tools/testing/dart/status_file_parser.dart"); 7 #import("../../../tools/testing/dart/status_file_parser.dart");
8 #import("../../../../tools/testing/dart/test_options.dart"); 8 #import("../../../tools/testing/dart/test_options.dart");
9 #source("ProcessTestUtil.dart"); 9 #source("process_test_util.dart");
10 10
11 class TestController { 11 class TestController {
12 static final int numTests = 4; 12 static final int numTests = 4;
13 static int numCompletedTests = 0; 13 static int numCompletedTests = 0;
14 14
15 // Used as TestCase.completedCallback. 15 // Used as TestCase.completedCallback.
16 static processCompletedTest(TestCase testCase) { 16 static processCompletedTest(TestCase testCase) {
17 TestOutput output = testCase.output; 17 TestOutput output = testCase.output;
18 print("Test: ${testCase.commands.last().commandLine}"); 18 print("Test: ${testCase.commands.last().commandLine}");
19 if (output.unexpectedOutput) { 19 if (output.unexpectedOutput) {
20 throw "Unexpected output: ${output.result}"; 20 throw "Unexpected output: ${output.result}";
21 } 21 }
22 print("stdout: "); 22 print("stdout: ");
23 for (var line in output.stdout) print(line); 23 for (var line in output.stdout) print(line);
24 print("stderr: "); 24 print("stderr: ");
25 for (var line in output.stderr) print(line); 25 for (var line in output.stderr) print(line);
26 26
27 print("Time: ${output.time}"); 27 print("Time: ${output.time}");
28 print("Exit code: ${output.exitCode}"); 28 print("Exit code: ${output.exitCode}");
29 29
30 ++numCompletedTests; 30 ++numCompletedTests;
31 print("$numCompletedTests/$numTests"); 31 print("$numCompletedTests/$numTests");
32 if (numCompletedTests == numTests) { 32 if (numCompletedTests == numTests) {
33 print("TestRunnerTest.dart PASSED"); 33 print("test_runner_test.dart PASSED");
34 } 34 }
35 } 35 }
36 } 36 }
37 37
38 38
39 TestCase MakeTestCase(String testName, List<String> expectations) { 39 TestCase MakeTestCase(String testName, List<String> expectations) {
40 String test_path = "tests/standalone/src/${testName}.dart"; 40 String test_path = "tests/standalone/${testName}.dart";
41 // Working directory may be dart/runtime rather than dart. 41 // Working directory may be dart/runtime rather than dart.
42 if (!new File(test_path).existsSync()) { 42 if (!new File(test_path).existsSync()) {
43 test_path = "../tests/standalone/src/${testName}.dart"; 43 test_path = "../tests/standalone/${testName}.dart";
44 } 44 }
45 45
46 var configuration = new TestOptionsParser().parse(['--timeout', '2'])[0]; 46 var configuration = new TestOptionsParser().parse(['--timeout', '2'])[0];
47 return new TestCase(testName, 47 return new TestCase(testName,
48 [new Command(getDartFileName(), 48 [new Command(getDartFileName(),
49 <String>["--ignore-unrecognized-flags", 49 <String>["--ignore-unrecognized-flags",
50 "--enable_type_checks", 50 "--enable_type_checks",
51 test_path])], 51 test_path])],
52 configuration, 52 configuration,
53 TestController.processCompletedTest, 53 TestController.processCompletedTest,
54 new Set<String>.from(expectations)); 54 new Set<String>.from(expectations));
55 } 55 }
56 56
57 57
58 void main() { 58 void main() {
59 new RunningProcess(MakeTestCase("PassTest", [PASS])).start(); 59 new RunningProcess(MakeTestCase("pass_test", [PASS])).start();
60 new RunningProcess(MakeTestCase("FailTest", [FAIL])).start(); 60 new RunningProcess(MakeTestCase("fail_test", [FAIL])).start();
61 new RunningProcess(MakeTestCase("TimeoutTest", [TIMEOUT])).start(); 61 new RunningProcess(MakeTestCase("timeout_test", [TIMEOUT])).start();
62 62
63 // The crash test sometimes times out. Run it with a large timeout to help 63 // The crash test sometimes times out. Run it with a large timeout to help
64 // diagnose the delay. 64 // diagnose the delay.
65 // The test loads a new executable, which may sometimes take a long time. 65 // The test loads a new executable, which may sometimes take a long time.
66 // It involves a wait on the VM event loop, and possible system delays. 66 // It involves a wait on the VM event loop, and possible system delays.
67 var configuration = new TestOptionsParser().parse(['--timeout', '60'])[0]; 67 var configuration = new TestOptionsParser().parse(['--timeout', '60'])[0];
68 new RunningProcess(new TestCase("CrashTest", 68 new RunningProcess(new TestCase("CrashTest",
69 [new Command(getProcessTestFileName(), 69 [new Command(getProcessTestFileName(),
70 const ["0", "0", "1", "1"])], 70 const ["0", "0", "1", "1"])],
71 configuration, 71 configuration,
72 TestController.processCompletedTest, 72 TestController.processCompletedTest,
73 new Set<String>.from([CRASH]))).start(); 73 new Set<String>.from([CRASH]))).start();
74 Expect.equals(4, TestController.numTests); 74 Expect.equals(4, TestController.numTests);
75 // Throw must be from body of start() function for this test to work. 75 // Throw must be from body of start() function for this test to work.
76 Expect.throws(new RunningProcess(MakeTestCase("PassTest", [SKIP])).start); 76 Expect.throws(new RunningProcess(MakeTestCase("pass_test", [SKIP])).start);
77 } 77 }
OLDNEW
« no previous file with comments | « tests/standalone/io/test_extension_test.dart ('k') | tests/standalone/io/testing_server.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698