从其父项的静态上下文中获取测试 class 名称
Get test class name within static context from it's parent
目前我正在尝试获取静态上下文中继承自 BaseTest 的任何基础 class 的 class 名称。所以为了解释,我正在写一个 base-class
它确实使用了 junit 的 @BeforeClass
。这里的问题是我在 class 的所有测试之前启动了一个假的应用程序,它在内存中有自己的 h2 数据库。我想将数据库命名为测试 class,这样我以后可以看到每次测试写入数据库的内容。
基础测试:
public abstract class BaseTest {
private static final Map<String, String> testConfig = getTestConfig();
private static FakeApplication fakeApplication;
@BeforeClass
public static void onlyOnce(){
fakeApplication = Helpers.fakeApplication(testConfig);
Helpers.start(fakeApplication);
}
@AfterClass
public static void afterClass(){
Helpers.stop(fakeApplication);
fakeApplication = null;
}
private static Map<String, String> getTestConfig() {
//Here should bee FooTest in this case! But actually it's BaseTest
String className = MethodHandles.lookup().lookupClass().getSimpleName();
...
configs.put("db.default.url", "jdbc:h2:file:./data/tests/" + className + ";AUTO_SERVER=TRUE;MODE=Oracle;DB_CLOSE_ON_EXIT=FALSE");
}
例如一些儿童测试:
public class FooTest extends BaseTest{
@Test
public void testFoo(){
}
}
我已经尝试了几件事,据我所知这是不可能的。
但我只是想问问有没有什么我还不知道的。
我找到了使用“@ClassRule”并实现自定义 TestWatcher
的解决方案。由于 starting(Description description)
在 @BeforeClass public static void beforeClass()
方法之前被调用,我可以这样使用它:
这是我的代码:
public abstract class BaseTest {
@ClassRule
public static CustomTestWatcher classWatcher = new CustomTestWatcher();
private static Map<String, String> testConfig;
private static FakeApplication fakeApplication;
public static class CustomTestWatcher extends TestWatcher {
private String className = BaseTest.class.getSimpleName();
public String getClassName() {
return className;
}
private void setClassName(String className) {
this.className = className;
}
@Override
protected void starting(Description description) {
//This will set className to = FooTest!
setClassName(description.getClassName());
System.out.println("\nStarting test class: " + className);
}
}
@BeforeClass
public static void beforeClass() {
//Here now finally is FooTest!
String className = classWatcher.getClassName();
System.out.println("Creating Test Database and Fake Application for " + className);
...
}
目前我正在尝试获取静态上下文中继承自 BaseTest 的任何基础 class 的 class 名称。所以为了解释,我正在写一个 base-class
它确实使用了 junit 的 @BeforeClass
。这里的问题是我在 class 的所有测试之前启动了一个假的应用程序,它在内存中有自己的 h2 数据库。我想将数据库命名为测试 class,这样我以后可以看到每次测试写入数据库的内容。
基础测试:
public abstract class BaseTest {
private static final Map<String, String> testConfig = getTestConfig();
private static FakeApplication fakeApplication;
@BeforeClass
public static void onlyOnce(){
fakeApplication = Helpers.fakeApplication(testConfig);
Helpers.start(fakeApplication);
}
@AfterClass
public static void afterClass(){
Helpers.stop(fakeApplication);
fakeApplication = null;
}
private static Map<String, String> getTestConfig() {
//Here should bee FooTest in this case! But actually it's BaseTest
String className = MethodHandles.lookup().lookupClass().getSimpleName();
...
configs.put("db.default.url", "jdbc:h2:file:./data/tests/" + className + ";AUTO_SERVER=TRUE;MODE=Oracle;DB_CLOSE_ON_EXIT=FALSE");
}
例如一些儿童测试:
public class FooTest extends BaseTest{
@Test
public void testFoo(){
}
}
我已经尝试了几件事,据我所知这是不可能的。 但我只是想问问有没有什么我还不知道的。
我找到了使用“@ClassRule”并实现自定义 TestWatcher
的解决方案。由于 starting(Description description)
在 @BeforeClass public static void beforeClass()
方法之前被调用,我可以这样使用它:
这是我的代码:
public abstract class BaseTest {
@ClassRule
public static CustomTestWatcher classWatcher = new CustomTestWatcher();
private static Map<String, String> testConfig;
private static FakeApplication fakeApplication;
public static class CustomTestWatcher extends TestWatcher {
private String className = BaseTest.class.getSimpleName();
public String getClassName() {
return className;
}
private void setClassName(String className) {
this.className = className;
}
@Override
protected void starting(Description description) {
//This will set className to = FooTest!
setClassName(description.getClassName());
System.out.println("\nStarting test class: " + className);
}
}
@BeforeClass
public static void beforeClass() {
//Here now finally is FooTest!
String className = classWatcher.getClassName();
System.out.println("Creating Test Database and Fake Application for " + className);
...
}