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