리스트 : 콘텐츠가 있으면 최근 5건을 불러옵니다.
-
[클린 아키텍처 09] 애플리케이션 조립하기기타 2024.09.29 13:00
왜 조립까지 신경 써야 할까?유스케이스가 영속성 어댑터를 호출해야 하고 스스로 인스턴스화한다면 코드 의존성이 잘못된 방향으로 만들어 진 것 유스케이스는 인터페이스만 알아야 하고, 런타임에 이 인터페이스의 구현을 제공받아야 한다. 그럼 객체 인스턴스를 생성할 책임은 누구에게 있을까?의존성 규칙을 어기지 않으면서 그렇게 할 수 있을까? 아키텍처에 대해 중립적이고 인스턴스 생성을 위해 모든 클래스에 대한 의존성을 가지는 설정 컴포넌트가 있어야 함! 설정 컴포넌트는 각 클래스의 인스턴스 생성 역할을 한다. 평범한 코드로 조립하기class Application { public static void main(String[] args) { AccountRepository accountRepository = n..
-
[클린 아키텍처 07] 아키텍처 요소 테스트하기기타 2024.09.09 17:01
테스트 피라미드어떤 종류의 테스트를 목표로 해야 하는가?- 만드는 비용이 적고, 유지보수하기 쉽고, 빨리 실행되고, 안정적인 작은 크기의 테스트들에 대해 높은 커버리지를 유지해야 한다.- 하나의 '단위'가 제대로 동작하는지 확인할 수 있는 단위 테스트 여러개의 단위와 단위를 넘는 경계, 아키텍처 경계, 시스템 경계를 결합하는 테스트는 만드는 비용이 더 비쌈, 실행이 더 느림! 테스트가 비싸질수록 테스트의 커버리지 목표는 낮게 잡아야함!그렇지 않으면 신규 기능 개발 단위 테스트, 통합 테스트, 시스템 테스트의 정의는 프로젝트마다 다른 의미를 가질 수 있다. 단위 테스트피라미드의 토대하나의 클래스를 인스턴스화하고 해당 클래스의 인터페이스를 통해 기능들을 테스트한다.만약 테스트 중인 클래스가 다른 클래스에 ..
-
[클린 아키텍처 06] 영속성 어댑터 구현하기기타 2024.09.01 18:50
> 영속성 어댑터 구현하기의존성 역전영속성 계층 대신 애플리케이션 서비스에 영속성 기능을 제공하는 영속성 어댑터에 대해 말해보자 application.service.Service-> application.port.out.Port 애플리케이션 서비스에서는 영속성 기능을 사용하기 위해 포트 인터페이스를 호출한다.이 포트는 실제로 영속성 작업을 수행하고 DB와 통신할 책임을 가진 영속성 어댑터 클래스에 의해 구현된다. 영속성 어댑터는 '주도되는' 어댑터다. 애플리케이션에 의해 호출될 뿐, 애플리케이션을 호출하지는 않기 때문이다. 포트는 사실상 애플리케이션 서비스와 영속성 코드 사이의 간적접인 계층이다.영속성 계층에 대한 코드 의존성을 없애기 위해 간접 계층을 추가하고 있다. 영속성 어댑터의 책임영속성 어댑..
-
[클린 아키텍처 05] 웹 어댑터 구현하기기타 2024.09.01 17:20
>우리가 목표로 하는 아키텍처에서 외부 세계와의 모든 커뮤니케이션은 어댑터를 통해 이루어진다! 의존성 역전웹 어댑터는 '주도하는' 어댑터다.외부로부터 요청을 받아 애플리케이션 코어를 호출하고 무슨 일을 해야하는 지 알려준다! 제어흐름adapter.in.web.Controller -> application.port.in.Port application.servcie.Service 애플리케이션 계층은 웹 어댑터가 통신할 수 있는 특정 포트를 제공서비스는 이 포트를 구현하고, 웹 어댑트는 이 포트를 호출할 수 있음 자세히 보면 의존성 역전 원칙이 적용된 걸 볼 수 있음! 왜 어댑터와 유스케이스 사이 또 다른 간접 계층을 넣어야 할까?애플리케이션 코어가 외부 세계와 통신할 수 있는 곳에 대한 명세가 포트이기 때..
-
[클린 아키텍처 04] 유스케이스 구현하기기타 2024.08.26 23:18
>유스케이스 구현하기유스케이스 둘러보기유스케이스를 구성하는 단계는 다음과 같다. 1. 입력을 받는다2. 비즈니스 규칙을 검증한다.3. 모델 상태를 조작한다.4. 출력을 반환한다. 입력 유효성 검증입력 유효성 검증은 어디에서 해야하는가? 바로 입력 모델이다.input parameter로 들어오는 모델(입력 모델)에서 입력 유효성 검증을 수행한다.해당 모델의 위치는 use case의 위치와 같다! because use case api의 일부이기 때문에! @Value@EqualsAndHashCode(callSuper = false)publicclass SendMoneyCommand extends SelfValidating { @NotNull private final AccountId sourceA..