Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- error
- 에스가든스냅
- mac
- extraParams
- Config
- minimalAPI
- vscode
- React
- c#코딩의기술실전편
- 명시적외래키
- 대전본식영상
- c#
- 코드프로그래머스
- 상속
- ViewModel
- .net
- 스냅잘찍음
- scanner
- Request
- 라도무스dvd
- JSON
- EFCore
- JavaScript
- Store
- LINQ
- lazy loading
- ORM
- intellij
- dbContext
- extjs
Archives
- Today
- Total
ejyoo's 개발 노트
[Junit4] 테스트 메소드 실행 순서 결정 본문
JUnit 4.11 버전부터 @FixMethodOrder 어노테이션 생성됨.
테스트 메소드의 실행순서 기준을 잡을 수 있도록 해줌.
@FixMethodOrder 정렬 옵션
속성 | 설명 |
MethodSorters.DEFAULT | HashCode를 기반으로 순서 결정. 사용자 예측 힘듬 |
MethodSorters.JVM | JVM 리턴 순으로 실행. 때에 따라 실행시 변경됨 |
MethodSorters.NAME_ASCENDING | 메소드 명을 오름차순으로 정렬한 순서대로 실행 |
사용 예
package kr.or.ddit.mybatis;
import java.util.List;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.junit.After;
import org.junit.Assert;
import org.junit.Before;
import org.junit.FixMethodOrder;
import org.junit.Test;
import org.junit.runners.MethodSorters;
import ejyoo.dto.MemberVO;
import ejyoo.servlet.util.OracleMyBatisSqlSessionFactory;
@FixMethodOrder(MethodSorters.NAME_ASCENDING)
public class TestOracleMyBatisMemberQuery {
private SqlSessionFactory factory = new OracleMyBatisSqlSessionFactory();
private SqlSession session;
@Before
public void openSession() {
session = factory.openSession();
}
@Test
public void Test1_selectMemberListSQL() {
MemberVO paramTypeMemberVo = new MemberVO();
paramTypeMemberVo.setUserNo(118);
paramTypeMemberVo.setUserId("test1");
paramTypeMemberVo.setUserPw("test");
paramTypeMemberVo.setUserPhone("010-0000-0000");
paramTypeMemberVo.setUserEmail("o3k1@test.com");
List<MemberVO> memberVoList = session.selectList("Member-Mapper.selectMemberList",paramTypeMemberVo);
Assert.assertTrue(memberVoList.size()>0);
}
@Test
public void Test2_selectMemberByInfoSQL() {
MemberVO paramTypeMemberVo = new MemberVO();
paramTypeMemberVo.setUserNo(118);
paramTypeMemberVo.setUserId("test1");
paramTypeMemberVo.setUserPw("test");
paramTypeMemberVo.setUserPhone("010-0000-0000");
paramTypeMemberVo.setUserEmail("o3k1@test.com");
MemberVO memberVo = session.selectOne("Member-Mapper.selectMemberById",paramTypeMemberVo);
Assert.assertEquals("test1", memberVo.getUserId());
}
@Test
public void Test3_selectMemberByIdSQL() {
String userId = "test1";
MemberVO memberVo = session.selectOne("Member-Mapper.selectMemberById",userId);
Assert.assertEquals("test1", memberVo.getUserId());
}
@Test
public void Test4_insertMemberByInfoSQL() {
MemberVO paramTypeMemberVo = new MemberVO();
paramTypeMemberVo.setUserId("test3");
paramTypeMemberVo.setUserPw("1234");
paramTypeMemberVo.setUserPhone("010-0000-0000");
paramTypeMemberVo.setUserEmail("test@test.com");
int cnt = session.insert("Member-Mapper.insertMemberByInfo", paramTypeMemberVo);
Assert.assertEquals(1, cnt);
}
@Test
public void Test5_updateMemberByInfoSQL() {
MemberVO paramTypeMemberVo = new MemberVO();
paramTypeMemberVo.setUserNo(135);
paramTypeMemberVo.setUserId("test4");
paramTypeMemberVo.setUserPw("1234");
paramTypeMemberVo.setUserPhone("010-1111-1111");
paramTypeMemberVo.setUserEmail("test@test.com");
int cnt = session.update("Member-Mapper.updateMemberByInfo", paramTypeMemberVo);
Assert.assertTrue(cnt == 1);
}
@Test
public void Test6_deleteMemberByIdSQL() {
String userId = "test4";
int cnt = session.update("Member-Mapper.deleteMemberById", userId);
Assert.assertTrue(cnt == 1);
}
@After
public void closeSession() {
session.close();
}
}
'BackEnd > JUnit' 카테고리의 다른 글
[JUnit4] 단정문 및 어노테이션 정리 (0) | 2021.05.19 |
---|---|
[JUnit4, MyBatis] 작성한 CRUD SQL 에 대해 테스트 코드 작성 (0) | 2021.05.19 |
[JUnit4] 사용법 -> 다른 블로그 링크 (0) | 2021.05.19 |
[JUnit4] 단위 테스트 라이브러리 추가 및 코드 (0) | 2021.05.18 |