From e32e7d2b38445d33d71e83e31abe4555df5126f2 Mon Sep 17 00:00:00 2001 From: Natalie Weizenbaum <nweiz@google.com> Date: Tue, 14 Apr 2015 16:53:10 -0700 Subject: [PATCH] Detect an old PhantomJS and emit a nice error. Closes #70 R=kevmoo@google.com Review URL: https://codereview.chromium.org//1055243005 --- lib/src/runner/browser/phantom_js.dart | 9 +++++++++ lib/src/runner/browser/server.dart | 5 ++++- 2 files changed, 13 insertions(+), 1 deletion(-) diff --git a/lib/src/runner/browser/phantom_js.dart b/lib/src/runner/browser/phantom_js.dart index b4e2f4a4..0eadafb4 100644 --- a/lib/src/runner/browser/phantom_js.dart +++ b/lib/src/runner/browser/phantom_js.dart @@ -9,7 +9,9 @@ import 'dart:io'; import 'package:path/path.dart' as p; +import '../../util/exit_codes.dart' as exit_codes; import '../../util/io.dart'; +import '../application_exception.dart'; import 'browser.dart'; /// The PhantomJS script that opens the host page. @@ -17,6 +19,9 @@ final _script = """ var system = require('system'); var page = require('webpage').create(); +// PhantomJS versions older than 2.0.0 don't support the latest WebSocket spec. +if (phantom.version.major < 2) phantom.exit(${exit_codes.protocol}); + // Pipe browser messages to the process's stdout. This isn't used by default, // but it can be useful for debugging. page.onConsoleMessage = function(message) { @@ -73,6 +78,10 @@ class PhantomJS implements Browser { return _process.exitCode; }); }).then((exitCode) { + if (exitCode == exit_codes.protocol) { + throw new ApplicationException( + "Only PhantomJS version 2.0.0 or greater is supported."); + } if (exitCode != 0) throw "PhantomJS failed with exit code $exitCode."; }).then(_onExitCompleter.complete) .catchError(_onExitCompleter.completeError); diff --git a/lib/src/runner/browser/server.dart b/lib/src/runner/browser/server.dart index 6c1d52d0..963a6b84 100644 --- a/lib/src/runner/browser/server.dart +++ b/lib/src/runner/browser/server.dart @@ -329,7 +329,10 @@ void main() { if (manager != null) return manager; var completer = new Completer(); - _browserManagers[platform] = completer.future; + + // Swallow errors, since they're already being surfaced through the return + // value and [browser.onError]. + _browserManagers[platform] = completer.future.catchError((_) {}); var path = _webSocketHandler.create(webSocketHandler((webSocket) { completer.complete(new BrowserManager(webSocket)); })); -- GitLab