我正在尝试使用以下命令从Java类运行JUnit测试:
JUnitCore core = new JUnitCore();
core.addListener(new RunListener());
core.run(classToRun);
问题是我的JUnit测试需要一个当前在JUnit测试中硬编码的数据库连接。
我正在寻找的是一种以编程方式运行JUnit测试的方法(上图),但是将数据库连接传递给我在运行测试的Java类中创建的数据库连接,而不是在JUnit类中进行硬编码。
基本上像
JUnitCore core = new JUnitCore();
core.addListener(new RunListener());
core.addParameters(java.sql.Connection);
core.run(classToRun);
然后在classToRun中:
@Test
Public void Test1(Connection dbConnection){
Statement st = dbConnection.createStatement();
ResultSet rs = st.executeQuery("select total from dual");
rs.next();
String myTotal = rs.getString("TOTAL");
//btw my tests are selenium testcases:)
selenium.isTextPresent(myTotal);
}
我知道@Parameters,但它似乎不适用于此,因为更多的是使用不同的值多次运行相同的测试用例。我希望我的所有测试用例共享一个数据库连接,我通过配置文件传递给我的java客户端,然后运行那些测试用例(也通过配置文件传入)。
这可能吗?
P.S。我理解这似乎是一种奇怪的做事方式。
答案 0 :(得分:45)
您可以使用java系统属性来实现此目的。
只需在junit命令行中使用-Dconnectionstring=foobar
传递所需内容,或使用java api for system properties以编程方式设置此System.setProperty(String name, String value)
和System.getProperty(String name)
。
在测试中,您可以使用@Before
或@BeforeClass
基于此属性设置公共对象,等待是否要为每个测试运行一次设置(在这种情况下,您可以使用类成员)或每个套件一次(然后使用静态成员)。
您甚至可以使用所有测试用例扩展的抽象类来分解此行为。