Eclipse在运行Spring JUnit时抛出java.lang.NullPointerException

时间:2015-07-17 06:15:01

标签: java eclipse spring maven junit

当我运行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)

和Base测试对象一样

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 manage beans。

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

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

如何解决问题,谢谢。

3 个答案:

答案 0 :(得分:12)

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

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

在我使用旧版JUnit之前遇到问题的其他工作区/项目中。

我认为这个旧的JUnit版本是问题,必须升级到更新的版本。

答案 1 :(得分:5)

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

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

答案 2 :(得分:0)

这样做:

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("file:src/main/webapp/WEB-INF/applicationContext.xml")
@WebAppConfiguration
public class StaffInfoServiceImplTest { ..Your Code.. }