프로젝트 기간 2023.11.17 ~ 2023.12.01 (14일)
기능 구현 기간 2023.11.18 ~ 2023.11.26 (8일)
개발자 : iOS 개발자 김태현
DawnMarket 앱을 클론 코딩한 프로젝트입니다.
카테고리 탭화면 | 나머지 탭화면 | 카테고리 View 미개발된 기능 |
---|---|---|
Pagination | 카테고리 하위목록 및 SearchValue 선택 |
---|---|
LaunchScreen | 상품명 토글 | 카테고리 대분류 조회 실패 |
---|---|---|
퀵 메뉴 조회 실패 | 카테고리 하위목록 조회 실패 | 카테고리 상품목록 조회 실패 |
---|---|---|
- SwiftUI
- Combine
- CleanArchitecture + MVVM
- Unit Test
- Xcode 15.0.1
- iOS Simulator 17.0.1
- iOS Deployment Target 15.0
- Minimum Deployment 15.0
- Karma
Clean Architecture로 분리한 Layer들을 ViewModel까지 주입하여 RootView에서 생성하기 위한 여러 고민들이 있었습니다. 그 중 가장 중요하게 생각한 부분은 Category 대분류 List가 나오는 View에서 Detail로 화면 전환이 일어날 때입니다. UIKit에서는 Coordinator 패턴을 사용하여 화면 전환을 할 때, 각 Coordinator를 주입해주면 되었습니다. 하지만 SwiftUI는 View 위에 View가 그려지는 방식으로 어떻게 Coordinator와 유사한 객체를 만들어서 DI Container를 효율적으로 만들 수 있을 지에 대해 고민하였습니다.
참고 Repository - Flow Router - iOS 16이상
SwiftUI에서는 Flow Router 객체를 만들어 사용하면 AView의 ViewModel과 ADetailView의 ViewModel을 주입할 수 있습니다.
- 클린 아키텍처의 핵심 개념인 의존성 역전 원칙과 인터페이스를 활용하여 각 레이어를 분리하고, 각 레이어 사이의 의존성을 최소화했습니다. MVVM은 뷰, 뷰 모델, 모델로 구성되어 있으며, 각 역할에 따라 책임을 명확하게 분리했습니다. 이러한 클린 아키텍처와 MVVM의 조합을 통해 프로젝트는 유지 보수성과 확장성을 높이며, 테스트 용이성을 제공합니다. 또한, 코드의 가독성과 재사용성을 향상시키고, 애플리케이션의 비즈니스 로직과 UI를 분리하여 개발 과정을 단순화했습니다.
Layers
Domain Layer = Entities + Use Cases + Repositories Interfaces
Data Repositories Layer = Repositories Implementations + API (Network)
Presentation Layer (MVVM) = ViewModels + Views + Model
- Domain Layer에 다른 레이어(예: Presentation — UIKit, Data Layer — Mapping Codable)가 포함되지 않도록 처리했습니다.
- Presentation Layer에 Domain Entity를 맵핑하기 위한 Mapper 타입, Model 타입을 구현하여 Domain인과의 의존성을 최소화 시켰습니다.
GitHub issue 이미지
- 구현할 feature, test에 대한 내용을 Github의 issues에 정리했습니다. 진행할 업무를 정리하고, 우선순위를 정하기 위함입니다.
- 진행하는 issue들 별로 Todo, In Progress, Done을 통해 Feature History를 관리했습니다.
GitHub branch 이미지
- Branch를 issue별로 분기 처리하여 관리하였습니다.
Git Flow
각 Branch의 구현 후, develop 브랜치에 Merge하고 최종적으로 main Branch에 Merge하는 방식으로 과제를 수행하였습니다.