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.1
Also nicht derselbe Bug.
$ 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)