1

我正在运行一些 Selenium 测试,但无法访问我的测试方法的名称。我想在日志中打印一些东西,比如“开始测试:foobarbaz”

我所有的测试类都继承了一个公共的“AbstractTest”类,其中包含:

@Rule TestName name = new TestName();

@BeforeTest
public void testSetUp(){
    System.out.println(name);
    System.out.println(name.getMethodName());
}

但输出是:

org.junit.rules.TestName@59f63e24
null

为什么 getMethodName() 方法返回 null?

我的 pom.xml 的摘录可能有用...

<dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>4.12</version>
    <scope>test</scope>
</dependency>

<dependency>
    <groupId>org.junit.jupiter</groupId>
    <artifactId>junit-jupiter-api</artifactId>
    <version>5.5.2</version>
    <scope>test</scope>
</dependency>

<dependency>
    <groupId>org.junit.jupiter</groupId>
    <artifactId>junit-jupiter-params</artifactId>
    <version>5.5.2</version>
    <scope>test</scope>
</dependency>
4

2 回答 2

1

如评论中所述,该问题混合了 JUnit 4、JUnit Jupiter (JUnit 5) 和 TestNG,您可能只想关注其中一个。

在 JUnit Jupiter 中,可以通过ExtensionContext. 我不知道仅打印它的内置扩展,但自己编写一个很容易:

public class NamePrinter implements BeforeEachCallback {
    @Override
    public void beforeEach(ExtensionContext extensionContext) throws Exception {
        extensionContext.getTestMethod().ifPresent(m -> System.out.println(
                "Running method: " + m.getName() + 
                " [display name: " + extensionContext.getDisplayName() + ")"));
    }
}

然后您可以将其用作扩展名:

@ExtendWith(NamePrinter.class)
public class MyClassTest {

    @Test
    public void someTest() {
        System.out.println("This is a test");
    }
}
于 2019-12-29T09:18:00.703 回答
0

TestNG 解决方案有效(在另一个线程中找到):https ://stackoverflow.com/a/12202455/7093031

import java.lang.reflect.Method;

public class Test {

    @BeforeMethod
    public void handleTestMethodName(Method method){
        String testName = method.getName(); 
    }

}
于 2019-12-30T03:24:25.030 回答