Thank you for your interest in contributing to Meshtastic-Android! We welcome contributions from everyone. Please take a moment to review these guidelines to help us maintain a high-quality, collaborative project.
- Fork the repository and create your branch from
mainor the appropriate feature branch. - Make your changes in a logical, atomic manner.
- Test your changes thoroughly before submitting a pull request.
- Submit a pull request (PR) with a clear description of your changes and the problem they solve.
- If you are addressing an existing issue, please reference it in your PR (e.g.,
Fixes #123).
- Follow the Kotlin Coding Conventions for Kotlin code.
- Use Android Studio's default formatting settings.
- We use spotless for automated code formatting. You can run
./gradlew spotlessApplyto format your code automatically.- You can also run
./gradlew spotlessInstallGitPrePushHook --no-configuration-cacheto install a pre-push Git hook that will run aspotlessCheck.
- You can also run
- Write clear, descriptive variable and function names.
- Add comments where necessary, especially for complex logic.
- Keep methods and classes focused and concise.
- Strings: Use localised strings via the Compose Multiplatform Resource library in
:core:resources.- Do not use the legacy
app/src/main/res/values/strings.xml. - Definition: Add strings to
core/resources/src/commonMain/composeResources/values/strings.xml. - Usage:
import org.jetbrains.compose.resources.stringResource import org.meshtastic.core.resources.Res import org.meshtastic.core.resources.your_string_key Text(text = stringResource(Res.string.your_string_key))
- Do not use the legacy
Meshtastic-Android uses Detekt for static code analysis and linting of Kotlin code.
- Run
./gradlew detektbefore submitting your pull request to ensure your code passes all lint checks. - Fix any Detekt warnings or errors reported in your code.
- It is possible to suppress warnings individually, but this should be used very sparingly.
- You can find Detekt configuration in the
config/detektdirectory. If you believe a rule should be changed or suppressed, discuss it in your PR.
Consistent linting helps keep the codebase clean and maintainable.
Meshtastic-Android uses unit tests, Robolectric JVM tests, and instrumented UI tests to ensure code quality and reliability.
- Unit tests are located in the
src/test/directory of each module. - Compose UI Tests (JVM) are preferred for component testing and are also located in
src/test/using Robolectric.- Note: If using Java 17, pin your Robolectric tests to
@Config(sdk = [34])to avoid SDK 35 compatibility issues.
- Note: If using Java 17, pin your Robolectric tests to
- Instrumented tests (including full E2E UI tests) are located in
src/androidTest/. For Compose UI, use the Jetpack Compose Testing APIs.
- Add or update tests for any new features or bug fixes.
- Ensure all tests pass by running:
./gradlew testfor unit and Robolectric tests./gradlew connectedAndroidTestfor instrumented tests
- For UI components, write Robolectric Compose tests where possible for faster execution.
- If your change is difficult to test, explain why in your pull request.
Comprehensive testing helps prevent regressions and ensures a stable experience for all users.
- branches should start with:
- bugfix
- enhancement
- dependencies
- repo
- reserved (release, automation)
- Ensure your branch is up to date with the latest
mainbranch before submitting a PR. - Provide a meaningful title and description for your PR.
- Include information on how to test and/or replicate if it is not obvious.
- Include screenshots or logs if your change affects the UI or user experience.
- Be responsive to feedback and make requested changes promptly.
- Squash commits if requested by a maintainer.
- Search existing issues before opening a new one to avoid duplicates.
- Provide a clear and descriptive title.
- Include steps to reproduce, expected behavior, and actual behavior.
- Attach logs, screenshots, or other helpful context if applicable.
- Be respectful and considerate in all interactions.
- The Meshtastic Android project is subject to the code of conduct for the parent project, which can be found here:
- Help others by reviewing pull requests and answering questions when possible.
Thank you for helping make Meshtastic-Android better!