2015-01-26 1 views
0

필자는 필요할 때 Firefox를 주입하기 위해 CDI를 사용하려고합니다. (항상 드라이버를 구성하는 것을 피하십시오). 그러나 나는 항상 NullPointer을 얻고 있습니다. CDI FirefoxDriver (Selenium)을 삽입 할 수 없습니다.

나는 파이어 폭스 드라이버

@ApplicationScoped 
public class FirefoxDriverProducer { 

    @Produces @RequestScoped 
    public FirefoxDriver getDriver() { 

     // Inicia o Firefox pelo Selenium 
     String caminhoFirefox = "/usr/bin/firefox"; 
     String profileFirefox = "Selenium"; 

     // Aponta o caminho para o firefox 
     File pathToBinary = new File(caminhoFirefox); 
     FirefoxBinary ffBinary = new FirefoxBinary(pathToBinary); 

     // Profile que precisa ser criado no firefox 
     ProfilesIni profile = new ProfilesIni(); 
     FirefoxProfile myprofile = profile.getProfile(profileFirefox); 

     // Proxy 
     String PROXY = "companyproxy:8080"; 
     org.openqa.selenium.Proxy proxy = new org.openqa.selenium.Proxy(); 
     proxy.setHttpProxy(PROXY).setFtpProxy(PROXY).setSslProxy(PROXY); 
     DesiredCapabilities cap = new DesiredCapabilities(); 
     cap.setCapability(CapabilityType.PROXY, proxy); 

     FirefoxDriver driver = new FirefoxDriver(ffBinary, myprofile, cap); 

     return driver; 
    } 

    public void close(@Disposes FirefoxDriver driver) { 
     driver.quit(); 
    } 

} 

에 대한 생산을 만들어 그리고 내가 그것을 사용하고자 할 때 내가 같이 호출 :

@Inject 
private FirefoxDriver driver; 

내가 주입하고자하는 다른 객체와 마찬가지로 . 난이도 호출되는 아니에요 getDriver() 생산자 방식 내부에 중단 점을 배치하여, 항상 null의 드라이버를 디버깅 할 때 는하지만 난 항상 내가 이미했습니다 같은 프로젝트에

..., NullPointer 받고 있어요 FacesContextNavigationHandler으로 비슷한 결과를 얻었습니다.

ps : Wildfly 8을 실행 중이며 beans.xml은 (는) 웹 사이트에 있습니다.

ps2 : 이유는 내가 다른 회사 사이트에 액세스하고 때때로 웹 브라우저를 통해서만 웹 서비스 나 다른 것을 제공하지 않기 때문에 때때로 정보를 다운로드해야하기 때문입니다.

ps3 : 나는 CDI를 사용하지 않고 제작자로부터 모든 코드를 가져 와서 클래스에 넣으면 잘 동작한다고합니다. 그래서 내가 그것을 셀레늄에 문제가 아니라고 믿고있어

스택 추적 :

