2017-12-01 19 views
2

Firefox 57, geckodriver 0.19.1 및 selenium 3.8.0을 사용하고 있습니다. (Java gradle 프로젝트) Btw : Chrome은 잘하고 있습니다. 내 테스트가 작동합니다.Selenium Firefox 57 이진/로컬 호스트에 연결하지 못했습니다.

Firefox가 시작되지만 아무 일도 일어나지 않습니다. 2 ~ 3 초 후 Intellij는 예외를 표시합니다.

나는 이것이 가능한 복제가 될 수 있지만 각 "조합"의 호환 버전을 표시하는 리소스는 찾을 수 없다는 것을 알고 있습니다.

이 내 예외 출력 :

org.openqa.selenium.firefox.NotConnectedException: Unable to connect to host 127.0.0.1 on port 7055 after 45000 ms. Firefox console output: 
[...] 
at org.openqa.selenium.firefox.internal.NewProfileExtensionConnection.start(NewProfileExtensionConnection.java:113) 
    at org.openqa.selenium.firefox.FirefoxDriver.startClient(FirefoxDriver.java:271) 
    at org.openqa.selenium.remote.RemoteWebDriver.<init>(RemoteWebDriver.java:119) 
    at org.openqa.selenium.firefox.FirefoxDriver.<init>(FirefoxDriver.java:216) 
    at org.openqa.selenium.firefox.FirefoxDriver.<init>(FirefoxDriver.java:211) 
    at org.openqa.selenium.firefox.FirefoxDriver.<init>(FirefoxDriver.java:128) 
    at com.bilsteingroup.css.pf2.seleniumtests.ConfigTests.<init>(ConfigTests.java:43) 
    at com.bilsteingroup.css.pf2.seleniumtests.ConfigTests.Start(ConfigTests.java:71) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:498) 
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50) 
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) 
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47) 
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) 
    at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325) 
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78) 
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57) 
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290) 
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71) 
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288) 
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58) 
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268) 
    at org.junit.runners.ParentRunner.run(ParentRunner.java:363) 
    at org.junit.runner.JUnitCore.run(JUnitCore.java:137) 
    at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:68) 
    at com.intellij.rt.execution.junit.IdeaTestRunner$Repeater.startRunnerWithArgs(IdeaTestRunner.java:47) 
    at com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:242) 
    at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:70) 

aswell :

org.openqa.selenium.WebDriverException: Failed to connect to binary FirefoxBinary(C:\Program Files (x86)\Mozilla Firefox\firefox.exe) on port 7055; process output follows: 
[...] 
at org.openqa.selenium.firefox.internal.NewProfileExtensionConnection.start(NewProfileExtensionConnection.java:125) 
    at org.openqa.selenium.firefox.FirefoxDriver.startClient(FirefoxDriver.java:271) 
    at org.openqa.selenium.remote.RemoteWebDriver.<init>(RemoteWebDriver.java:119) 
    at org.openqa.selenium.firefox.FirefoxDriver.<init>(FirefoxDriver.java:216) 
    at org.openqa.selenium.firefox.FirefoxDriver.<init>(FirefoxDriver.java:211) 
    at org.openqa.selenium.firefox.FirefoxDriver.<init>(FirefoxDriver.java:128) 
    at com.bilsteingroup.css.pf2.seleniumtests.ConfigTests.<init>(ConfigTests.java:43) 
    at com.bilsteingroup.css.pf2.seleniumtests.ConfigTests.Start(ConfigTests.java:71) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:498) 
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50) 
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) 
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47) 
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) 
    at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325) 
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78) 
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57) 
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290) 
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71) 
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288) 
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58) 
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268) 
    at org.junit.runners.ParentRunner.run(ParentRunner.java:363) 
    at org.junit.runner.JUnitCore.run(JUnitCore.java:137) 
    at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:68) 
    at com.intellij.rt.execution.junit.IdeaTestRunner$Repeater.startRunnerWithArgs(IdeaTestRunner.java:47) 
    at com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:242) 
    at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:70) 

이 내 TestClass에 있습니다 :

import org.junit.Test; 
import org.openqa.selenium.By; 
import org.openqa.selenium.Keys; 
import org.openqa.selenium.WebDriver; 
import org.openqa.selenium.WebElement; 
import org.openqa.selenium.chrome.ChromeDriver; 
import org.openqa.selenium.firefox.FirefoxDriver; 
import org.openqa.selenium.ie.InternetExplorerDriver; 
import org.openqa.selenium.remote.DesiredCapabilities; 

import java.net.URISyntaxException; 
import java.net.URL; 
import java.nio.file.Paths; 

public class ConfigTests { 

    enum Browser { CHROME, FIREFOX, IE } 

    private WebDriver webDriver; 

    public ConfigTests() {} 

