Ausführen von Selen-Chromedriver mit Protractor unter Linux

Ich benutze einen Winkelmesser, um Tests mit einer Angular-Anwendung durchzuführen. Sie funktionieren in meiner OSX-Umgebung, aber nicht unter Linux, wo TeamCity versucht, sie auszuführen.

Wenn ich diesen Befehl in meiner lokalen OSX-Umgebung ausführe, funktioniert er (auch auf meinem Kollegen-Computer getestet):

./node_modules/protractor/bin/protractor protractor.conf.js

Using ChromeDriver directly...
..
Finished in 5.55 seconds
2 tests, 2 assertions, 0 failures

Wenn ich dies auf einem Linux-Computer ausführe oder ein TeamCity-Job versucht, es auszuführen, schlägt dies fehl:

./node_modules/protractor/bin/protractor protractor.conf.js

Using ChromeDriver directly...

/usr/share/TeamCity/buildAgent/work/57bd89f9c9abb5d5/webapp/node_modules/protractor/node_modules/selenium-webdriver/http/util.js:87
          Error('Timed out waiting for the WebDriver server at ' + url));
          ^
Error: Timed out waiting for the WebDriver server at http://127.0.0.1:52959/
    at Error (<anonymous>)
    at onResponse (/usr/share/TeamCity/buildAgent/work/57bd89f9c9abb5d5/webapp/node_modules/protractor/node_modules/selenium-webdriver/http/util.js:87:11)
    at /usr/share/TeamCity/buildAgent/work/57bd89f9c9abb5d5/webapp/node_modules/protractor/node_modules/selenium-webdriver/http/util.js:42:21
    at /usr/share/TeamCity/buildAgent/work/57bd89f9c9abb5d5/webapp/node_modules/protractor/node_modules/selenium-webdriver/lib/webdriver/http/http.js:96:5
    at ClientRequest.<anonymous> (/usr/share/TeamCity/buildAgent/work/57bd89f9c9abb5d5/webapp/node_modules/protractor/node_modules/selenium-webdriver/http/index.js:136:7)
    at ClientRequest.EventEmitter.emit (events.js:95:17)
    at Socket.socketErrorListener (http.js:1547:9)
    at Socket.EventEmitter.emit (events.js:95:17)
    at net.js:440:14
    at process._tickCallback (node.js:415:13)
==== async task ====
WebDriver.createSession()
    at Function.webdriver.WebDriver.acquireSession_ (/usr/share/TeamCity/buildAgent/work/57bd89f9c9abb5d5/webapp/node_modules/protractor/node_modules/selenium-webdriver/lib/webdriver/webdriver.js:131:49)
    at Function.webdriver.WebDriver.createSession (/usr/share/TeamCity/buildAgent/work/57bd89f9c9abb5d5/webapp/node_modules/protractor/node_modules/selenium-webdriver/lib/webdriver/webdriver.js:111:30)
Versuche zu lösen:

Ich habe angeschautdieses Problem, aber ein eigenständiger Webdriver-Server ist keine Lösung.

Ich sah mich umdieses Problem aber meine version von selen-wedriver ist2.42.1Also nicht derselbe Bug.

Versionen:
$ node --version
v0.10.26

$ ./node_modules/protractor/bin/protractor --version
Version 1.0.0

$ uname -mrs
Linux 3.11.0-15-generic x86_64
Fortschrittsbericht:

Ich versuche die Version von zu bekommenchrome-webdriver ein Problem aufgedeckt:

$ ./node_modules/protractor/selenium/chromedriver --version
./node_modules/protractor/selenium/chromedriver: error while loading shared libraries: libnss3.so: cannot open shared object file: No such file or directory

Daraus schloss ich, dass es ein Abhängigkeitsproblem gab und stellte fest, dassSelen benötigt Chrome. (Mehr).

Ich habe Chrome auf der Linux-Box mit installiertSchritte wie diese:

sudo apt-get install libxss1 libappindicator1 libindicator7
sudo wget https://dl.google.com/linux/direct/google-chrome-stable_current_amd64.deb
sudo dpkg -i google-chrome*.deb

Das hat nicht genau so funktioniert, aber nach ein paar Hin und Her mit Abhängigkeiten undsudo apt-get install Ich glaube, ich habe Chrome installiert:

$ google-chrome --version
Google Chrome 36.0.1985.143 

Damit hat die Chromedriver-Version funktioniert:

$ ./node_modules/protractor/selenium/chromedriver --version
ChromeDriver 2.10.267518

Das Ausführen von Protractor funktioniert jedoch immer noch nicht:

$ ./node_modules/protractor/bin/protractor protractor.conf.js
Using ChromeDriver directly...

/usr/share/TeamCity/buildAgent/work/57bd89f9c9abb5d5/webapp/node_modules/protractor/node_modules/selenium-webdriver/lib/atoms/error.js:109
  var template = new Error(this.message);
                 ^
UnknownError: unknown error: Chrome failed to start: exited abnormally
  (Driver info: chromedriver=2.10.267518,platform=Linux 3.11.0-15-generic x86_64)
    at new bot.Error (/usr/share/TeamCity/buildAgent/work/57bd89f9c9abb5d5/webapp/node_modules/protractor/node_modules/selenium-webdriver/lib/atoms/error.js:109:18)
    at Object.bot.response.checkResponse (/usr/share/TeamCity/buildAgent/work/57bd89f9c9abb5d5/webapp/node_modules/protractor/node_modules/selenium-webdriver/lib/atoms/response.js:106:9)

Antworten auf die Frage(2)

Ihre Antwort auf die Frage