16:48:29,632 WARNING [javax.enterprise.resource.webcontainer.jsf.lifecycle] (default task-43) #{testeBean.teste()}: java.lang.NullPointerException: javax.faces.FacesException: #{testeBean.teste()}: java.lang.NullPointerException 
    at com.sun.faces.application.ActionListenerImpl.processAction(ActionListenerImpl.java:118) [jsf-impl-2.2.8-jbossorg-1.jar:] 
    at javax.faces.component.UICommand.broadcast(UICommand.java:315) [jboss-jsf-api_2.2_spec-2.2.8.jar:2.2.8] 
    at javax.faces.component.UIViewRoot.broadcastEvents(UIViewRoot.java:790) [jboss-jsf-api_2.2_spec-2.2.8.jar:2.2.8] 
    at javax.faces.component.UIViewRoot.processApplication(UIViewRoot.java:1282) [jboss-jsf-api_2.2_spec-2.2.8.jar:2.2.8] 
    at com.sun.faces.lifecycle.InvokeApplicationPhase.execute(InvokeApplicationPhase.java:81) [jsf-impl-2.2.8-jbossorg-1.jar:] 
    at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101) [jsf-impl-2.2.8-jbossorg-1.jar:] 
    at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:198) [jsf-impl-2.2.8-jbossorg-1.jar:] 
    at javax.faces.webapp.FacesServlet.service(FacesServlet.java:646) [jboss-jsf-api_2.2_spec-2.2.8.jar:2.2.8] 
    at io.undertow.servlet.handlers.ServletHandler.handleRequest(ServletHandler.java:85) [undertow-servlet-1.1.0.Final.jar:1.1.0.Final] 
    at io.undertow.servlet.handlers.security.ServletSecurityRoleHandler.handleRequest(ServletSecurityRoleHandler.java:61) [undertow-servlet-1.1.0.Final.jar:1.1.0.Final] 
    at io.undertow.servlet.handlers.ServletDispatchingHandler.handleRequest(ServletDispatchingHandler.java:36) [undertow-servlet-1.1.0.Final.jar:1.1.0.Final] 
    at org.wildfly.extension.undertow.security.SecurityContextAssociationHandler.handleRequest(SecurityContextAssociationHandler.java:78) 
    at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43) [undertow-core-1.1.0.Final.jar:1.1.0.Final] 
    at io.undertow.servlet.handlers.security.SSLInformationAssociationHandler.handleRequest(SSLInformationAssociationHandler.java:131) [undertow-servlet-1.1.0.Final.jar:1.1.0.Final] 
    at io.undertow.servlet.handlers.security.ServletAuthenticationCallHandler.handleRequest(ServletAuthenticationCallHandler.java:56) [undertow-servlet-1.1.0.Final.jar:1.1.0.Final] 
    at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43) [undertow-core-1.1.0.Final.jar:1.1.0.Final] 
    at io.undertow.security.handlers.AbstractConfidentialityHandler.handleRequest(AbstractConfidentialityHandler.java:45) [undertow-core-1.1.0.Final.jar:1.1.0.Final] 
    at io.undertow.servlet.handlers.security.ServletConfidentialityConstraintHandler.handleRequest(ServletConfidentialityConstraintHandler.java:63) [undertow-servlet-1.1.0.Final.jar:1.1.0.Final] 
    at io.undertow.security.handlers.AuthenticationMechanismsHandler.handleRequest(AuthenticationMechanismsHandler.java:58) [undertow-core-1.1.0.Final.jar:1.1.0.Final] 
    at io.undertow.servlet.handlers.security.CachedAuthenticatedSessionHandler.handleRequest(CachedAuthenticatedSessionHandler.java:70) [undertow-servlet-1.1.0.Final.jar:1.1.0.Final] 
    at io.undertow.security.handlers.SecurityInitialHandler.handleRequest(SecurityInitialHandler.java:76) [undertow-core-1.1.0.Final.jar:1.1.0.Final] 
    at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43) [undertow-core-1.1.0.Final.jar:1.1.0.Final] 
    at org.wildfly.extension.undertow.security.jacc.JACCContextIdHandler.handleRequest(JACCContextIdHandler.java:61) 
    at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43) [undertow-core-1.1.0.Final.jar:1.1.0.Final] 
    at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43) [undertow-core-1.1.0.Final.jar:1.1.0.Final] 
    at io.undertow.servlet.handlers.ServletInitialHandler.handleFirstRequest(ServletInitialHandler.java:261) [undertow-servlet-1.1.0.Final.jar:1.1.0.Final] 
    at io.undertow.servlet.handlers.ServletInitialHandler.dispatchRequest(ServletInitialHandler.java:247) [undertow-servlet-1.1.0.Final.jar:1.1.0.Final] 
    at io.undertow.servlet.handlers.ServletInitialHandler.access$000(ServletInitialHandler.java:76) [undertow-servlet-1.1.0.Final.jar:1.1.0.Final] 
    at io.undertow.servlet.handlers.ServletInitialHandler$1.handleRequest(ServletInitialHandler.java:166) [undertow-servlet-1.1.0.Final.jar:1.1.0.Final] 
    at io.undertow.server.Connectors.executeRootHandler(Connectors.java:197) [undertow-core-1.1.0.Final.jar:1.1.0.Final] 
    at io.undertow.server.HttpServerExchange$1.run(HttpServerExchange.java:759) [undertow-core-1.1.0.Final.jar:1.1.0.Final] 
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) [rt.jar:1.8.0_25] 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) [rt.jar:1.8.0_25] 
    at java.lang.Thread.run(Thread.java:745) [rt.jar:1.8.0_25] 
