헥사고날 아키텍처 질문 있습니다.
140
작성한 질문수 57
학습 관련 질문을 남겨주세요. 어떤 부분이 고민인지, 무엇이 문제인지 상세히 작성하면 더 좋아요!
먼저 유사한 질문이 있었는지 검색해 보세요.
서로 예의를 지키며 존중하는 문화를 만들어가요.
jpa와 너무 강하게 결합되어 있어
repository 인터페이스를 만든다고 하셨는데
그러면
1. repository 인터페이스
2. 1의 repository 인터페이스를 구현한 repositoryimpl
3. 2의 repositoryimpl에서 사용할 jparepository
이렇게 세 개나 만들어서 사용하는건가요?
답변 2
1
안녕하세요, 인프런 AI 인턴입니다. 대영님, 질문해 주셔서 감사합니다.
헥사고날 아키텍처에서는 애플리케이션의 비즈니스 로직을 외부의 프레임워크나 라이브러리와 분리하여 독립적으로 유지하는 것이 중요합니다. 이를 통해 코드의 유연성과 재사용성을 높일 수 있습니다.
질문하신 내용에 대해 말씀드리면, JPA와의 결합력을 낮추기 위해 인터페이스와 구현체를 나누는 방식은 일반적인 패턴입니다. 헥사고날 아키텍처를 적용할 때, 주로 다음과 같이 구성될 수 있습니다:
Repository Interface: 비즈니스 로직에서 JPA나 다른 구현체에 의존하지 않도록 Repository의 인터페이스를 정의합니다. 이렇게 함으로써 인터페이스를 통해 비즈니스 로직과 데이터 접근 로직을 분리할 수 있습니다.
Repository Implementation (RepositoryImpl): 이 인터페이스를 구현하는 클래스를 만들고, 이 클래스에서 JPA 리포지토리를 사용하여 데이터베이스 접근을 수행합니다. 이는 DAO(Data Access Object) 패턴에 가깝습니다.
JPA Repository: JPA의 스프링 데이터 리포지토리를 실제로 사용하는 구현체입니다. 이 레이어는 실제 데이터베이스와의 상호작용을 담당합니다.
이러한 구조는 코드의 테스트 용이성을 높이고, 다른 데이터 접근 방법으로 쉽게 전환할 수 있는 장점이 있습니다. 또한, Mocking이나 다른 테스트 방법을 통해 비즈니스 로직을 검증할 때 JPA에 대한 의존을 줄일 수 있습니다.
기존의 유사한 질문으로 아래 링크를 참고하시기 바랍니다:
- 패키지 구조: 강의 프로젝트의 패키지 구조가 헥사고날 아키텍처와 연관이 있는지에 대한 질문 내용입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
private 상수 테스트 관련 질문
0
82
1
void는 어떻게 테스트하나요..? void로 애초에 코딩하면 안되나요??
0
124
2
커버리지는 어떻게 활용하시는지 궁금합니다.
0
159
2
테스트 문서화 질문입니다
0
104
2
단위테스트 질문이 있습니다
0
95
2
컨트롤러는 모킹을 한 이유가 궁금합니다.
0
100
2
ERD 가장자리에 있는 도메인 테스트 질문
0
87
2
DTO 검증 필드에 대한 테스트 코드 작성은 어디까지?
0
134
2
OrderCreateRequest DTO에 대해서 궁금한점
0
101
2
고전파의 테스트 대역 사용 대상, 공유 의존성
0
154
2
계층 관련 질문이 있습니다.
0
137
3
'코틀린'에서는 빌더를 따로 쓰지 않는데, 이 때는 어떻게 test fixture를 만드시는지 궁금합니다
1
123
2
혹시 update 로직은 어떻게 테스트하나요? (@Setter?)
0
133
2
단위테스트와 통합테스트의 경계가 궁금합니다.
0
228
2
Service+Repository 통합테스트 관련 질문입니다.
0
149
2
OrderControllerDocsTest 작성 해봤는데요. 날짜 형식이 이상하게 나와요
0
183
2
test 용 .yml
0
89
2
throws Exception
0
78
2
카페키오스크 클래스 문의 ,,
0
87
2
Rest docs 문서용 테스트코드를 따로 작성해야 되나요?
0
172
2
테스트 코드에서 필요한 생성자
0
138
1
tearDown 순서
0
115
2
@Builder 생성자 private
0
135
2
@DisplayName gradle / intellJ
0
92
2





