JUnit單元測試中的setUpBeforeClass()、tearDownAfterClass()、setUp()、tearDown()方法小結
阿新 • • 發佈:2019-01-30
編寫JUnit單元測試的時候,會用到setUpBeforeClass()、tearDownAfterClass()、setUp()、tearDown()這四個方法,例如用eclipse新建一個junit test case的時候,就會有如下圖1的視窗讓你去選擇使用哪些方法(也可以不使用):
圖1:選擇使用哪些方法
上面這四個方法到底有什麼用處,以及使用什麼修飾符,看下面的這個例子就知道了:
import org.junit.After; import org.junit.AfterClass; import org.junit.Before; import org.junit.BeforeClass; import org.junit.Test; public class UserEntityTest { @BeforeClass public static void setUpBeforeClass() throws Exception { System.out.println("this is setUpBeforeClass..."); } @AfterClass public static void tearDownAfterClass() throws Exception { System.out.println("this is tearDownAfterClass..."); } @Before public void setUp() throws Exception { System.out.println("this is setUp..."); } @After public void tearDown() throws Exception { System.out.println("this is tearDown..."); } @Test public void testGetUserId() { System.out.println("this is testGetUserId..."); } @Test public void testGetUserName() { System.out.println("this is testGetUserName..."); } }
上面這段程式碼的執行結果如下:
this is setUpBeforeClass...
this is setUp...
this is testGetUserName...
this is tearDown...
this is setUp...
this is testGetUserId...
this is tearDown...
this is tearDownAfterClass...
看程式碼,再看結果,可以很明顯的發現:
(1)使用@BeforeClass修飾的setUpBeforeClass()方法,在類中所有的方法執行之前執行;那麼,使用@AfterClass修飾的tearDownAfterClass()方法則與之完全相反;可以看到這兩個方法都被static修飾,在類載入以後,這兩個方法就會被載入,並且只會存在一份。
(2)使用@Before修飾的setUp()方法,在每一個@Test測試方法執行之前執行;那麼,使用@After修飾的tearDown()方法則與之完全相反。
如果測試的程式使用jdbc連線資料庫,那麼setUpBeforeClass()方法中就可以寫上初始化資料庫連線的一些程式碼,tearDownAfterClass()方法中就可以寫上關閉資料庫連線的一些程式碼。
原地址:http://yedward.net/?id=288