Eclipse throws java.lang.NullPointerException when running Spring JUnit

2022-09-02 21:22:13

当我运行我的 junit 测试时,控制台打印此 Excpetion:

java.lang.NullPointerException
at org.eclipse.jdt.internal.junit4.runner.SubForestFilter.shouldRun(SubForestFilter.java:81)
at org.junit.internal.runners.JUnit4ClassRunner.filter(JUnit4ClassRunner.java:110)
at org.junit.runner.manipulation.Filter.apply(Filter.java:47)
at org.junit.internal.requests.FilterRequest.getRunner(FilterRequest.java:34)
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestLoader.createFilteredTest(JUnit4TestLoader.java:77)
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestLoader.createTest(JUnit4TestLoader.java:68)
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestLoader.loadTests(JUnit4TestLoader.java:43)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:444)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:675)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:382)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192)

像这样的基本测试对象

import org.junit.runner.RunWith;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.test.context.transaction.TransactionConfiguration;
import org.springframework.transaction.annotation.Transactional;

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = {
            "classpath*:config/spring/appcontext-*.xml",
            "classpath*:config/sqlmap/*.xml"
})
@TransactionConfiguration(defaultRollback = false)
@Transactional
public abstract class AbstractTestObject {
    static {
        //DOMConfigurator.configure("target/classes/log/log4j.xml");
    }
}

而JUnit方法就像这样:

public class StaffInfoServiceImplTest extends AbstractTestObject{
    @Autowired
    StaffInfoServiceImpl service;

    @Test
    public void insertTest() {
        StaffInfo bo = new StaffInfo();
        bo.setEmail("a@b.com");
        bo.setEntId(1);
        bo.setEntStaffNum("000XXXX");
        bo.setName("julia");
        bo.setPhone("00000000");
        bo.setSerialNum("SD12233KSRONDU189342ND");
        bo.setSuperior(2321);
        bo.setDepartment("Sale");
        bo.setSingleCredit(BigDecimal.valueOf(100));
        bo.setMonthlyCredit(BigDecimal.valueOf(10000));
        SLTContext c = new SLTContext();
        c.setOperator("0000001");
        service.insertStaffInfo(bo, c);
    }
}

我的项目是Java EE项目,使用maven来管理lib,使用spring管理bean。

我的开发环境是:
Mac OS X Yosetime 10.10.4
Eclipse Java EE IDE for Web Developers(版本:Mars Release (4.5.0))
Maven 插件(从 Eclipse->安装新软件)

我想这是eclipse junit和project junit config之间的冲突,但我不确定。

如何解决问题,谢谢。


答案 1

在执行(单个)JUnit测试时,在Eclipse Mars上遇到了相同的NPE。

我试图创建一个全新的工作区,并添加了一些测试类+测试方法,但使用了Eclipse Mars(版本4.12)附带的JUnit库。有了这个库,我可以在火星内执行所有测试。

在另一个工作区/项目中,我在使用旧版本的JUnit之前遇到了问题。

我认为这个旧的JUnit版本是问题所在,将不得不升级到一个更新的版本。


答案 2

是的。我提出了一个针对Eclipse的错误,他们建议将我的依赖关系更改为较新版本的JUnit。

我从JUnit 4.4转到JUnit 4.9,它又开始工作了。


推荐