This project uses static code analysis in order to ensure that the codebase meets certain standards that can be verified through automation. Two of these libraries used throughout this project are Detekt and Ktlint.
Detekt is a static analysis tool that checks for code smells. Examples include magic numbers, complicated conditionals, long methods, long parameter lists, and so much more. It is highly configurable, and if you choose to turn off any checks or customize thresholds you can do so in the config file.
To run a detekt validation, use the following Gradle command:
./gradlew detekt
Ktlint is a static analysis tool from Pinterest that prevents bike shedding when it comes to code formatting. It also comes with a Gradle task to automatically format your entire codebase, if it can. The benefit of a tool like this is to ensure everyone on the team will have code formatted the same way, and there's no debating around white spaces, indentation, imports, etc.
We use the JLLeitschuh Ktlint Gradle plugin in this project. You can find the setup in this Gradle file.
The following Gradle commands can be helpful:
// Format the Codebase
./gradlew ktlintFormat
// Check if everything is formatted correctly
./gradlew ktlintCheck