Skip to content

A simple app used to demonstrate clean architecture with coroutines and MVI

License

Notifications You must be signed in to change notification settings

bkach/PostDashboard

Repository files navigation

PostDashboard

AppVideo

A simple project used to illustrate clean architecture and testing in Android with Kotlin.

The app shows a list of posts from JsonPlaceholder. Upon tapping on one of the posts, a detail view is shown with further details on the tapped post.

Architecture

Architecture Diagram

The hastily drawn diagram above illustrates how the Architecture for the App works. Essentially this is a slimmed down version of MVI.

There are three layers to the app, namely the UI, View Model, and Repository layers. Users send an Intent through the View Model layer which are later emitted by a State. The State is emitted via a LiveData, and is all the UI layer needs to do is observe it in order to figure out what to display.

The View Model layer is (importantly) unidirectional, and takes intents, maps them to actions, performs the actions, and returns results. Those results are finally mapped to the State.

These mappings occur in an Interpreter which exists in each step along the way. For example, the ActionInterpreter which takes an Action and produces a Result. Below is a method in the ViewModel which exemplifies this process:

fun sendIntent(intent: Intent) {
    launch(contextPool.IO) {
        intentInterpreter.interpret(intent) { action ->
            actionInterpreter.interpret(action) { result ->
                resultInterpreter.interpret(result, ::changeState)
            }
        }
    }
}

The Repository layer contains a Repository which is the logic of how the app gets data. Data is initially loaded from the network, but subsequently saved to a Database until that data is no longer viable. At the present there is no invalidation logic.

The UI layer is an Activity with multiple fragments - but in this app it is pretty bare bones. I decided to concentrate heavily on the Architecture as I was left pretty inspired by Droidcon London 2018 - where many of the talks involved Architecture and structuring the app in a clean way. I figured this would be a good way to put theory into practice.

Installing and Testing

The app can be run and installed easily from Android Studio. The instructions below are for running it via the command line.

Running the app via the command line

Run the following command in the repository's directory:

./gradlew installDebug

If a device is connected, the app should run without a problem.

Running the Espresso tests via the command line

Similarly, run the following command:

./gradlew connectedAndroidTest

Running the unit tests via the command line

Unit tests work the same way:

./gradlew test

Built With

License

Copyright (C) 2018 Boris Kachscovsky

This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/.

Releases

No releases published

Packages

No packages published

Languages