gpt4 book ai didi

java - 来自命令行的 NullPointerException,而不是在 IntelliJ 调试器中

转载 作者:行者123 更新时间:2023-11-30 11:13:59 26 4
gpt4 key购买 nike

当从命令行运行 JUnit 测试时,我得到一个 NullPointerException,但是当通过 IntelliJ 的调试器运行时,没有抛出任何异常。

这里是相关的异常信息:

java.lang.NullPointerException
at org.ecx.test.models.AbstractPage.open(AbstractPage.java:98)
at org.ecx.test.UserContext.login(UserContext.java:64)
at org.ecx.test.TabMemory.TabMemoryTest(TabMemory.java:21)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:47)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:44)
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26)
at org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:27)
at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:271)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:70)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:50)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:238)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:63)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:236)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:53)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:229)
at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26)
at org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:27)
at org.junit.runners.ParentRunner.run(ParentRunner.java:309)
at org.junit.runners.Suite.runChild(Suite.java:127)
at org.junit.runners.Suite.runChild(Suite.java:26)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:238)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:63)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:236)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:53)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:229)
at org.junit.runners.ParentRunner.run(ParentRunner.java:309)
at org.junit.runner.JUnitCore.run(JUnitCore.java:160)
at org.junit.runner.JUnitCore.run(JUnitCore.java:138)
at org.junit.runner.JUnitCore.run(JUnitCore.java:117)
at org.junit.runner.JUnitCore.runMain(JUnitCore.java:96)
at org.junit.runner.JUnitCore.runMainAndExit(JUnitCore.java:47)
at org.junit.runner.JUnitCore.main(JUnitCore.java:40)

我不确定是什么导致了这个问题,因为有问题的行是:driver.navigate().to(url);

并且 url 是一个字符串,它被硬编码到重写的 getPageUrl() 方法中。 WebDriver 启动正常,因为指定的浏览器打开,并且在其他脚本(实用程序、测试数据管理等)中起作用,这很有趣,因为相同的代码用于管理驱动程序/selenium 实例。

IntelliJ 的调试配置没有指定其他参数,除了将 -ea 传递给 Java VM,这是默认设置。

AbstractTest.open:

public void open() {
if (!isInitialized) {
throw new IllegalStateException("Page not initialized.");
}
String url = Environment.getBaseUrl() + getPageUrl();
Log.debug("Opening url: %s", url);
WebDriver.Navigation navigation = driver.navigate(); //Error is thrown here.
navigation.to(url);
//driver.navigate().to(url);
PageFactory.initElements(driver, this);
isLoaded = true;
}

抽象测试(构造函数):

public AbstractPage(Selenium selenium) {
this.selenium = selenium;
if (WebDriverBackedSelenium.class.isInstance(selenium)) {
this.driver = ((WebDriverBackedSelenium) selenium).getWrappedDriver();
}
PageFactory.initElements(driver, this);
uiMap = new Properties();
initialize();
}

环境.openSelenium:

public static void openSelenium() {
if (!isSelenium) {
Log.info("Opening Selenium...");
driver = WebDriverFactory.getWebDriver();
selenium = new WebDriverBackedSelenium(driver, Environment.getBaseUrl());
Environment.setIsSelenium(true);
seleniumExtension = SeleniumExtension.getInstance();
}
}

最佳答案

@Jerry101 的建议很好。但是,如果您想要一种不更改源代码(或者您无法更改代码)的方法来执行此操作,您还可以在 IDEA 中创建远程调试配置。这将允许您在出现 null 时在环境中运行它,但使用 IDEA 调试器查看问题所在。

Run/Debug Configurations 对话框中,单击添加按钮 Add Button并选择 Remote Debug Icon 远程。您可能希望使用 Listen 调试器模式,以便您可以先启动调试器。您可以使用 Attach 模式,但需要确保在从命令行开始测试后,在它到达有问题的代码之前,您可以快速启动 IDEA 调试配置。对于非生产系统,Listen 就可以了。

当您通过命令行运行测试时,将必要的配置选项(如 IDEA 远程调试配置对话框中所示)添加到您的命令行。当命中断点时,您可以看到什么是 null

关于java - 来自命令行的 NullPointerException,而不是在 IntelliJ 调试器中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26130029/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com