使用套件时的 JUnit 4 @BeforeClass 和 @AfterClass

新手上路,请多包涵

在下面使用此方法时,通过设置带有套件的 jUnit。当每个测试类中的所有 @BeforeClass 都将在任何测试开始执行之前执行时,我们遇到了问题。 (对于@BeforeClass运行的每个n个TestClass文件,然后在它们执行后,它开始执行第一个MyTest.class文件@Test)

这将导致我们分配大量资源和内存。我的想法是它一定是错误的,每个@BeforeClass 不应该只在实际测试类执行之前运行,而不是在套件启动时运行吗?

 @RunWith(Suite.class)
@Suite.SuiteClasses({ MyTests.class, Mytests2.class, n1, n2, n })
public class AllTests {
    // empty
}

public class MyTests {  // no extends here
    @BeforeClass
    public static void setUpOnce() throws InterruptedException {
        ...
    @Test
        ...

public class MyTests2 {  // no extends here
    @BeforeClass
    public static void setUpOnce() throws InterruptedException {
        ...
    @Test
        ...

原文由 Andreas Mattisson 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 460
2 个回答

AllTests 类中写一个 @BeforeClass 方法,套件启动时执行。

 public class MyTests1 {
    @BeforeClass
    public static void beforeClass() {
        System.out.println("MyTests1.beforeClass");
    }

    @Before
    public void before() {
        System.out.println("MyTests1.before");
    }

    @AfterClass
    public static void afterClass() {
        System.out.println("MyTests1.AfterClass");
    }

    @After
    public void after() {
        System.out.println("MyTests1.after");
    }

    @Test
    public void test1() {
        System.out.println("MyTests1.test1");
    }

    @Test
    public void test2() {
        System.out.println("MyTests1.test2");
    }
}

public class MyTests2 {
    @BeforeClass
    public static void beforeClass() {
        System.out.println("MyTests2.beforeClass");
    }

    @Before
    public void before() {
        System.out.println("MyTests2.before");
    }

    @AfterClass
    public static void afterClass() {
        System.out.println("MyTests2.AfterClass");
    }

    @After
    public void after() {
        System.out.println("MyTests2.after");
    }

    @Test
    public void test1() {
        System.out.println("MyTests2.test1");
    }

    @Test
    public void test2() {
        System.out.println("MyTests2.test2");
    }
}

@RunWith(Suite.class)
@Suite.SuiteClasses( { MyTests1.class, MyTests2.class })
public class AllTests {

    @BeforeClass
    public static void beforeClass() {
        System.out.println("AllTests.beforeClass");
    }

    @Before
    public void before() {
        System.out.println("AllTests.before");
    }

    @AfterClass
    public static void afterClass() {
        System.out.println("AllTests.AfterClass");
    }

    @After
    public void after() {
        System.out.println("AllTests.after");
    }

    @Test
    public void test1() {
        System.out.println("AllTests.test1");
    }

    @Test
    public void test2() {
        System.out.println("AllTests.test2");
    }

}

输出:

 AllTests.beforeClass
MyTests1.beforeClass
MyTests1.before
MyTests1.test1
MyTests1.after
MyTests1.before
MyTests1.test2
MyTests1.after
MyTests1.AfterClass
MyTests2.beforeClass
MyTests2.before
MyTests2.test1
MyTests2.after
MyTests2.before
MyTests2.test2
MyTests2.after
MyTests2.AfterClass
AllTests.AfterClass

原文由 nayakam 发布,翻译遵循 CC BY-SA 4.0 许可协议

我不太熟悉 JUnit 中的 @RunWith ,所以我可能做错了什么,但我似乎无法复制您描述的行为。随着班级:

 @RunWith(Suite.class)
@Suite.SuiteClasses( { FirstTest.class, SecondTest.class, ThirdTest.class })
public class AllTests {
    // empty
}

FirstTest.java 看起来像这样:

 public class FirstTest {
    @BeforeClass
    public static void doBeforeClass() {
         System.out.println("Running @BeforeClass for FirstTest");
    }

    @Test
    public void doTest() {
        System.out.println("Running @Test in " + getClass().getName());
    }
}

…与 SecondTest.java 和 ThirdTest.java 几乎相同。我得到测试输出:

 Running @BeforeClass for FirstTest
Running @Test in FirstTest
Running @BeforeClass for SecondTest
Running @Test in SecondTest
Running @BeforeClass for ThirdTest
Running @Test in ThirdTest

这是在 Sun 的 JDK 1.6.0_12 上使用 JUnit 4.5.0(Eclipse 3.5.1 中的默认 JUnit)。你能看出我的例子和你的有什么不同吗?也许是不同的 JDK/JVM?我对 JUnit 的内部结构知之甚少,无法知道这些是否是一个因素。

原文由 Grundlefleck 发布,翻译遵循 CC BY-SA 2.5 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题