클라우드 환경에서 테스트할 때 디비 사용법이 궁금해요
688
작성한 질문수 1
GitHub Actions을 사용하여 우분투 가상환경 위에서 스프링 부트 프로젝트를 빌드할 일이 있었는데요. 빌드 과정에서 테스트를 실행하는 단계가 있더라구요! application-test.yml에서 사용할 db의 정보를 지정하는 부분에 로컬 호스트 디비를 사용했는데 우분투 가상환경에서 테스트가 수행되다보니로컬호스트 디비와 연결하는 과정에서 커넥션 에러가 뜨더라구요 ㅠㅠ
이런 경우에선 테스트 환경에서 인메모리 디비를 사용해야 하나요..??어떤 방법이 최선인지 궁금해서 질문 남기게 되었습니다!
답변 2
2
안녕하세요, Kimyubi님! :)
맞습니다. 원격 환경에서의 실행을 고려하기 때문에 저도 강의 중에서 별도의 로컬 DB를 띄워서 테스트하는 것이 아니라, 어디서든 실행할 수 있는 인메모리 DB를 사용한 것이었어요.
H2를 사용하지 않고 싶다면 해당 환경에 테스트용 로컬 DB를 구축하는 방법이 있긴 하지만, 추천드리고 싶지는 않습니다 ㅎㅎ (서버를 내렸다 올린다던가, 배포 시마다 같이 확인해야 하는 관리포인트가 되기 때문입니다.)
도움이 되셨기를 바랍니다.
감사합니다 :)
1
안녕하세요. 해당 강의를 수강하고 있는 테스트 초짜 입니다.
제가 말하는게 답이 아닐 수도 있습니다. 따라서 강사님은 제가 답한것이 적절치 않다고 판단 하신다면 편하게 지적드리면 감사드리겠습니다.
application-test를 이용해서 로컬에서 테스트를 진행할때 커넥션 에러가 뜬다고 말씀해주셨는데... 다음과 같은 경우로 판단할 수 있겠습니다.
test 프로파일로 테스트가 실행되지 않았을 수도 있습니다. 따라서 실제로 application-test에 적힌 datasource로 connection이 이뤄지지 않았을 수도 있습니다.
Test 종속성에 H2 인메모리 디비가 추가되지 않았을 수도 있습니다.
더 자세한 실행 로그, 환경, 코드 정보등을 남겨주신다면 강사님이 답변 하시는데 도움이 될 수 있을 것 같습니다.
논외로 커넥션이 문제가 아니라고 가정했을때, 커넥션이 이뤄진다고 해도 mysql, H2(인메모리 디비)의 호환성 차이로 기능을 제대로 못할 수도 있습니다. 이 경우에는 datasource.url의 ?MODE=MYSQL를 추가할 수도 있지만
다른 문제 (예약어...) 등으로 해결이 안되실 수 도 있습니다.
private 상수 테스트 관련 질문
0
83
1
void는 어떻게 테스트하나요..? void로 애초에 코딩하면 안되나요??
0
126
2
커버리지는 어떻게 활용하시는지 궁금합니다.
0
161
2
테스트 문서화 질문입니다
0
105
2
단위테스트 질문이 있습니다
0
96
2
컨트롤러는 모킹을 한 이유가 궁금합니다.
0
103
2
ERD 가장자리에 있는 도메인 테스트 질문
0
89
2
DTO 검증 필드에 대한 테스트 코드 작성은 어디까지?
0
135
2
OrderCreateRequest DTO에 대해서 궁금한점
0
102
2
고전파의 테스트 대역 사용 대상, 공유 의존성
0
156
2
계층 관련 질문이 있습니다.
0
139
3
'코틀린'에서는 빌더를 따로 쓰지 않는데, 이 때는 어떻게 test fixture를 만드시는지 궁금합니다
1
124
2
혹시 update 로직은 어떻게 테스트하나요? (@Setter?)
0
135
2
단위테스트와 통합테스트의 경계가 궁금합니다.
0
229
2
Service+Repository 통합테스트 관련 질문입니다.
0
150
2
OrderControllerDocsTest 작성 해봤는데요. 날짜 형식이 이상하게 나와요
0
185
2
test 용 .yml
0
90
2
throws Exception
0
80
2
카페키오스크 클래스 문의 ,,
0
89
2
Rest docs 문서용 테스트코드를 따로 작성해야 되나요?
0
174
2
테스트 코드에서 필요한 생성자
0
138
1
tearDown 순서
0
116
2
@Builder 생성자 private
0
136
2
@DisplayName gradle / intellJ
0
93
2





