Search code examples
ubuntujenkinsjenkins-pluginsrobotframeworkheadless

Jenkins : Ubuntu 16.04 : Headless Chrome failed to start: exited abnormally


jenkins@ubuntu:~$ which chromedriver /usr/local/bin/chromedriver

ChromeDriver 2.42.591071 (0b695ff80972cc1a65a5cd643186d2ae582cd4ac)

I am trying to run some Robot framework scripts from Jenkins. My robot script runs headless on an Ubuntu16.04 version machine.

Everytime when I run my testcases or even a simple selenium script it gives me the following error:

>>> from selenium import webdriver
    we = webdriver.Chrome()
    Traceback (most recent call last):
    File "<stdin>", line 1, in <module>
    File "/var/lib/jenkins/.local/lib/python2.7/site- 
    packages/selenium/webdriver/chrome/webdriver.py", line 81, in __init__
    desired_capabilities=desired_capabilities)
    File "/var/lib/jenkins/.local/lib/python2.7/site- 
    packages/selenium/webdriver/remote/webdriver.py", line 157, in __init__
   self.start_session(capabilities, browser_profile)
   File "/var/lib/jenkins/.local/lib/python2.7/site- 
   packages/selenium/webdriver/remote/webdriver.py", line 252, in 
   start_session
   response = self.execute(Command.NEW_SESSION, parameters)
   File "/var/lib/jenkins/.local/lib/python2.7/site- 
   packages/selenium/webdriver/remote/webdriver.py", line 321, in execute
   self.error_handler.check_response(response)
   File "/var/lib/jenkins/.local/lib/python2.7/site- 
   packages/selenium/webdriver/remote/errorhandler.py", line 242, in 
   check_response
   raise exception_class(message, screen, stacktrace)
   selenium.common.exceptions.WebDriverException: Message: unknown 
   error: Chrome failed to start: exited abnormally
   (unknown error: DevToolsActivePort file doesn't exist)
   (The process started from chrome location /usr/bin/google-chrome is 
    no longer running, so ChromeDriver is assuming that Chrome has 
   crashed.)
   (Driver info: chromedriver=2.42.591071 
  (0b695ff80972cc1a65a5cd643186d2ae582cd4ac),platform=Linux 4.4.0-87- 
  generic x86_64)

For running it headless I am doing the following : Xvfb -ac :90 -screen 0 1280x1024x16 & export DISPLAY=:90

Any help in solving this issue will be greatly appreciated.

Thanks in advance!


Solution

  • To resolve this issue I have downgraded my google-chrome version to 57.0.2987.133 and chromedriver version 2.26.436382 (70eb799287ce4c2208441fc057053a5b07ceabac).

    Seems like the newer versions of chromedriver and google-chrome have some issues with running them headless in ubuntu 14.04 for robot scripts.

    For running it headless I've used:

    Xvfb -ac :90 -screen 0 1280x1024x16 & export DISPLAY=:90