스프링통합테스트시.. IllegalStateException
h2 데이터에는 delete from member 로 데이터 다 삭제한 상태인데
package hello.hellospring.service;
import hello.hellospring.domain.Member;
import hello.hellospring.repository.MemberRepository;
import org.assertj.core.api.Assertions;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.transaction.annotation.Transactional;
import java.util.ArrayList;
import java.util.List;
import static org.junit.jupiter.api.Assertions.assertThrows;
@SpringBootTest
@Transactional
class MemberServiceIntegrationTest {
//@SpringBootTest 스프링 컨테이너와 테스트를 연결해줌.
//@Transactional test 함수 하나를 실행 후 commit까지 하지 않고 rollback을 시켜준다. 따라서 store.clear()같은 게 필요 없다.
@Autowired MemberService memberService;
@Autowired MemberRepository memberRepository;
/*@BeforeEach
void beforeEach() {
memberRepository = new MemoryMemberRepository();
memberService = new MemberService(memberRepository);
는 순수 java의 테스트여서 Spring 통합테스트에서는 @BeforeEach를 사용하지 않고
@Autowired를 통해 객체를 끌어다 쓴다. 단, 생성자를 만들어도 되지만
테스트는 객체를 다른데서 이어서 쓸 게 아니기 때문에 편하게 @Autowired만으로 써도 된다.
참고. 현재 MemberRepository는 new JdbcMemberRepository(dataSource); 로 등록되어 있다.
}*/
@Test
void join() {
Member member = new Member();
member.setName("hi2");
Long savedId = memberService.join(member);
Member savedMember = memberRepository.findById(savedId).get();
Assertions.assertThat(savedMember.getName()).isEqualTo(member.getName());
}
@Test
void validDuplicateMember() {
Member member1 = new Member();
member1.setName("hi123");
Member member2 = new Member();
member2.setName("hi123");
memberService.join(member1);
IllegalStateException e = assertThrows(IllegalStateException.class, () -> { memberService.join(member2); });
Assertions.assertThat(e.getMessage()).isEqualTo("이미존재하는 회원입니다");
}
를 실행하면 모든 함수에서 이미존재하는 회원이라고 뜹니다(다른 Test코드 포함)
2021-05-29 11:42:58.502 INFO 14008 --- [ main] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Starting...
2021-05-29 11:42:58.785 INFO 14008 --- [ main] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Start completed.
2021-05-29 11:42:58.806 INFO 14008 --- [ main] o.s.t.c.transaction.TransactionContext : Began transaction (1) for test context [DefaultTestContext@45815ffc testClass \ 생략..
2021-05-29 11:42:59.813 INFO 14008 --- [ main] o.s.t.c.transaction.TransactionContext : Rolled back transaction for test: [DefaultTestContext@45815ffc testClass = 생략.. ApplicationEventsTestExecutionListener.recordApplicationEvents' -> false]]
java.lang.IllegalStateException: 이미존재하는회원입니다
at hello.hellospring.service.MemberService.lambda$validDuplicateMember$0(MemberService.java:24)
at java.base/java.util.Optional.ifPresent(Optional.java:183)
at hello.hellospring.service.MemberService.validDuplicateMember(MemberService.java:23)
at hello.hellospring.service.MemberService.join(MemberService.java:17)
at hello.hellospring.service.MemberServiceIntegrationTest.validDuplicateMember(MemberServiceIntegrationTest.java:48)
<..생략..>
at com.intellij.rt.junit.JUnitStarter.main(JUnitStarter.java:54)
이라고 나옵니다.
순수JDBC 테스트코드에선 정상작동하는데
이것저것해보다가 안돼서 질문남깁니다.. 죄송합니다 :(
JDBC순수 test코드:
package hello.hellospring.service;
import hello.hellospring.domain.Member;
import hello.hellospring.repository.MemberRepository;
import hello.hellospring.repository.MemoryMemberRepository;
import org.assertj.core.api.Assertions;
import org.junit.jupiter.api.AfterEach;
import static org.junit.jupiter.api.Assertions.*;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import java.util.ArrayList;
import java.util.List;
import java.util.Optional;
class MemberServiceTest {
MemberService memberService;
MemoryMemberRepository memberRepository;
@BeforeEach
void beforeEach() {
memberRepository = new MemoryMemberRepository();
memberService = new MemberService(memberRepository);
}
@AfterEach
void afterEach() {
memberRepository.clearStore();
}
@Test
void join() {
Member member = new Member();
member.setName("hi");
Long savedId = memberService.join(member);
Member savedMember = memberRepository.findById(savedId).get();
Assertions.assertThat(savedMember.getName()).isEqualTo(member.getName());
}
@Test
void validDuplicateMember() {
Member member1 = new Member();
member1.setName("hi");
Member member2 = new Member();
member2.setName("hi");
memberService.join(member1);
IllegalStateException e = assertThrows(IllegalStateException.class, () -> { memberService.join(member2); });
Assertions.assertThat(e.getMessage()).isEqualTo("이미존재하는회원입니다");
}
MemberService 코드 :
package hello.hellospring.service;
import hello.hellospring.domain.Member;
import hello.hellospring.repository.MemberRepository;
import java.util.List;
import java.util.Optional;
public class MemberService {
MemberRepository memberRepository;
public MemberService(MemberRepository memberRepository) {
this.memberRepository = memberRepository;
}
public Long join(Member member) {
validDuplicateMember(member);//name중복확인
memberRepository.save(member);
return member.getId();
}
private void validDuplicateMember(Member member) {
memberRepository.findByName(member.getName()).ifPresent(m -> {
throw new IllegalStateException("이미존재하는회원입니다");
});
}
답변 2
1
안녕하세요. relate16님
확인해보니 JdbcMemberRespository.findByName()의 로직이 잘못 작성되어 있습니다.
member 객체 조건과 무관하게 항상 반환하도록 개발되어 있습니다.
메뉴얼을 참고해서 해당 로직을 다시 작성해주세요.
감사합니다.
0
해결하고 의문점이 생겼어서 답글로 한 번 더 물어봤는데(현재는 삭제한 상태입니다),
고민하고 쭉 타고 올라가길 반복하면서
다 해결했습니다 !! 정말정말 감사합니다 ! :]
인텔리제이 오류
0
50
1
..
0
113
2
Unused property.....
0
121
2
project JDK is misconfigured
0
166
2
외부 API의 ID 타입(String/UUID)과 내부 도메인의 ID 타입(Long)이 불일치할 때의 설계 정석
0
102
2
단위/통합 테스트 버전충돌 문제
0
103
2
❗️springboot 4.0.2 버전 aspectj dependency 설정❗️
0
256
1
왜 컨트롤러는 변한게 없는데 새로 만든 html 파일이 뜨나요?
0
125
2
윈도우 build test오류 질문
1
123
2
테스트 관련 공부에 대한 조언을 얻고 싶습니다
0
113
2
테스트 실행 시 에러 질문
0
316
1
name을 통한 비교와 객체를 통한 비교
0
82
1
빌드 후 libs 없음
1
149
1
윈도우 gradlew.bat 에러
0
186
1
@PostMapping("/members/new")가 동작하지 않습니다
0
98
1
java static class와 kotlin class
0
89
1
스프링 DB연결
0
145
1
소요 시간
0
96
2
ddl.sql에 빨간 밑줄
1
118
2
welcome page 에러
0
201
3
잘 모르겠습니다.
0
173
2
fail을 똑같이 쳤는데 오류가 발생해요
0
173
2
index.html Welcome page
0
137
1
프로젝트 gradle-groovy ?
0
403
1





