JUnit 4 @BeforeClass & @AfterClass при использовании комплектов - PullRequest
29 голосов
/ 17 декабря 2009

При использовании этого подхода ниже, путем настройки jUnit с комплектами. У нас возникла проблема, когда все @BeforeClass в каждом Testclass будут выполняться до того, как начнут выполняться какие-либо тесты. (Для каждого n файла TestClass запускается @BeforeClass, затем после их выполнения он начинает выполнять первые файлы MyTest.class @Test)

Это приведет к тому, что мы выделим много ресурсов и памяти. Я думал, что это должно быть неправильно, не должен ли каждый @BeforeClass запускаться только до того, как будет выполнен настоящий тестовый класс, а не при запуске Suite?

@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
        ...

Ответы [ 3 ]

50 голосов
/ 17 декабря 2009

Напишите метод @BeforeClass в классе AllTests, который будет выполняться при запуске набора.

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");
    }

}

OUTPUT

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

НТН

1 голос
/ 17 декабря 2009

Я не слишком знаком с @RunWith в JUnit, поэтому, возможно, я сделал что-то не так, но я не могу воспроизвести поведение, которое вы описываете. С классом:

@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

Это с JUnit 4.5.0 (JUnit по умолчанию в Eclipse 3.5.1) на JDK Sun 1.6.0_12. Можете ли вы заметить разницу в моем примере от вашего? Возможно, другой JDK / JVM? Я не знаю достаточно о внутренностях JUnit, чтобы знать, могут ли они быть фактором.

0 голосов
/ 17 декабря 2009

Я думаю, @BeforeClass выполняется в момент инстанции.

...