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

Unified Diff: test/runner/browser/safari_test.dart

Issue 1243293002: Convert a bunch of tests to use scheduled_test's infrastructure. (Closed) Base URL: git@github.com:dart-lang/test@master
Patch Set: Code review changes Created 5 years, 5 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « test/runner/browser/runner_test.dart ('k') | test/runner/compact_reporter_test.dart » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: test/runner/browser/safari_test.dart
diff --git a/test/runner/browser/safari_test.dart b/test/runner/browser/safari_test.dart
index 254a0fc865ae569dd296daec54c554f851d0ef8d..85d4f56f048212d16dcdd49f0be5bc0fda323478 100644
--- a/test/runner/browser/safari_test.dart
+++ b/test/runner/browser/safari_test.dart
@@ -4,138 +4,48 @@
@TestOn("vm && mac-os")
-import 'dart:async';
-
-import 'package:test/test.dart';
+import 'package:scheduled_test/descriptor.dart' as d;
+import 'package:scheduled_test/scheduled_stream.dart';
+import 'package:scheduled_test/scheduled_test.dart';
import 'package:test/src/runner/browser/safari.dart';
-import 'package:test/src/util/io.dart';
-import 'package:shelf/shelf.dart' as shelf;
-import 'package:shelf/shelf_io.dart' as shelf_io;
-import 'package:shelf_web_socket/shelf_web_socket.dart';
import '../../io.dart';
import '../../utils.dart';
+import 'code_server.dart';
void main() {
- group("running JavaScript", () {
- // The JavaScript to serve in the server. We use actual JavaScript here to
- // avoid the pain of compiling to JS in a test
- var javaScript;
-
- var servePage = (request) {
- var path = request.url.path;
-
- // We support both shelf 0.5.x and 0.6.x. The former has a leading "/"
- // here, the latter does not.
- if (path.startsWith("/")) path = path.substring(1);
-
- if (path.isEmpty) {
- return new shelf.Response.ok("""
-<!doctype html>
-<html>
-<head>
- <script src="index.js"></script>
-</head>
-</html>
-""", headers: {'content-type': 'text/html'});
- } else if (path == "index.js") {
- return new shelf.Response.ok(javaScript,
- headers: {'content-type': 'application/javascript'});
- } else {
- return new shelf.Response.notFound(null);
- }
- };
-
- var server;
- var webSockets;
- setUp(() async {
- var webSocketsController = new StreamController();
- webSockets = webSocketsController.stream;
-
- server = await shelf_io.serve(
- new shelf.Cascade()
- .add(webSocketHandler(webSocketsController.add))
- .add(servePage).handler,
- 'localhost', 0);
- });
+ useSandbox();
- tearDown(() {
- if (server != null) server.close();
+ test("starts Safari with the given URL", () {
+ var server = new CodeServer();
- javaScript = null;
- server = null;
- webSockets = null;
+ schedule(() async {
+ var safari = new Safari(await server.url);
+ currentSchedule.onComplete.schedule(
+ () async => (await safari).close());
});
- test("starts Safari with the given URL", () async {
- javaScript = '''
+ server.handleJavaScript('''
var webSocket = new WebSocket(window.location.href.replace("http://", "ws://"));
webSocket.addEventListener("open", function() {
webSocket.send("loaded!");
});
-''';
- var safari = new Safari(baseUrlForAddress(server.address, server.port));
-
- try {
- var message = await (await webSockets.first).first;
- expect(message, equals("loaded!"));
- } finally {
- safari.close();
- }
- });
+''');
- test("doesn't preserve state across runs", () {
- javaScript = '''
-localStorage.setItem("data", "value");
+ var webSocket = server.handleWebSocket();
-var webSocket = new WebSocket(window.location.href.replace("http://", "ws://"));
-webSocket.addEventListener("open", function() {
- webSocket.send("done");
-});
-''';
- var safari = new Safari(baseUrlForAddress(server.address, server.port));
-
- var first = true;
- webSockets.listen(expectAsync((webSocket) {
- if (first) {
- // The first request will set local storage data. We can't kill the
- // old safari and start a new one until we're sure that that has
- // finished.
- webSocket.first.then((_) {
- safari.close();
-
- javaScript = '''
-var webSocket = new WebSocket(window.location.href.replace("http://", "ws://"));
-webSocket.addEventListener("open", function() {
- webSocket.send(localStorage.getItem("data"));
-});
-''';
- safari = new Safari(baseUrlForAddress(server.address, server.port));
- first = false;
- });
- } else {
- // The second request will return the local storage data. This should
- // be null, indicating that no data was saved between runs.
- expect(
- webSocket.first
- .then((message) => expect(message, equals('null')))
- .whenComplete(safari.close),
- completes);
- }
- }, count: 2));
+ schedule(() async {
+ expect(await (await webSocket).first, equals("loaded!"));
});
});
test("a process can be killed synchronously after it's started", () async {
- var server = await shelf_io.serve(
- expectAsync((_) {}, count: 0), 'localhost', 0);
+ var server = new CodeServer();
- try {
- var safari = new Safari(baseUrlForAddress(server.address, server.port));
+ schedule(() async {
+ var safari = new Safari(await server.url);
await safari.close();
- } finally {
- server.close();
- }
+ });
});
test("reports an error in onExit", () {
@@ -144,4 +54,32 @@ webSocket.addEventListener("open", function() {
expect(safari.onExit, throwsA(isApplicationException(startsWith(
"Failed to run Safari: $noSuchFileMessage"))));
});
+
+ test("can run successful tests", () {
+ d.file("test.dart", """
+import 'package:test/test.dart';
+
+void main() {
+ test("success", () {});
+}
+""").create();
+
+ var test = runTest(["-p", "safari", "test.dart"]);
+ test.stdout.expect(consumeThrough(contains("+1: All tests passed!")));
+ test.shouldExit(0);
+ });
+
+ test("can run failing tests", () {
+ d.file("test.dart", """
+import 'package:test/test.dart';
+
+void main() {
+ test("failure", () => throw new TestFailure("oh no"));
+}
+""").create();
+
+ var test = runTest(["-p", "safari", "test.dart"]);
+ test.stdout.expect(consumeThrough(contains("-1: Some tests failed.")));
+ test.shouldExit(1);
+ });
}
« no previous file with comments | « test/runner/browser/runner_test.dart ('k') | test/runner/compact_reporter_test.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698