Hamcrest가 제공하는 문자열 Matcher들에 대해서 알아봅니다.
프로젝트 의존성 설정
Gradle 프로젝트는 build.gradle
에서 아래와 같이 java-hamcrest
를 추가합니다.
dependencies {
testImplementation 'org.hamcrest:java-hamcrest:2.0.0.0'
}
Equality
equalTo()
는 두개의 문자열이 동등한지 확인하는 Matcher입니다. 문자열을 비교할 때 대소문자를 구분합니다.
@Test
public void testStringsEquals() {
String str1 = "equals";
String str2 = "EQUALS";
String str3 = "equals";
assertThat(str1, equalTo(str3));
assertThat(str1, not(equalTo(str2)));
}
대소문자 구분하지 않고 비교하고 싶다면 equalToIgnoringCase()
를 사용할 수 있습니다.
@Test
public void testStringsEquals2() {
String str1 = "equals";
String str2 = "EQUALS";
assertThat(str1, equalToIgnoringCase(str2));
}
또한, 대소문자도 구분하지 않으면서, 문자열 앞, 뒤의 공백도 무시하고 싶다면 equalToIgnoringWhiteSpace()
를 사용할 수 있습니다.
@Test
public void testStringsEquals3() {
String str1 = "equals";
String str2 = " EQUALS ";
assertThat(str1, equalToIgnoringWhiteSpace(str2));
}
Empty
emptyString()
는 문자열이 empty인지 확인하는 Matcher입니다.
만약 null과 empty를 함께 확인하고 싶다면 emptyOrNullString()
를 사용할 수 있습니다.
@Test
public void testStringsEmpty() {
String emptyStr = "";
String nullStr = null;
assertThat(emptyStr, emptyString());
assertThat(nullStr, emptyOrNullString());
}
문자열 비교
Regex Pattern
문자열을 비교할 때 정규표현식으로 비교할 수 있습니다. matchesPattern()
는 문자열이 인자로 전달된 정규표현식과 일치하는지 확인하는 Matcher입니다.
@Test
public void testStringsPattern() {
String str = "String Pattern Matchers";
assertThat(str, matchesPattern("String.*Matchers"));
}
Contains
containsString()
은 문자열에 특정 문자열이 포함되어있는지 확인하는 Matcher입니다.
대소문자를 구분하고 싶지 않다면 containsStringIgnoringCase()
를 사용하면 됩니다.
@Test
public void testStringsContains() {
String str = "String Pattern Matchers";
assertThat(str, containsString("Matchers"));
assertThat(str, containsStringIgnoringCase("pattern"));
}
StartsWith
문자열이 특정 문자열로 시작하는지 확인하려면 startsWith()를 사용하고, 대소문자 구분이 필요없다면 startsWithIgnoringCase()
를 사용할 수 있습니다.
@Test
public void testStringsStartsWith() {
String str = "String Pattern Matchers";
assertThat(str, startsWith("String"));
assertThat(str, startsWithIgnoringCase("string"));
}
EndsWith
문자열이 특정 문자열로 끝나는지 확인하려면 endsWith()를 사용하고, 대소문자 구분이 필요없다면 endsWithIgnoringCase()
를 사용할 수 있습니다.
@Test
public void testStringsEndsWith() {
String str = "String Pattern Matchers";
assertThat(str, endsWith("Matchers"));
assertThat(str, endsWithIgnoringCase("matchers"));
}
Related Posts
- Java - Unsupported class file major version 61 에러
- Java - String.matches()로 문자열 패턴 확인 및 다양한 예제 소개
- Java - 문자열 공백제거 (trim, replace)
- Java - replace()와 replaceAll()의 차이점
- Java - ArrayList 초기화, 4가지 방법
- Java - 배열 정렬(Sorting) (오름차순, 내림차순)
- Java - 문자열(String)을 비교하는 방법 (==, equals, compare)
- Java - StringBuilder 사용 방법, 예제
- Java - 로그 출력, 파일 저장 방법 (Logger 라이브러리)
- Java IllegalArgumentException 의미, 발생 이유
- Java - NullPointerException 원인, 해결 방법
- Seleninum의 ConnectionFailedException: Unable to establish websocket connection 해결
- Java - compareTo(), 객체 크기 비교
- Java - BufferedWriter로 파일 쓰기
- Java - BufferedReader로 파일 읽기
- Java charAt() 함수 알아보기
- Java - BigInteger 범위, 비교, 연산, 형변환
- Java contains()로 문자(대소문자 X) 포함 확인
- Java - Set(HashSet)를 배열로 변환
- Java - 문자열 첫번째 문자, 마지막 문자 확인
- Java - 문자열 한글자씩 자르기
- Java - 문자열 단어 개수 가져오기
- Java - 1초마다 반복 실행
- Java - 배열을 Set(HashSet)로 변환
- Java - 여러 Set(HashSet) 합치기
- Java - 명령행 인자 입력 받기
- Java - 리스트 역순으로 순회, 3가지 방법
- Java - 특정 조건으로 리스트 필터링, 3가지 방법
- Java - HashMap 모든 요소들의 합계, 평균 계산
- Java - 특정 조건으로 HashMap 필터링
- Java - 싱글톤(Singleton) 패턴 구현
- Java - 숫자 왼쪽에 0으로 채우기
- Java - String 배열 초기화 방법
- Java - 정렬된 순서로 Map(HashMap) 순회
- Java - HashMap에서 key, value 가져오기