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

Side by Side Diff: test/runner/engine_test.dart

Issue 1187103004: Allow Suites to be added to an Engine over time. (Closed) Base URL: git@github.com:dart-lang/test@master
Patch Set: Created 5 years, 6 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
OLDNEW
1 // Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2015, 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 'package:test/src/backend/declarer.dart'; 5 import 'package:test/src/backend/declarer.dart';
6 import 'package:test/src/backend/state.dart'; 6 import 'package:test/src/backend/state.dart';
7 import 'package:test/src/backend/suite.dart'; 7 import 'package:test/src/backend/suite.dart';
8 import 'package:test/src/runner/engine.dart'; 8 import 'package:test/src/runner/engine.dart';
9 import 'package:test/test.dart'; 9 import 'package:test/test.dart';
10 10
11 void main() { 11 void main() {
12 var declarer; 12 var declarer;
13 setUp(() => declarer = new Declarer()); 13 setUp(() => declarer = new Declarer());
14 14
15 test("runs each test in each suite in order", () async { 15 test("runs each test in each suite in order", () async {
16 var testsRun = 0; 16 var testsRun = 0;
17 for (var i = 0; i < 4; i++) { 17 for (var i = 0; i < 4; i++) {
18 declarer.test("test ${i + 1}", expectAsync(() { 18 declarer.test("test ${i + 1}", expectAsync(() {
19 expect(testsRun, equals(i)); 19 expect(testsRun, equals(i));
20 testsRun++; 20 testsRun++;
21 }, max: 1)); 21 }, max: 1));
22 } 22 }
23 23
24 var engine = new Engine([ 24 var engine = new Engine.withSuites([
25 new Suite(declarer.tests.take(2)), 25 new Suite(declarer.tests.take(2)),
26 new Suite(declarer.tests.skip(2)) 26 new Suite(declarer.tests.skip(2))
27 ]); 27 ]);
28 28
29 await engine.run(); 29 await engine.run();
30 expect(testsRun, equals(4)); 30 expect(testsRun, equals(4));
31 }); 31 });
32 32
33 test("runs tests in a suite added after run() was called", () {
34 var testsRun = 0;
35 for (var i = 0; i < 4; i++) {
36 declarer.test("test ${i + 1}", expectAsync(() {
37 expect(testsRun, equals(i));
38 testsRun++;
39 }, max: 1));
40 }
41
42 var engine = new Engine();
43 expect(engine.run().then((_) {
44 expect(testsRun, equals(4));
45 }), completes);
46
47 engine.suiteSink.add(new Suite(declarer.tests));
48 engine.suiteSink.close();
49 });
50
33 test("emits each test before it starts running and after the previous test " 51 test("emits each test before it starts running and after the previous test "
34 "finished", () { 52 "finished", () {
35 var testsRun = 0; 53 var testsRun = 0;
36 for (var i = 0; i < 3; i++) { 54 for (var i = 0; i < 3; i++) {
37 declarer.test("test ${i + 1}", expectAsync(() => testsRun++, max: 1)); 55 declarer.test("test ${i + 1}", expectAsync(() => testsRun++, max: 1));
38 } 56 }
39 57
40 var engine = new Engine([new Suite(declarer.tests)]); 58 var engine = new Engine.withSuites([new Suite(declarer.tests)]);
59
41 engine.onTestStarted.listen(expectAsync((liveTest) { 60 engine.onTestStarted.listen(expectAsync((liveTest) {
42 // [testsRun] should be one less than the test currently running. 61 // [testsRun] should be one less than the test currently running.
43 expect(liveTest.test.name, equals("test ${testsRun + 1}")); 62 expect(liveTest.test.name, equals("test ${testsRun + 1}"));
44 63
45 // [Engine.onTestStarted] is guaranteed to fire before the first 64 // [Engine.onTestStarted] is guaranteed to fire before the first
46 // [LiveTest.onStateChange]. 65 // [LiveTest.onStateChange].
47 expect(liveTest.onStateChange.first, 66 expect(liveTest.onStateChange.first,
48 completion(equals(const State(Status.running, Result.success)))); 67 completion(equals(const State(Status.running, Result.success))));
49 }, count: 3, max: 3)); 68 }, count: 3, max: 3));
50 69
51 return engine.run(); 70 return engine.run();
52 }); 71 });
53 72
54 test(".run() returns true if every test passes", () { 73 test(".run() returns true if every test passes", () {
55 for (var i = 0; i < 2; i++) { 74 for (var i = 0; i < 2; i++) {
56 declarer.test("test ${i + 1}", () {}); 75 declarer.test("test ${i + 1}", () {});
57 } 76 }
58 77
59 var engine = new Engine([new Suite(declarer.tests)]); 78 var engine = new Engine.withSuites([new Suite(declarer.tests)]);
60 expect(engine.run(), completion(isTrue)); 79 expect(engine.run(), completion(isTrue));
61 }); 80 });
62 81
63 test(".run() returns false if any test fails", () { 82 test(".run() returns false if any test fails", () {
64 for (var i = 0; i < 2; i++) { 83 for (var i = 0; i < 2; i++) {
65 declarer.test("test ${i + 1}", () {}); 84 declarer.test("test ${i + 1}", () {});
66 } 85 }
67 declarer.test("failure", () => throw new TestFailure("oh no")); 86 declarer.test("failure", () => throw new TestFailure("oh no"));
68 87
69 var engine = new Engine([new Suite(declarer.tests)]); 88 var engine = new Engine.withSuites([new Suite(declarer.tests)]);
70 expect(engine.run(), completion(isFalse)); 89 expect(engine.run(), completion(isFalse));
71 }); 90 });
72 91
73 test(".run() returns false if any test errors", () { 92 test(".run() returns false if any test errors", () {
74 for (var i = 0; i < 2; i++) { 93 for (var i = 0; i < 2; i++) {
75 declarer.test("test ${i + 1}", () {}); 94 declarer.test("test ${i + 1}", () {});
76 } 95 }
77 declarer.test("failure", () => throw "oh no"); 96 declarer.test("failure", () => throw "oh no");
78 97
79 var engine = new Engine([new Suite(declarer.tests)]); 98 var engine = new Engine.withSuites([new Suite(declarer.tests)]);
80 expect(engine.run(), completion(isFalse)); 99 expect(engine.run(), completion(isFalse));
81 }); 100 });
82 101
83 test(".run() may not be called more than once", () { 102 test(".run() may not be called more than once", () {
84 var engine = new Engine([]); 103 var engine = new Engine.withSuites([]);
85 expect(engine.run(), completes); 104 expect(engine.run(), completes);
86 expect(engine.run(), throwsStateError); 105 expect(engine.run, throwsStateError);
87 }); 106 });
88 107
89 group("for a skipped test", () { 108 group("for a skipped test", () {
90 test("doesn't run the test's body", () async { 109 test("doesn't run the test's body", () async {
91 var bodyRun = false; 110 var bodyRun = false;
92 declarer.test("test", () => bodyRun = true, skip: true); 111 declarer.test("test", () => bodyRun = true, skip: true);
93 112
94 var engine = new Engine([new Suite(declarer.tests)]); 113 var engine = new Engine.withSuites([new Suite(declarer.tests)]);
95 await engine.run(); 114 await engine.run();
96 expect(bodyRun, isFalse); 115 expect(bodyRun, isFalse);
97 }); 116 });
98 117
99 test("exposes a LiveTest that emits the correct states", () { 118 test("exposes a LiveTest that emits the correct states", () {
100 declarer.test("test", () {}, skip: true); 119 declarer.test("test", () {}, skip: true);
101 120
102 var engine = new Engine([new Suite(declarer.tests)]); 121 var engine = new Engine.withSuites([new Suite(declarer.tests)]);
103 var liveTest = engine.liveTests.single;
104 expect(liveTest.test, equals(declarer.tests.single));
105 122
106 var first = true; 123 engine.onTestStarted.listen(expectAsync((liveTest) {
107 liveTest.onStateChange.listen(expectAsync((state) { 124 expect(liveTest, same(engine.liveTests.single));
108 expect(state, equals(first 125 expect(liveTest.test, equals(declarer.tests.single));
109 ? const State(Status.running, Result.success)
110 : const State(Status.complete, Result.success)));
111 first = false;
112 }, count: 2));
113 126
114 expect(liveTest.onComplete, completes); 127 var first = true;
128 liveTest.onStateChange.listen(expectAsync((state) {
129 expect(state, equals(first
130 ? const State(Status.running, Result.success)
131 : const State(Status.complete, Result.success)));
132 first = false;
133 }, count: 2));
134
135 expect(liveTest.onComplete, completes);
136 }));
115 137
116 return engine.run(); 138 return engine.run();
117 }); 139 });
118 }); 140 });
119 } 141 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698