Caused by: javax.faces.el.EvaluationException: java.lang.NullPointerException 
    at javax.faces.component.MethodBindingMethodExpressionAdapter.invoke(MethodBindingMethodExpressionAdapter.java:101) [jboss-jsf-api_2.2_spec-2.2.8.jar:2.2.8] 
    at com.sun.faces.application.ActionListenerImpl.processAction(ActionListenerImpl.java:102) [jsf-impl-2.2.8-jbossorg-1.jar:] 
    ... 33 more 
Caused by: java.lang.NullPointerException 
    at br.com.timbrasil.bluemonster.csr.DownloadCsr.<init>(DownloadCsr.java:49) [classes:] 
    at br.com.timbrasil.bluemonster.csr.TesteBean.teste(TesteBean.java:24) [classes:] 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) [rt.jar:1.8.0_25] 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) [rt.jar:1.8.0_25] 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) [rt.jar:1.8.0_25] 
    at java.lang.reflect.Method.invoke(Method.java:483) [rt.jar:1.8.0_25] 
    at javax.el.ELUtil.invokeMethod(ELUtil.java:308) [jboss-el-api_3.0_spec-1.0.3.Final.jar:1.0.3.Final] 
    at javax.el.BeanELResolver.invoke(BeanELResolver.java:537) [jboss-el-api_3.0_spec-1.0.3.Final.jar:1.0.3.Final] 
    at javax.el.CompositeELResolver.invoke(CompositeELResolver.java:256) [jboss-el-api_3.0_spec-1.0.3.Final.jar:1.0.3.Final] 
    at com.sun.el.parser.AstValue.invoke(AstValue.java:286) [javax.el-3.0.1-b05.jar:] 
    at com.sun.el.MethodExpressionImpl.invoke(MethodExpressionImpl.java:304) [javax.el-3.0.1-b05.jar:] 
    at org.jboss.weld.util.el.ForwardingMethodExpression.invoke(ForwardingMethodExpression.java:40) [weld-core-impl-2.2.6.Final.jar:2014-10-03 10:05] 
    at org.jboss.weld.el.WeldMethodExpression.invoke(WeldMethodExpression.java:50) [weld-core-impl-2.2.6.Final.jar:2014-10-03 10:05] 
    at org.jboss.weld.util.el.ForwardingMethodExpression.invoke(ForwardingMethodExpression.java:40) [weld-core-impl-2.2.6.Final.jar:2014-10-03 10:05] 
    at org.jboss.weld.el.WeldMethodExpression.invoke(WeldMethodExpression.java:50) [weld-core-impl-2.2.6.Final.jar:2014-10-03 10:05] 
    at com.sun.faces.facelets.el.TagMethodExpression.invoke(TagMethodExpression.java:105) [jsf-impl-2.2.8-jbossorg-1.jar:] 
    at javax.faces.component.MethodBindingMethodExpressionAdapter.invoke(MethodBindingMethodExpressionAdapter.java:87) [jboss-jsf-api_2.2_spec-2.2.8.jar:2.2.8] 
    ... 34 more 

