5分でJUnitのポイントを把握


1分目:テストメソッドの宣言
新しいクラスを作成し、テストするメソッドに@Testコメントを追加します.
import org.junit.Test;
import static org.junit.Assert.assertEquals;

public class UserServiceTest{
   @Test
   public void should_success_when_login() {
       assertEqualis(5, 2+ 3);
   }
}

注意:
メソッド側は無視され、テストクラスとして認識されません.
JUnitはpublic以外の方法を発見すると、それを無視します.
メソッドにパラメータがある場合は無視されます.
メソッドが非voidを返すと無視されます.
メソッドがstaticと宣言されると無視されます.
メソッドにJUnitの@Test注記がなければ無視されます.
2分目:Junitライフサイクル
@BeforeClassすべてのテストメソッドを実行する前に実行
@Before各テストメソッド実行先
@Test実行試験方法
@After各試験方法の実行後に実行
@AfterClassすべてのテスターが実行後に実行
public void UserServiceTest{
    private User user;
    @BeforeClass
    public void register(){
         this.user = new User();
    }

    @Before
    public void setup() {
        this.user.setUserName("Aaron");
    }

    @Test
    public void should_success_when_login_with_username() {
         assertNotNull(this.user);
         assertEquals(this.user.getUserName(), "Aaron");
    }

    @After
    public void resetUser() {
        this.user.setUserName("");
    }

    @AfterClass
    public void destroyUser() {
        this.user = null;
    }
}

3分目:JUnit断言
よく使われる断言は次のとおりです.
assertEqualsは、2つのオブジェクトが等しいかどうかを断言します.
assertArrayEqualsは、2つの配列に同じ要素が含まれているかどうかを断言します.
assertTrueは文が真であると断言する.
assertFalse断言文は偽です.
assertNullはオブジェクト参照が空であると断言します.
assertNotNullは、オブジェクト参照が空ではないと断言します.
assertSameは、2つのオブジェクト参照が同じインスタンスを指すと断言します.
assertNotSameは、2つのオブジェクト参照が同じインスタンスではないと断言します.
assertThat断言対象が定められた条件を満たす(後述する)
分目:JUnitが投げ出した異常情報を検証する
ユーザがログインしている間にパラメータが空になって制御ポインタが異常になった場合、JUnitを使用してコードロジックでnullが入力されたときに本当に所望の異常情報が放出されたかどうかを検証するなど、コードから積極的に異常情報が放出される場合があります.
public class UserValidator{
    public void validateUserName(String name) {
        if (String.isEmpty(name)){
             throw new ArgumentException();
        }
    }
}


public class UserValidatorTest {
    private UserValidator userValidator;
    @BeforeClass
    public void setup() {
        userValidator = new UserValidator();
    }

    @Test(expected=ArgumentException.class)
    public void shouldThrowExceptionWhenUsernameIsEmpty() {
        String username = "";
        userValidator.validateUserName(username);
    }

}

5分目:assertThat拡張
    org.junit.AssertのassertThatは最も特別で、プログラマが基本的な断言を拡張したり、サードパーティのマッチングライブラリを使用したりすることを許可するフックメソッドです.次の例では、2つのUserオブジェクトが同じかどうかを判断します.
public class User{
    private String name;

    public void setName(String name){
        this.name = name;
    }
    public String get

    @Override
    public boolean equals(Object obj) {
        User user = (User)obj;
        return name.equals(obj.getName());
    }
    @Override
    public int hashCode(){
        return 1;
    }
}


public class UserTest{
    private User user;

    @Before
    public void setup() {
        this.user = new User();
        this.user.setName("ab");
    }


    @Test
    public void shouldSuccessWhenNameEquals() {
        User actualUser = new User();
        actualUser.setName(this.user.getName());
        assertThat(actualUser, is(this.user));
    }
}