프로그래밍/기타
-
[클린 아키텍처 11] 의식적으로 지름길 사용하기프로그래밍/기타 2024. 10. 11. 12:45
지름길을 방지하기 위해선 -> 먼저 지름길 자체를 파악해야 한다.잠재적인 지름길에 대한 인식을 높이자! 왜 지름길은 깨진 창문 같을까?깨진 창문 이론:어떤 것이 멈춘 것처럼 보이고, 망가져 보이고, 혹은 관리되지 않는다고 여겨지면 인간의 뇌는 이를 더 멈추고, 망가뜨려도 된다고 생각하게 된다! - 기물 파손이 흔한 동네에서는 방치된 차를 도둑질하거나 망가뜨리는 일이 더 쉽게 일어남- '좋은 동네'라도 차의 챙문이 깨져있다면 차를 망가뜨리는 일이 쉽게 일어남 ... 코드에 적용해보면?- 품질이 떨어진 코드에서 작업할 때 더 낮은 품질의 코드를 추가하기 쉽다- 코딩 규칙을 많이 어긴 코드에서 작업할 때 또 다른 규칙을 어기기 쉽다 깨끗한 상태로 시작할 책임가능한 한 지름길을 거의 쓰지 않고 기술 부채를 ..
-
[클린 아키텍처 10] 아키텍처 경계 강화하기프로그래밍/기타 2024. 10. 1. 20:16
경계와 의존성'경계를 강제한다'는 것은 무엇인가도메인 > 애플리케이션 > 어댑터 > 설정 각 계층 사이의 경계를 유지하는 것. 계층 경계를 넘는 의존성은 항상 안쪽 방향으로 향하는 것! 접근 제한자경제를 강제하는 가장 기본적인 도구 = 접근 제한자 package-private의 중요성 - 자바 패키지를 통해 클래스들을 응집적인 '모듈'로 만들어줌 - 패키지내 클래스들은 서로 접근 가능하지만, 패키지 바깥에서는 접근 불가- 모듈의 진입점으로 활용된 클래스만 Public 설정 > 의존성 규칙 위반할 위험이 줄어듬 - domain 패키지는 다른 계층에서 접근 가능 해야함- application은 web 어댑터와 persitence 어댑터에서 접근 가능해야함 패키지내의 클래스가 특정 개수를 넘어가기 시작하면 ..
-
[클린 아키텍처 09] 애플리케이션 조립하기프로그래밍/기타 2024. 9. 29. 13:00
왜 조립까지 신경 써야 할까?유스케이스가 영속성 어댑터를 호출해야 하고 스스로 인스턴스화한다면 코드 의존성이 잘못된 방향으로 만들어 진 것 유스케이스는 인터페이스만 알아야 하고, 런타임에 이 인터페이스의 구현을 제공받아야 한다. 그럼 객체 인스턴스를 생성할 책임은 누구에게 있을까?의존성 규칙을 어기지 않으면서 그렇게 할 수 있을까? 아키텍처에 대해 중립적이고 인스턴스 생성을 위해 모든 클래스에 대한 의존성을 가지는 설정 컴포넌트가 있어야 함! 설정 컴포넌트는 각 클래스의 인스턴스 생성 역할을 한다. 평범한 코드로 조립하기class Application { public static void main(String[] args) { AccountRepository accountRepository = n..
-
[클린 아키텍처 07] 아키텍처 요소 테스트하기프로그래밍/기타 2024. 9. 9. 17:01
테스트 피라미드어떤 종류의 테스트를 목표로 해야 하는가?- 만드는 비용이 적고, 유지보수하기 쉽고, 빨리 실행되고, 안정적인 작은 크기의 테스트들에 대해 높은 커버리지를 유지해야 한다.- 하나의 '단위'가 제대로 동작하는지 확인할 수 있는 단위 테스트 여러개의 단위와 단위를 넘는 경계, 아키텍처 경계, 시스템 경계를 결합하는 테스트는 만드는 비용이 더 비쌈, 실행이 더 느림! 테스트가 비싸질수록 테스트의 커버리지 목표는 낮게 잡아야함!그렇지 않으면 신규 기능 개발 단위 테스트, 통합 테스트, 시스템 테스트의 정의는 프로젝트마다 다른 의미를 가질 수 있다. 단위 테스트피라미드의 토대하나의 클래스를 인스턴스화하고 해당 클래스의 인터페이스를 통해 기능들을 테스트한다.만약 테스트 중인 클래스가 다른 클래스에 ..
-
[클린 아키텍처 06] 영속성 어댑터 구현하기프로그래밍/기타 2024. 9. 1. 18:50
> 영속성 어댑터 구현하기의존성 역전영속성 계층 대신 애플리케이션 서비스에 영속성 기능을 제공하는 영속성 어댑터에 대해 말해보자 application.service.Service-> application.port.out.Port 애플리케이션 서비스에서는 영속성 기능을 사용하기 위해 포트 인터페이스를 호출한다.이 포트는 실제로 영속성 작업을 수행하고 DB와 통신할 책임을 가진 영속성 어댑터 클래스에 의해 구현된다. 영속성 어댑터는 '주도되는' 어댑터다. 애플리케이션에 의해 호출될 뿐, 애플리케이션을 호출하지는 않기 때문이다. 포트는 사실상 애플리케이션 서비스와 영속성 코드 사이의 간적접인 계층이다.영속성 계층에 대한 코드 의존성을 없애기 위해 간접 계층을 추가하고 있다. 영속성 어댑터의 책임영속성 어댑..
-
[클린 아키텍처 05] 웹 어댑터 구현하기프로그래밍/기타 2024. 9. 1. 17:20
>우리가 목표로 하는 아키텍처에서 외부 세계와의 모든 커뮤니케이션은 어댑터를 통해 이루어진다! 의존성 역전웹 어댑터는 '주도하는' 어댑터다.외부로부터 요청을 받아 애플리케이션 코어를 호출하고 무슨 일을 해야하는 지 알려준다! 제어흐름adapter.in.web.Controller -> application.port.in.Port application.servcie.Service 애플리케이션 계층은 웹 어댑터가 통신할 수 있는 특정 포트를 제공서비스는 이 포트를 구현하고, 웹 어댑트는 이 포트를 호출할 수 있음 자세히 보면 의존성 역전 원칙이 적용된 걸 볼 수 있음! 왜 어댑터와 유스케이스 사이 또 다른 간접 계층을 넣어야 할까?애플리케이션 코어가 외부 세계와 통신할 수 있는 곳에 대한 명세가 포트이기 때..
-
[클린 아키텍처 04] 유스케이스 구현하기프로그래밍/기타 2024. 8. 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..
-
[클린 아키텍처 03] 코드 구성하기프로그래밍/기타 2024. 8. 26. 22:10
>코드 구성하기계층으로 구성하기Web, Domain, Persistence의 구조로 패키지를 구성한다.요렇게 구성하는 경우의 문제점은? 1) 기능이나 특성을 구분짓는 경계가 없음 만약 User 기능이 추가 된다면...?서로 연관되지 않은 기능끼리 마구마구 섞임 (domain 패키지에 user repo, service, user entity 모두 추가됨 ㄷㄷ) 2) 어떤 유스케이스가 있는지 파악 불가AccountController에는 어떤 기능이 있을까..? User Controller에는..?기능으로 구성하기Account 패키지 안에 몽땅 넣는다!그 와중에 AccountService 네이밍을 SendMoneyService로 변경함이렇게 구성할 경우 '송금하기' 기능이 어딨는지 파악 가능하긴 함.. 그러..