16:48:29,642 SEVERE [javax.enterprise.resource.webcontainer.jsf.context] (default task-43) javax.faces.el.EvaluationException: java.lang.NullPointerException 
    at javax.faces.component.MethodBindingMethodExpressionAdapter.invoke(MethodBindingMethodExpressionAdapter.java:101) 
    at com.sun.faces.application.ActionListenerImpl.processAction(ActionListenerImpl.java:102) 
    at javax.faces.component.UICommand.broadcast(UICommand.java:315) 
    at javax.faces.component.UIViewRoot.broadcastEvents(UIViewRoot.java:790) 
    at javax.faces.component.UIViewRoot.processApplication(UIViewRoot.java:1282) 
    at com.sun.faces.lifecycle.InvokeApplicationPhase.execute(InvokeApplicationPhase.java:81) 
    at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101) 
    at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:198) 
    at javax.faces.webapp.FacesServlet.service(FacesServlet.java:646) 
    at io.undertow.servlet.handlers.ServletHandler.handleRequest(ServletHandler.java:85) 
    at io.undertow.servlet.handlers.security.ServletSecurityRoleHandler.handleRequest(ServletSecurityRoleHandler.java:61) 
    at io.undertow.servlet.handlers.ServletDispatchingHandler.handleRequest(ServletDispatchingHandler.java:36) 
    at org.wildfly.extension.undertow.security.SecurityContextAssociationHandler.handleRequest(SecurityContextAssociationHandler.java:78) 
    at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43) 
    at io.undertow.servlet.handlers.security.SSLInformationAssociationHandler.handleRequest(SSLInformationAssociationHandler.java:131) 
    at io.undertow.servlet.handlers.security.ServletAuthenticationCallHandler.handleRequest(ServletAuthenticationCallHandler.java:56) 
    at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43) 
    at io.undertow.security.handlers.AbstractConfidentialityHandler.handleRequest(AbstractConfidentialityHandler.java:45) 
    at io.undertow.servlet.handlers.security.ServletConfidentialityConstraintHandler.handleRequest(ServletConfidentialityConstraintHandler.java:63) 
    at io.undertow.security.handlers.AuthenticationMechanismsHandler.handleRequest(AuthenticationMechanismsHandler.java:58) 
    at io.undertow.servlet.handlers.security.CachedAuthenticatedSessionHandler.handleRequest(CachedAuthenticatedSessionHandler.java:70) 
    at io.undertow.security.handlers.SecurityInitialHandler.handleRequest(SecurityInitialHandler.java:76) 
    at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43) 
    at org.wildfly.extension.undertow.security.jacc.JACCContextIdHandler.handleRequest(JACCContextIdHandler.java:61) 
    at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43) 
    at io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43) 
    at io.undertow.servlet.handlers.ServletInitialHandler.handleFirstRequest(ServletInitialHandler.java:261) 
    at io.undertow.servlet.handlers.ServletInitialHandler.dispatchRequest(ServletInitialHandler.java:247) 
    at io.undertow.servlet.handlers.ServletInitialHandler.access$000(ServletInitialHandler.java:76) 
    at io.undertow.servlet.handlers.ServletInitialHandler$1.handleRequest(ServletInitialHandler.java:166) 
    at io.undertow.server.Connectors.executeRootHandler(Connectors.java:197) 
    at io.undertow.server.HttpServerExchange$1.run(HttpServerExchange.java:759) 
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) 
    at java.lang.Thread.run(Thread.java:745) 
Caused by: java.lang.NullPointerException 
    at br.com.timbrasil.bluemonster.csr.DownloadCsr.<init>(DownloadCsr.java:49) 
    at br.com.timbrasil.bluemonster.csr.TesteBean.teste(TesteBean.java:24) 
    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:483) 
    at javax.el.ELUtil.invokeMethod(ELUtil.java:308) 
    at javax.el.BeanELResolver.invoke(BeanELResolver.java:537) 
    at javax.el.CompositeELResolver.invoke(CompositeELResolver.java:256) 
    at com.sun.el.parser.AstValue.invoke(AstValue.java:286) 
    at com.sun.el.MethodExpressionImpl.invoke(MethodExpressionImpl.java:304) 
    at org.jboss.weld.util.el.ForwardingMethodExpression.invoke(ForwardingMethodExpression.java:40) 
    at org.jboss.weld.el.WeldMethodExpression.invoke(WeldMethodExpression.java:50) 
    at org.jboss.weld.util.el.ForwardingMethodExpression.invoke(ForwardingMethodExpression.java:40) 
    at org.jboss.weld.el.WeldMethodExpression.invoke(WeldMethodExpression.java:50) 
    at com.sun.faces.facelets.el.TagMethodExpression.invoke(TagMethodExpression.java:105) 
    at javax.faces.component.MethodBindingMethodExpressionAdapter.invoke(MethodBindingMethodExpressionAdapter.java:87) 
    ... 34 more 

@Edit 내가 FireFoxDriver 주입이

Download 클래스 :

public class DownloadCsr { 

    @Inject 
    private FirefoxDriver driver; 

    public DownloadCsr(String usuario, String senha, LocalDateTime dataInicial, 
      LocalDateTime dataFinal) throws LoginException { 

     driver.get("https://companysite.net"); 

     // Encontra o elemento para inserir o usuario 
     WebElement webUsuario = getElementByLocator(By.name("USER"), driver); 
     // Insere o usuario 
     webUsuario.sendKeys(usuario); 

     // Encontra o elemento para inserir a senha 
     WebElement webSenha = getElementByLocator(By.name("PASSWORD"), driver); 
     // Insere a senha 
     webSenha.sendKeys(senha); 

     // Acha o bot�o de login e clica 
     WebElement button = getElementByLocator(By.name("IMAGE1"), driver); 
     button.click(); 

     // Confere se logou na pagina verificando o titulo dela, do contrario 
     // lança a exceção 
     if (!driver.getTitle().equals("Business Home")) { 
      throw new LoginException("Can't reach the loged-in page"); 
     } 

    } 

테스트를 위해 다음을 사용하고 있습니다.

@Named 
@RequestScoped 
public class TesteBean implements Serializable { 

