- Test를 하는 이유 ( 해야하는 이유 ) 1. 안전해진다. "제품이든 앱이든 테스트를 거치는 이유는 제품의 안정성을 높이기 위해서" == "앱의 완성도를 높이기 위해서" 라 생각합니다. 2. 믿을 수 있기 위해. 단위테스트는 가장 작은 단위들부터 테스트를 하고, 범위를 점점 넓혀 이전에 테스트한 객체를 활용하여 상위객체를 테스트하는 방식을 반복합니다. 그러다 보면 객체 재활용시에도, "이 기능은 믿을 수 있는 기능이야!" 라는 확신이 생기게 되고, 오류가 발생하더라도 "이 행동들의 케이스에서는 오류가 나지 않았어"라는 확신을 갖을 수 있습니다. 해당글을 생각날 때 마다 읽으며 테스트 개념을 익히는 중입니다. ( 돌아서면 까먹어요 ㅜㅜ ) https://ssowonny.medium.com/%EC%84..
값? 참조? 이 두 단어가 무엇인지 이해하고 나면 거의 다 이해한거라 봐도 무방하다 생각합니다. 값타입은 struct, 참조타입은 class입니다. - struct 컴파일타임에 실행 값타입 = Stack영역에 저장됩니다. 그렇기에 Heap영역에 저장되는 참조타입보다 속도가 빠릅니다. 하지만 struct의 변수가 바뀌는 경우 Mutating되기에 메모리에 다시 할당됩니다. struct는 변치 않는 고유값을 갖는 경우, 즉 struct내부의 변수가 바뀌지 않는 경우 사용하기 좋다 생각합니다. - class 런타임에 실행 참조타입 = Stack영역에 Heap영역 주소를 저장합니다. ARC가 메모리를 관리해줍니다. 상속이 가능하며 deinit을 사용하여 인스턴스 메모리를 해제할 수 있습니다. struct보다 속..
지극히 저의 주관적인 생각입니다. MVVM의 장점 : Testable하다. -> ViewModel이 View와 독립적이다! MVVM View에서의 Action을 ViewModel로 전달합니다. 이후 ViewModel은 해당 로직에 맞는 작업을 다른 Model에게 요청하고, 이의 응답을 ViewModel State에 업데이트합니다. View는 ViewModel State를 구독하여 State의 변화가 있을 때 View를 업데이트합니다. 오늘도 +, - 버튼을 넣어보겠습니다. :) 저번 MVC글에서는 오토레이아웃을 적용했는데.. SnapKit없이 쓰기에 정말 간단한 예제임에도 layout관련 코드가 너무 늘어다더라구요.. 그래서 이번엔 스토리보드를 사용하였습니다. - View ( ViewController ..
MVC의 구현방법부터 테스트코드까지 다뤄보겠습니다. https://eastbyeden.tistory.com/8 [Swift][MVC] MVC는 무엇일까? MVC패턴은 ios개발에 사용되는 아키텍쳐(MVC, MVP, MVC-N, MVVM, VIPER) 중 하나입니다. 먼저 아키텍쳐의 사용이유는 - 개체들의 책임을 균형있게 분리하기 위해 (Solid의 Single Responsibility Principle - 단일.. eastbyeden.tistory.com 이전의 MVC소개글 입니다. MVC보다 MVVM을 채택하는 이유는 무엇일까요? 라고 하면 당장 떠오르는 이유는 2가지입니다. 1. Testable하지 않다. 2. Massive ViewController. Testable하지 않은 이유. -> MVVM..
이전부터 공부하던 Dependency에 대해 공부하다 보니, 같은 코드를 여러 프로젝트에서 적용하게 되었고 "아예 cocoapods를 만들어볼까?"는 생각으로 만들게 되었습니다. 1. 의존성 주입 방식. 2. EbonyDependencyKit 사용방법. 링크 : https://github.com/rising-jun/EbonyDependencyKit GitHub - rising-jun/EbonyDependencyKit Contribute to rising-jun/EbonyDependencyKit development by creating an account on GitHub. github.com 1. 의존성을 주입 라이브러리는 크게 Pure와 Swinject가 있습니다. Pure는 AppDelegate에서..
개인적으로 생각하는 Moya를 다룬 포스트입니다. Moya가 등장한 계기는 Alamofire와 URLSession에 있습니다. URLSession의 코드를 더 가독성 좋게 작성하기 위해 나온 라이브러리가 Alamofire입니다. 하지만 Alamofire도 테스트 코드를 작성하기 위해서는 URLProtocol을 사용해야 했습니다. 그렇기에 이를 테스트하기 좋게 하기 위해 Alamofire를 한번 더 추상화한 라이브러리가 Moya입니다. 이러한 내용들로 보아 Moya는 URLSession보다 코드 가독성이 좋고, URLProtocol보다 테스트하기 편하다는 장점이 있다 생각합니다. Github에서 token을 가져오는 API 사용 로직을 구현해보겠습니다. 사용법 import Moya enum GithubAP..
2021년 취업준비를 하며 보았던 iOS개발자 채용 공고들 중 RxSwift, MVVM, MVC만큼이나 많이 볼 수 있었던 단어가 있었습니다. "HIG" = Human Interface Guide https://developer.apple.com/design/human-interface-guidelines/ Human Interface Guidelines - Design - Apple Developer Human Interface Guidelines Get in-depth information and UI resources for designing great apps that integrate seamlessly with Apple platforms. developer.apple.com HIG를 알아야 ..
작년에 퇴사한 곳의 모바일 서비스 "위치위치"의 개선점들을 iOS개발 관점에서 생각해보았습니다. 이를 유지보수하고, 회사 직원들과 이를 사용하면서 느낀 불편한 점들을 기준으로 개선점들을 고민해보았습니다. 개발자 관점에서 개선해야 된다 생각한 내용들. 1. 하나의 포스트 기준, 로딩속도가 평균 2~3초정도 걸림. 2. 과도한 모바일 데이터 사용 3. 많은 게시물을 업로드한 사용자 페이지 방문 시 앱 종료 고민한 내용 1. 하나의 포스트 기준, 로딩속도가 평균 2~3초정도 걸림. - 모바일에서 사진, 동영상 촬영 후 서버에 업로드 시 해당 이미지, 동영상의 용량을 줄여 서버에 업로드한다. 예를 들어 3MB의 이미지를 300KB의 크기로 resize하여 업로드를 합니다. ( 이미지 리사이즈 방법 : https..
저번에 주입한 의존성 주입 코드를 테스트해보겠습니다. 1. 서버가 없다 가정하고, 목데이터 책 펙토리 생성 후 책 정보를 가져오기. 2. 테스트 코드 추가, 실행 3. 서버가 생겼다 가정하고, 목데이터로 된 펙토리, 서버에서 가져오는 로직으로 바꾸기. 4. 테스트 코드 실행 의존성 주입을 함으로써 코드 테스트가 간편해진 이유는 "서버에서 책을 가져온다"는 동작을 추상화 했기에!! 의존성 주입의 필요성을 저번 포스트와 함께 작성하다 보니, 이의 필요성을 느끼는 것 같습니다. class MyTest: XCTestCase { let bookMakable = MockBookFactory() let testMockClass = TestMockClass() func testMockData() throws { let..
이번주 포스트의 주제는 NotificationCenter입니다. https://developer.apple.com/documentation/foundation/notificationcenter Apple Developer Documentation developer.apple.com A가 B에게 카톡을 보내면 B의 폰에 알림이 옵니다! A가 B에게 카톡을 "보내면" B의 폰에 "알림"이 옵니다. 어떠한 이벤트에 대해 구독하고, 해당 이벤트가 일어나면 알림을 주는 역할이 NotificationCenter입니다. NotificationCenter는 URLSession, UserDefault와 같이 default를 통해 싱글톤을 사용할 수 있습니다. NotificaiionCenter.default.post(na..