Необходимо добавить прослушиватель событий в жизненный цикл componentDidMount
:
componentDidMount() {
window.addEventListener('resize', this.handleWindowResize)
}
Не забудьте удалить прослушиватель событий при размонтировании компонента, чтобы избежать утечек памяти:
componentWillUnmount() {
window.removeEventListener('resize', this.handleWindowResize)
}
Напишите метод @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
hth
Я не слишком знаком с @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, чтобы знать, могут ли они быть фактором.
Я думаю, @BeforeClass
выполняется при создании экземпляра.