For this exercise I decided to use the Single Activity principle, additionally Clean Architecture as a pattern through modules, MVVM, Jetapck (view bindings, nav component, list adapter) so in the project structure it looks as follows: - App: Everything related to the graphical interface such as Fragments, Activity, ViewModels, Adapters, ViewHolders - Domain: Everything related to business logic, data conversions and connection with the data source - Framework: Practically a domain extension, necessary for the use of Paging and its dependency with Android APIs - Data: Data sources, endpoints
- About the caching requirement for images: I delegated that behavior directly to Glide, so no implementation was necessary.
- It was also not necessary to create a custom RatingView component as the similar Material component is now stable.
Dependencies are centralized inside the dependencies.gradle file in the buildsystem
folder. This provides convenient centralization. It will allow us to update any dependency in a single place without the necessity to go manually to each gradle file where is used to change it, avoiding possible conflicts between versions if someone forgets to update one of these dependencies.
The objective of Clean Architecture is the separation of concerns. Using a layers architecture like this one, allow us to be more independent of frameworks and limit proper boundaries. It also provide more benefits as higher testability and the possibility to scale well.
The project will start growing keeping in mind this, for now we don't have many modules but instead we'll handle the layer by using packages referencing them as such.
- Glide: Image loading and caching
- Retrofit: HTTP Client
- Retrofit Gson Converter: GSON converter for JSON responses
- MockitoKotlin: Mockito for Kotlin unit testing
- Hamcrest: Matchers for unit testing, make it more readable and efficient
Movie Detail | Home |
---|---|