티스토리 뷰
회원 서비스
package kr.example.spring.service;
import kr.example.spring.domain.Member;
import kr.example.spring.repository.MemberRepository;
import java.util.List;
import java.util.Optional;
public class MemberService {
private final MemberRepository memberRepository = new
MemoryMemberRepository();
// 회원 가입
public Long join(Member member) {
// 같은 이름이 있는 중복 회원 X
validateDuplicateMember(member); // 중복 회원 검증
memberRepository.save(member);
return member.getId();
}
private void validateDuplicateMember(Member member) {
memberRepository.findByName(member.getName())
.ifPresent(m -> {
throw new IllegalStateException("이미 존재하는 회원입니다.");
});
}
// 전체 회원 조회
public List<Member> findmembers(){
return memberRepository.findAll();
}
public Optional<Member> findOne(Long memberId) {
return memberRepository.findById(memberId);
}
}
회원 서비스 테스트
package kr.example.spring.service;
import kr.example.spring.domain.Member;
import kr.example.spring.repository.MemoryMemberRepository;
import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.Test;
import static org.assertj.core.api.Assertions.*;
import static org.junit.jupiter.api.Assertions.*;
class MemberServiceTest {
MemberService memberService = new MemberService();
MemoryMemberRepository memberRepository = new MemoryMemberRepository();
@AfterEach
public void afterEach() {
memberRepository.clearStore();
}
@Test
void 회원가입() {
//given
Member member = new Member();
member.setName("hello");
//when
Long saveId = memberService.join(member);
//then
Member findMember = memberService.findOne(saveId).get();
assertThat(member.getName()).isEqualTo(findMember.getName());
}
@Test
public void 중복_회원_예외() {
//given
Member member1 = new Member();
member1.setName("spring");
Member member2 = new Member();
member2.setName("spring");
//when
memberService.join(member1);
IllegalStateException e = assertThrows(IllegalStateException.class, () -> memberService.join(member2));
assertThat(e.getMessage()).isEqualTo("이미 존재하는 회원입니다.");
//then
}
@Test
void findmembers() {
}
@Test
void findOne() {
}
}
테스트 결과
- 기존에는 회원 서비스가 메모리 회원 리포지토리를 직접 생성하게 했다.
public class MemberService {
private final MemberRepository memberRepository = new MemoryMemberRepository();
...
}
- 회원 리포지토리의 코드가 회원 서비스 코드를 DI 가능하게 변경한다.
public class MemberService {
private final MemberRepository memberRepository;
public MemberService(MemberRepository memberRepository) {
this.memberRepository = memberRepository;
}
...
}
class MemberServiceTest {
MemberService memberService;
MemoryMemberRepository memberRepository;
@BeforeEach
public void beforeEach() {
memberRepository = new MemoryMemberRepository();
memberService = new MemberService(memberRepository);
}
...
}
- @BeforeEach
- 각 테스트 실행 전에 호출된다. 테스트가 서로 영향이 없도록 항상 새로운 객체를 생성하고, 의존관계도 새로 맺어준다.
결과
'Spring' 카테고리의 다른 글
Logback을 이용하여 로그 기록하기 (0) | 2020.10.20 |
---|---|
Interceptor를 통한 로그인 처리 (0) | 2020.10.20 |
Gradle-Spring Project #3 - 도메인, 리포지토리, 테스트 케이스 (0) | 2020.10.06 |
Gradle-Spring Project #2 - 정적 컨텐츠, MVC-템플릿, API (0) | 2020.10.04 |
Gradle-Spring Project #1 - 프로젝트 환경설정 (0) | 2020.10.04 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- mapreduce
- SPARK
- hadoop
- Disk Scheduling
- File Protection
- linux
- springboot
- HDFS
- Replacement Strategies
- 빅데이터 플랫폼
- maven
- Disk System
- gradle
- RAID Architecture
- 하둡
- Variable allocation
- Allocation methods
- jdbc
- JSON
- oracle
- vmware
- I/O Mechanisms
- Spring
- I/O Services of OS
- Free space management
- SQL
- Java
- 빅데이터
- aop
- Flume
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
글 보관함