- Application for viewing starred github repositories π±πβ¨
- Implement a test-driven development (TDD) approach to ensure high code quality and reliability π§ͺπ
- Utilize a multi-module architecture to achieve modularity and maintainability π§©
- Integrate Hilt for dependency injection and enhance code organization ποΈ
- Utilize Coroutines and Flow for asynchronous programming and reactive data streams β‘π
- Follow Material Design guidelines to provide a visually appealing and user-friendly interface π¨
includes unit tests of Network module, data module( repository layer), common module, Feature module (ViewModels)
-
Android Architecture Components - Collection of libraries that help you design robust, testable, and maintainable apps.
-
100% Jetpack Compose based + Coroutines + Flow for asynchronous.
-
Jetpack
-
Retrofit2 & OkHttp3: Construct the REST APIs and paging network data.
-
viewmodel-lifecycle: ViewModel Lifecycle allows you to track and observe Jetpack's ViewModel lifecycle changes.
This app has been fully modularized.
Modularization is the practice of breaking the concept of a monolithic, one-module codebase into loosely coupled, self contained modules.
This offers many benefits, including:
Scalability - In a tightly coupled codebase, a single change can trigger a cascade of alterations. A properly modularized project will embrace the separation of concerns principle. This in turn empowers the contributors with more autonomy while also enforcing architectural patterns.
Enabling work in parallel - Modularization helps decrease version control conflicts and enables more efficient work in parallel for developers in larger teams.
Ownership - A module can have a dedicated owner who is responsible for maintaining the code and tests, fixing bugs, and reviewing changes.
Encapsulation - Isolated code is easier to read, understand, test and maintain.
Reduced build time - Leveraging Gradleβs parallel and incremental build can reduce build times.
Dynamic delivery - Modularization is a requirement for Play Feature Delivery which allows certain features of your app to be delivered conditionally or downloaded on demand.
Reusability - Proper modularization enables opportunities for code sharing and building multiple apps, across different platforms, from the same foundation.
-
The
app
module - contains app level and scaffolding classes that bind the rest of the codebase, such asMainActivity
. Theapp
module depends on allfeature
modules and requiredcore
modules. -
feature:
modules - feature specific modules which are scoped to handle a single responsibility in the app. These modules can be reused by any app, including test or other flavoured apps, when needed, while still keeping it separated and isolated. -
core:
modules - common library modules containing auxiliary code and specific dependencies that need to be shared between other modules in the app. These modules can depend on other core modules, but they shouldnβt depend on feature nor app modules.
Name | Responsibilities |
app
|
Brings everything together required for the app to function correctly. This includes UI scaffolding and navigation. |
feature:1, ... |
Functionality associated with a specific feature or user journey. Typically contains UI components and ViewModels which read data from other modules. Examples include: feature:trending displays information about starred repositories of specific programming language
|
core:data
|
Fetching app data from multiple sources, shared by different features. |
core:ui
|
Composite UI components and resources used by feature modules, such as the repos feed. It is dependent on the data layer since it renders models, like star repos. |
core:common
|
Common classes shared between modules. |
core:network
|
Making network requests and handling responses from a remote data source. |
core:testing
|
Testing dependencies, repositories and util classes. |
core:datastore
|
Storing persistent data using DataStore. |
core:model
|
Model classes used throughout the app. |
Mirza Arslan