    public void teste() { 
     LocalDateTime dataInicial = LocalDateTime.now().minusDays(1); 
     LocalDateTime dataFinal = LocalDateTime.now(); 

     try { 
      new DownloadCsr("login", "password", 
        dataInicial, dataFinal); 
     } catch (LoginException e) { 
      // TODO Auto-generated catch block 
      e.printStackTrace(); 
     } 
    } 

} 
+0

과 : 당신은 무엇을 할 수 있는지

은 같은 것입니다. 그리고이 빈 (bean)을 어떻게 부르는 지에 대한 세부 사항을 알려주시겠습니까? –

+0

@ AntoineSabot-Durand 모두를 추가했습니다. – prabello

답변

2

DownloadCsr은 빈이 아닙니다. 그것은 매개 변수를 가진 생성자를 가지며 클래스 TesteBean에서 그것을 인스턴스화합니다. CDI 기능을 사용하려면 CDI 컨테이너가 Bean을 인스턴스화하고 필요한 모든 정보를 다른 주입 가능한 Bean으로 제공해야합니다. 다른 말로하면 : new를 사용하면 관리되지 않는 비 주입 인스턴스를 얻을 수 있습니다.

비즈니스 코드를 생성자에 넣는 것도 나쁜 습관입니다. 생성자는 초기화 코드 만 포함해야합니다. 생성자 (constructor) 동안 아무 필드도 아직 주입되지 않았으므로 비록 여러분의 DownloadCsr이 빈이어야한다는 요구 사항이라도 생성자에 NPE가 있어야합니다.

@Named 
@RequestScoped 
public class TesteBean implements Serializable { 

@Inject 
private DownloadCsr dcsr; 

    public void teste() { 
    LocalDateTime dataInicial = LocalDateTime.now().minusDays(1); 
    LocalDateTime dataFinal = LocalDateTime.now(); 

    try { 
     dcsr.crawl("login","password", dataInicial, dataFinal); 
    } catch (LoginException e) { 
     // TODO Auto-generated catch block 
     e.printStackTrace(); 
    } 
    } 

} 

당신이 FirefoxDriver 주입 빈의 코드의 일부를 줄 수있는 다음 DownloadCsr

public class DownloadCsr { 

    @Inject 
    private FirefoxDriver driver; 

    public void crawl(String usuario, String senha, LocalDateTime dataInicial, 
     LocalDateTime dataFinal) throws LoginException { 

    driver.get("https://companysite.net"); 

    // Encontra o elemento para inserir o usuario 
    WebElement webUsuario = getElementByLocator(By.name("USER"), driver); 
    // Insere o usuario 
    webUsuario.sendKeys(usuario); 

    // Encontra o elemento para inserir a senha 
    WebElement webSenha = getElementByLocator(By.name("PASSWORD"), driver); 
    // Insere a senha 
    webSenha.sendKeys(senha); 

    // Acha o boto de login e clica 
    WebElement button = getElementByLocator(By.name("IMAGE1"), driver); 
    button.click(); 

    // Confere se logou na pagina verificando o titulo dela, do contrario 
    // lança a exceção 
    if (!driver.getTitle().equals("Business Home")) { 
     throw new LoginException("Can't reach the loged-in page"); 
    } 

    } 
} 
+0

DownloadCsr 클래스를 bean으로 만들고 JSF와 함께 사용하여 해당 메소드를 유지하고 삽입을 가능하게하는 경우에는 좋지 않을까요? 내 목표는 매일 실행되도록 다운로드 방법을 예약하는 것이지만 Firefox 드라이버를 사용할 다른 방법도 있습니다. 빈을 사용하는 것이 좋을까요? – prabello

+1

예. 배치를 전면에서 트리거하지 않는 것이 좋습니다. JavaBatch를 사용하거나 Bean을 제한 시간과 함께 EJB로 만들거나 Deltaspike 스케줄 모듈을 사용하여 스케줄을 관리 할 수 ​​있습니다. –

관련 문제