    private ConfigTests(Browser browser) throws URISyntaxException { 
     URL chromeURL = getClass().getResource("../../../../../../resources/driver/win/chromedriver_32.exe"); 
     System.setProperty("webdriver.chrome.driver", Paths.get(chromeURL.toURI()).toFile().getAbsolutePath()); 

     URL firefoxURL = getClass().getResource("../../../../../../resources/driver/win/geckodriver_32_v0-19-1.exe"); 
     System.setProperty("webdriver.gecko.driver", Paths.get(firefoxURL.toURI()).toFile().getAbsolutePath()); 

     /*URL ieURL = getClass().getClassLoader().getResource("driver" + File.separator + "IEDriverServer.exe"); 
     System.setProperty("webdriver.ie.driver", Paths.get(ieURL.toURI()).toFile().getAbsolutePath());*/ 

     switch (browser) { 
      case CHROME: 
       webDriver = new ChromeDriver(); 
       break; 
      case FIREFOX: 
       DesiredCapabilities capabilities = DesiredCapabilities.firefox(); 
       /*webDriver = new FirefoxDriver(capabilities); 
       webDriver.manage().timeouts().implicitlyWait(10, TimeUnit.SECONDS);*/ 
       break; 
      case IE: 
       webDriver = new InternetExplorerDriver(); 
       break; 
     } 
    } 


    private void goToLocalPartsfinder() { 
     webDriver.get("http://localhost:8080"); 
     WebElement searchFieldElement = webDriver.findElement(By.id("search-input-field")); 
     searchFieldElement.sendKeys("08900"); 
     searchFieldElement.sendKeys(Keys.ENTER); 
    } 


    private void quit() { 
     webDriver.quit(); 
    } 


    @Test 
    public void Start() throws URISyntaxException { 

     // Test for each browser definition 
     for (Browser browser : Browser.values()) { 
      ConfigTests configTests = new ConfigTests(browser); 
      configTests.goToLocalPartsfinder(); 
      configTests.quit(); 
     } 
    } 
} 

사람이 나에게 힌트를 줄 수 있을까? 다른 geckodriver 및 selenium 버전을 이미 사용했습니다. 나는 FF의 버전을 변경하는 것이 허용되지 않기 때문에 IT의 제한 ...

나는 어떤 성공도없이 FirefoxOptions을 잔뜩 시도했다.

나는 크롬이 잘 작동하는지 궁금하지만 파이어 폭스는 아무 것도하지 않는다.

UPDATE :

//build.gradle 
dependencies { 
    compile group: 'org.seleniumhq.selenium', name: 'selenium-java', version: '3.8.0' 
    compile "org.seleniumhq.selenium:selenium-chrome-driver:3.8.0" 
    compile "org.seleniumhq.selenium:selenium-firefox-driver:3.8.0" 
} 

UPDATE2 :

java.lang.NoClassDefFoundError: org/openqa/selenium/MutableCapabilities 

    at java.lang.ClassLoader.defineClass1(Native Method) 
    at java.lang.ClassLoader.defineClass(ClassLoader.java:763) 
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142) 
    at java.net.URLClassLoader.defineClass(URLClassLoader.java:467) 
    at java.net.URLClassLoader.access$100(URLClassLoader.java:73) 
    at java.net.URLClassLoader$1.run(URLClassLoader.java:368) 
    at java.net.URLClassLoader$1.run(URLClassLoader.java:362) 
    at java.security.AccessController.doPrivileged(Native Method) 
    at java.net.URLClassLoader.findClass(URLClassLoader.java:361) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424) 
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357) 
    at org.openqa.selenium.chrome.ChromeDriver.<init>(ChromeDriver.java:123) 
    at com.bilsteingroup.css.pf2.seleniumtests.ConfigTests.<init>(ConfigTests.java:38) 
    at com.bilsteingroup.css.pf2.seleniumtests.ConfigTests.Start(ConfigTests.java:70) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:498) 
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50) 
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) 
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47) 
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) 
    at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325) 
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78) 
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57) 
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290) 
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71) 
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288) 
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58) 
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268) 
    at org.junit.runners.ParentRunner.run(ParentRunner.java:363) 
    at org.junit.runner.JUnitCore.run(JUnitCore.java:137) 
    at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:68) 
    at com.intellij.rt.execution.junit.IdeaTestRunner$Repeater.startRunnerWithArgs(IdeaTestRunner.java:47) 
    at com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:242) 
    at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:70) 

그래서 나는 여전히이 있음을 추측 :

드라이버 종속성을 추가 할 build.gradle을 변경 한 후,이 예외가 의존성 누락, 그렇지 않아?

+0

셀레늄'3.7.1' 또는 '3.5'에서 작동합니까? –

+0

3.7.1 시도했는데 그다지 사용하지 못했습니다. 3.5도 확인할 수 있습니다. – Ismoh

+0

3.5에 FirefoxDriver 클래스가 없으므로 사용 방법을 모른다. 어떤 힌트? – Ismoh

답변

2

문제가없는 dependecies

다운로드 모든 관련 셀레늄 종속성에 의해 발생합니다.

compile group: 'org.seleniumhq.selenium', name: 'selenium-java', version: '3.8.0' 
compile 'org.seleniumhq.selenium:selenium-java:3.8.0' 
compile 'org.seleniumhq.selenium:selenium-server:3.8.0' 
compile 'org.seleniumhq.selenium:selenium-api:3.8.0' 
compile 'org.seleniumhq.selenium:selenium-support:3.8.0' 
compile 'org.seleniumhq.selenium:selenium-remote-driver:3.8.0' 
compile 'org.seleniumhq.selenium:selenium-chrome-driver:3.8.0' 
compile 'org.seleniumhq.selenium:selenium-firefox-driver:3.8.0' 
+1

Rafał Laskowski 감사합니다. 너 나 많이 도와 줬어! – Ismoh