Md *_*lam 14 java parameters junit
我写了一个测试类,如下所示
public class MyParameterizedClassTest extends BaseRepositoryTest {
private int multiplierA;
private int multiplierB;
public MyParameterizedClassTest(int multiplierA) {
this.multiplierA = multiplierA;
}
@Parameters
public static Collection<Object[]> data() {
Object[][] data = new Object[][] { { 1 }, { 5 }, { 121 } };
return Arrays.asList(data);
}
@Test
public void testMultiplyException() {
assertEquals("Result", multiplierA * multiplierA,multiply(multiplierA));
}
public int multiply(int a){
return a*a;
}
}
Run Code Online (Sandbox Code Playgroud)
我的BaseRepositoryTest类如下
@RunWith (Parameterized.class)
@ContextConfiguration(locations = {"classpath:applicationContext.xml"})
public abstract class BaseRepositoryTest extends
AbstractJUnit4SpringContextTests {
@Inject
SessionFactory sessionFactory;
private Transaction transaction;
public Session getSession() {
Session session;
try {
session = sessionFactory.getCurrentSession();
} catch (SessionException se) {
session = sessionFactory.openSession();
}
return session;
}
@Before
public void setUp() throws Exception {
transaction = getSession().beginTransaction();
}
@After
public void tearDown() throws Exception {
if (transaction != null) {
transaction.rollback();
}
getSession().close();
}
@Before
public void baseSetUp() {
MockitoAnnotations.initMocks(this);
}
}
Run Code Online (Sandbox Code Playgroud)
当我运行我的测试类时,它显示为,
Test class should have exactly one public zero-argument constructor:at
org.junit.runners.BlockJUnit4ClassRunner.validateZeroArgConstructor
Run Code Online (Sandbox Code Playgroud)
我想用@参数制作测试方法,所以请任何人都可以帮助找到解决方案
s1m*_*nw1 13
当我导入错误的Test实现时,我遇到了这个问题。当我的构造函数使用 JUnit 5 特性时,我导入了旧的org.junit.Test而不是org.junit.jupiter.api.Test.
我认为问题是你定义了两个测试运行器.一个人自己@RunWith (Parameterized. class)和一个春天,因为一个AbstractJUnit4SpringContextTests定义一个@RunWith(SpringJUnit4ClassRunner.class).
因为Junit只能处理一个@RunWith你只能使用@Parameterized或者AbstractJUnit4SpringContextTests.如果你想使用两者,你必须使用@Parameterized和SpringJUnit4ClassRunner你自己做的相同的逻辑.
一个简单的方法就是使用弹簧org.springframework.test.context.TestContextManager.
@RunWith(Parameterized.class)
@ContextConfiguration(locations = {"classpath:applicationContext.xml"})
public abstract class BaseRepositoryTest extends AbstractJUnit4SpringContextTests {
private TestContextManager testContextManager;
@Before
public void setUpContext() throws Exception {
this.testContextManager = new TestContextManager(getClass());
this.testContextManager.prepareTestInstance(this);
}
}
Run Code Online (Sandbox Code Playgroud)
但这只能确保TestExecutionListener调用s.Spring通常更像应用程序上下文缓存等等.还应该实现一种关闭应用程序上下文的拆除方法.
如果您正在运行单个测试,请确保正确编写了测试类名称
我做的一个常见错误是有一个名为'Foo'的类和一个名为的测试类
'FooTest'
并运行单个单元测试
"富"
而不是'FooTest'
如果'Foo'有一个带参数的公共构造函数,我会得到错误:
java.lang.Exception: Test class should have exactly one public zero-argument constructor
Run Code Online (Sandbox Code Playgroud)