Openshift - gitlab-cli - phantomjs - WebDriverException:等待驱动程序服务器启动超时

时间:2017-09-06 10:48:43

标签: selenium phantomjs gitlab-ci

我有一个带有验收测试(即一致性测试)的Java项目的设置。 在本地使用chrome和phantomjs驱动程序(在Windows上)测试正在通过(即通过gradle运行)。

在gitlab-ci上运行时(在openshift中有一个运行器),我得到以下异常:

  java.lang.ExceptionInInitializerError
    at be.axians.actemium.milter.helper.BrowserTestParent.openBrowser(BrowserTestParent.java:32)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)

    ...

    at org.gradle.internal.concurrent.ThreadFactoryImpl$ManagedThreadRunnable.run(ThreadFactoryImpl.java:55)
    at java.lang.Thread.run(Thread.java:748)
Caused by: org.openqa.selenium.WebDriverException: Timed out waiting for driver server to start.
Build info: version: '3.4.0', revision: 'unknown', time: 'unknown'
System info: host: 'runner-5408090a-project-349-concurrent-0dtvl2', ip: '10.131.1.51', os.name: 'Linux', os.arch: 'amd64', os.version: '3.10.0-514.26.1.el7.x86_64', java.version: '1.8.0_131'
Driver info: driver.version: PhantomJSDriver
    at org.openqa.selenium.remote.service.DriverService.waitUntilAvailable(DriverService.java:193)
    at org.openqa.selenium.remote.service.DriverService.start(DriverService.java:181)
    at org.openqa.selenium.phantomjs.PhantomJSCommandExecutor.execute(PhantomJSCommandExecutor.java:78)
    at org.openqa.selenium.remote.RemoteWebDriver.execute(RemoteWebDriver.java:637)
    at org.openqa.selenium.remote.RemoteWebDriver.startSession(RemoteWebDriver.java:250)
    at org.openqa.selenium.remote.RemoteWebDriver.startSession(RemoteWebDriver.java:236)
    at org.openqa.selenium.remote.RemoteWebDriver.<init>(RemoteWebDriver.java:137)
    at org.openqa.selenium.phantomjs.PhantomJSDriver.<init>(PhantomJSDriver.java:116)
    at be.axians.actemium.milter.helper.WebDriverManager.<clinit>(WebDriverManager.java:53)
    ... 52 more
Caused by: org.openqa.selenium.net.UrlChecker$TimeoutException: Timed out waiting for [http://localhost:7465/status] to be available after 20001 ms
    at org.openqa.selenium.net.UrlChecker.waitUntilAvailable(UrlChecker.java:107)
    at org.openqa.selenium.remote.service.DriverService.waitUntilAvailable(DriverService.java:190)
    ... 60 more
Caused by: com.google.common.util.concurrent.UncheckedTimeoutException: java.util.concurrent.TimeoutException
    at com.google.common.util.concurrent.SimpleTimeLimiter.callWithTimeout(SimpleTimeLimiter.java:140)
    at org.openqa.selenium.net.UrlChecker.waitUntilAvailable(UrlChecker.java:80)
    ... 61 more
Caused by: java.util.concurrent.TimeoutException
    at java.util.concurrent.FutureTask.get(FutureTask.java:205)
    at com.google.common.util.concurrent.SimpleTimeLimiter.callWithTimeout(SimpleTimeLimiter.java:128)
    ... 62 more

驱动程序初始化如下:

        DesiredCapabilities capabilities = DesiredCapabilities.phantomjs();
        capabilities.setJavascriptEnabled(true);

        PhantomJSDriverService service = new PhantomJSDriverService.Builder()
                .usingPhantomJSExecutable(new File("/actemium/milter/acceptance-tests/driver/phantomjs/bin/phantomjs"))
                .usingAnyFreePort()
                .build();
//
        driver = new PhantomJSDriver(service, capabilities);

具有给定的依赖项:

testCompile "com.codeborne:phantomjsdriver:1.4.3"
phantomjs-1.9.8

使用以下gitlab-ci config:

acceptance-test:
  stage: acceptance-test
  services:
   - jboss/keycloak:3.3.0.CR1
   - postgres:latest
  variables:
    POSTGRES_DB: "..."
    POSTGRES_USER: "..."
    POSTGRES_PASSWORD: "..."
    KEYCLOAK_PASSWORD: "..."
    KEYCLOAK_USER: "..."
  script:
    - ls
    - cd acceptance-tests/driver
    - ls
    - tar xf phantomjs-1.9.8-linux-x86_64.tar.bz2
    - ls -al
    - mv phantomjs-1.9.8-linux-x86_64 phantomjs
    - ls
    - ls phantomjs
    #- ls -al phantomjs/bin
    #- ln -s phantomjs/bin/phantomjs /usr/bin/phantomjs
    - ls -al /actemium/milter/acceptance-tests/driver/phantomjs/bin/phantomjs
    - cd ../..
    - ls
    - pwd
    - ./gradlew -g .gradle_home acceptanceTest -Dspring.profiles.active=at --stacktrace
  artifacts:
    when: on_failure
    paths:
      - acceptance-tests/tests/build/reports/tests
    expire_in: 1 week

任何人都知道如何解决这个问题?

2 个答案:

答案 0 :(得分:2)

我对PhantomJS的解决方案是安装一个隐藏的依赖项:

yum install -y libfontconfig1 fontconfig libfontconfig1-dev libfreetype6-dev

答案 1 :(得分:1)

您可以使用无头通过Chrome浏览器执行所有操作。不要使用HTMLUnit,因为它有很多配置问题。

PhamtomJS是无头浏览器的另一种方法,但PhantomJs最近因为维护不善而出现了bug。

你可以将chromedriver本身用于无头工作。

您只需要在chromedriver中传递一个选项,如下所示: -

chromeOptions.addArguments("--headless");

完整代码将如下所示: -

System.setProperty("webdriver.chrome.driver","D:\\Workspace\\JmeterWebdriverProject\\src\\lib\\chromedriver.exe");
ChromeOptions chromeOptions = new ChromeOptions();
chromeOptions.addArguments("--headless");
chromeOptions.addArguments("--start-maximized");
WebDriver driver = new ChromeDriver(chromeOptions);
driver.get("https://www.google.co.in/");

如果你还想使用phantomjs。 然后首先从以下URL下载phantomjs二进制文件: -

http://phantomjs.org/download.html

完整代码如下: -

System.setProperty("phantomjs.binary.path","D:\\Workspace\\kumolus-test-automation\\src\\lib\\phantomjs\\phantomjs.exe");
DesiredCapabilities capabilities = null;
ArrayList<String> cliArgsCap = new ArrayList<String>();
capabilities = DesiredCapabilities.phantomjs();
cliArgsCap.add("--web-security=false");
cliArgsCap.add("--ssl-protocol=any");
cliArgsCap.add("--ignore-ssl-errors=true");
capabilities.setCapability("takesScreenshot", true);
capabilities.setJavascriptEnabled(true);
capabilities.setCapability(
    PhantomJSDriverService.PHANTOMJS_CLI_ARGS, cliArgsCap);
capabilities.setCapability(
    PhantomJSDriverService.PHANTOMJS_GHOSTDRIVER_CLI_ARGS,
        new String[] { "--logLevel=2" });

WebDriver driver = new PhantomJSDriver();
driver.get("https://www.facebook.com/");
System.out.println(driver.getTitle());

在上面代码的第1行中更改phantomjs位置路径的位置

希望它会对你有所帮助:)。