작성
·
95
0
질문 전 말씀드리면, Kotlin + Spring Boot를 사용하고 있습니다.
Datasource Connection Test 코드를 작성하고 테스트할 때 application.yml에서 properties 객체로의 binding시 이슈가 있습니다.
정확하게는 prefix가 존재할 때 binding시 String에서 Properties 객체로 binding을 시도하다가 에러가 발생하고 있고, application.properties 해당 문제가 발생하지 않음과 달리 application.yml에서 prefix 존재하는 경우 발생하고 있습니다.
혹시, 강의에서 진행해주셨던 postProcessAfterInitialization의 내부 로직에서 application.yml + prefix 조합에서의 별도 처리가 필요한걸까요?
binding error를 확인하기 위해 작성한 테스트 코드는 아래와 같습니다.
답변 3
0
일반적으로 properties가 아니고 yml이라고 prefix 관련 문제가 발생하지는 않을텐데요.
정확히 어떤 상황인지 올려주신 코드만으로는 파악하기가 어렵습니다.
실제 에러가 발생하는 코드 전체를 GitHub에 공유해주시면 받아서 한번 확인해보겠습니다. 코드와 함께 어떻게 실행을 할 때 에러가 발생하는지도 알려주세요.
추가적으로, 제가 debugging 했을때는 java layer에 해당하는 Properties Class에서의 load부분은 이슈가 없었고 Binder에서 bind할때 context객체를 디버깅하면 prefix 존재시 매핑결과가 달랐어서 yml의 경우 하나의 과정을 springframework layer에서 더 거치는게 아닌가 조심스레 추측하고 있습니다.
확인해보니, @SpringBootTest 에서 yml reader하는 기능도 포함되었군요.
"[DataSource 자동 구성 클래스 테스트] properties와 yml의 차이점 관련 질문입니다." 라는 다른 분의 질문 내용을 통해 원인 파악완료되었습니다! 감사합니다!
0
myserver:
context-path: /my-app
port: 9090
data:
url: jdbc:h2:mem:
driver-class-name: org.h2.Driver
username: sa
password:
0
@ExtendWith(SpringExtension::class)
@ContextConfiguration(classes = [SpringBootTobyApplication::class])
@TestPropertySource(locations = ["classpath:application.yml"])
class MyDataSourcePropertiesTest {
@Autowired
private lateinit var myDataSourceProperties: MyDataSourceProperties
@Test
fun testPropertiesBinding() {
assertNotNull(myDataSourceProperties)
assertNotNull(myDataSourceProperties.url)
assertNotNull(myDataSourceProperties.driverClassName)
}
}
토비님 답변이 늦었습니다 ㅠㅠ
repository & feature/spring-boot-toby branch 입니다. 올려드립니다 (multi-module 로 구성되어있어 불편하실 수도 있습니다 ㅠㅠ)
MyDataSourcePropertiesTest, MyServerPropertiesTest 등 Properties를 binding하는 테스트를 실행했을때 에러가 발생 유무를 통해 확인했습니다. (서버 가동시에도 동일한 에러가 발생합니다.)