test 하위에 있는 application.properties를 읽어오지 않는 것 같습니다.
605
작성한 질문수 3
학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.
1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)
질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)
[질문 내용]
안녕하세요! Window, Eclipse 사용하고 있습니다.
testcase용 db 만들어서 testcase.mv.db 파일 생성된 것도 확인하고 jdbc:h2:tcp://localhost/~/testcase 로 접속도 잘 됩니다. test하위에 있는 application.properties도 강의에 말씀하신대로 바꾸어놓았습니다.
그런데 자꾸 findItems() 테스트가 이전 강의에서 나왔던 에러가 발생합니다. testcase h2 db들어가서 select 해보면 아무것도 안나오구요,,
콘솔 창은 아래와 같습니다.
2022-10-07 10:04:43.159 INFO 16288 --- [ main] h.itemservice.domain.ItemRepositoryTest : The following 1 profile is active: "local"
2022-10-07 10:04:45.130 INFO 16288 --- [ main] o.s.b.a.w.s.WelcomePageHandlerMapping : Adding welcome page: class path resource [static/index.html]
2022-10-07 10:04:45.787 INFO 16288 --- [ main] h.itemservice.domain.ItemRepositoryTest : Started ItemRepositoryTest in 2.961 seconds (JVM running for 4.344)
2022-10-07 10:04:45.791 INFO 16288 --- [ main] hello.itemservice.TestDataInit : test data init
2022-10-07 10:04:45.793 DEBUG 16288 --- [ main] o.s.jdbc.core.simple.SimpleJdbcInsert : JdbcInsert not compiled before execution - invoking compile
2022-10-07 10:04:45.803 DEBUG 16288 --- [ main] o.s.jdbc.datasource.DataSourceUtils : Fetching JDBC Connection from DataSource
2022-10-07 10:04:45.803 INFO 16288 --- [ main] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Starting...
2022-10-07 10:04:45.945 INFO 16288 --- [ main] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Start completed.local로 가길래 테스트 클래스에서 다음과 같은 애노테이션도 추가해서 해보았는데도 위 콘솔창과 동일하게 나타납니다.
@TestPropertySource(locations = "/application.properties")
@SpringBootTest
//@SpringBootTest(properties = "classpath:application.properties")
class ItemRepositoryTest {... }혹시 몰라서 test/resources/application.properties도 삭제했다가 다시 만들어보고 이클립스도 껏다 다시 해보는데도 실패합니다..
++ 집에 있는 맥북이랑 회사에서 사용하는 노트북이랑 깃으로 연동해서 사용하는데, 집에 와서 맥북으로 테스트해보니 잘 됩니다. 소스는 분명히 동일할탠데 맥북에서 잘 되는 것을 보니 h2 생성에 문제가 있는 것 같습니다(아마도). 화요일에 다시 회사 노트북(윈도우)로 시도해보고자 하는데 그 전에 혹시 제가 실수한 부분이나 참고할만한 부분을 답변으로 달아주신다면 참고하겠습니다,,!
답변 2
0
안녕하세요. ggggg님
이클립스의 경우 src, test 하위에 있는 application.properties 둘다 읽지 못하고, 하나만 읽는 문제가 발생할 수 있습니다.
이 경우 별도의 설정 파일을 만들어야 하는데요. 다음을 참고해주세요.
감사합니다.
0
vscode에서도 동일한 문제가 발생합니다.
문제가 발생하는 원인이 eclipse와 vscode가 동일한건진 잘 모르겠습니다.
밑에 분의 경우,
@SpringBootTest(properties = "spring.profiles.active:test")
@ActiveProfiles("test")이 2개의 annotation을 이용해서 해결하셨다고 댓글 달아주셨는데,
vscode의 경우, 위의 두 annotation을 적용해도 문제가 해결되지 않습니다.
테스트 디버그 콘솔상으로는 The following 1 profile is active: "test" 이 나오는데, 실제 db 커넥션은 src/main 하위에 있는 application.properties를 사용합니다.
혹시 추가적으로 해결하신 방법이 있으시면 답글 부탁드립니다 ㅠㅠ..
0
안녕하세요. ggggg님
자주하는 질문에 있는 H2 데이터베이스 접속 오류 부분을 참고해보시겠어요?
감사합니다.
0
자주하는 질문에 나와있는 h2 버전으로도 맞추고, ~~.mv.db도 직접 만들어서 실행해봐도 The following 1 profile is active: "local"로 나와서 좀 더 구글링해보니 아래와 같은 방법으로 해결했습니다!
@SpringBootTest(properties = "spring.profiles.active:test")
@ActiveProfiles("test")출처: https://sunghs.tistory.com/158
그런데 이러한 방법으로 테스트 케이스를 작성해도 되는지는 의문입니다.
감사합니다.
설정 정보 없이 임베디드 데이터베이스 생성
0
15
1
RepositoryTest의 패키지 위치가 domain인 이유
0
38
2
REQUIRES_NEW 해결 방법에 대해서 질문있습니다!!
0
32
1
update()에 사용하는 setter 질문드립니다.
0
49
1
SQL 중심적 개발의 문제점에 대한 질문
0
78
1
혹시 Containing 을 안쓰신 이유가 있을까요?
0
89
2
[공유] 스프링부트 4.x 버전 mybatis 연동
0
184
1
@repository 어노테이션
0
94
3
ItemService
0
59
1
논리 커밋, 물리 커밋 질문드립니다.
0
54
1
내부 트랜잭션 커밋은 필수인가요?
0
57
1
프록시 커넥션 객체를 반환할 때 생성하는건가요?
0
55
1
Transaction readOnly 성능 개선 (김영한님의 대한 감사인사)
2
180
2
JPQL 대신 네이티브 쿼리를 사용해야 하는 경우
0
81
1
@EventListener(ApplicationReadyEvent.class) 관련
0
90
1
트랜잭션 동기화 매니저와 데이터 소스
0
77
1
DB 관련 강의 개설 계획은 없으신건가요?
0
133
2
물리 트랜잭션 과 논리트랜잭션 용어를 맞게 이해한걸까요
0
96
1
스프링 3 버전 이상 rollbackFor 변경된듯요
1
114
1
트랜잭션 전파 질문.
0
87
1
프로젝트 오픈 에러
0
126
1
외부 트랜잭션에서 isNewTransaction이 false로 나오는거에 대해 질문드립니다
0
84
2
같은 스레드를 사용하면 트랜잭션 동기화 매니저는 같은 커넥션을 반환
0
74
1
h2 인메모리 테스트중 예약어 충돌날 경우 대처방법
0
105
1





