This document is still in draft stage!
Documentation and common resources for development processes
StarChart Labs is about creating a consistent process around development, and making it easier to "do things right". For us, "right" means libraries and tools that are easy to consume, stable, and make it easier to focus on the primary aim of the consuming project. Working towards this goal can be as simple as ensuring tests are written, or as complex as standardizing build and deployment processes.
Like many organizations, StarChart Labs is constantly tweaking how we operate, and rolling out changes we find helpful across our wide range of projects. Part of the process is also identifying the maturity of a project, and when it's worth the effort to apply certain practices. We are constantly trying to find ways to automate standards and checks, to improve consistency and let the humans get on with human work, instead of being bogged down in repetative work.
Our current best-practice process(s)
- Source files should follow consistent formatting pattern(s)
- Source files should have consistent and accurate copyright statements present
- Pull requests should be small and focused to specific issues or improvements
- Pull requests will be assigned/commented on to/by a maintainer within a week of filing
- Pull requests are compiled and tested prior to merge
- TODOs should not be added unless associated with an issue
- APIs meant for external consumption should be documented
- Code quality guidelines should be established and enforced prior to merge
- Tests should be present for new functionality, and to ensure fixed bugs do not regress
- Change log entries for changes should be added at the time the change is applied
- If breaking changes are made, the old and new methodologies should both exist at some point in time, and deprecation documentation on the old method should include details on how to migrate
All projects have some basic documentation
- A README which includes
- A summary or one-line description of what the purpose of the project is
- Information on licensing, including steps required by clients to use the library or it's source
- Information on reporting vulnerabilities
- Guidelines for contributors on setting up for development and requirements for pull requests
- Guidelines for collaborators on handling pull requests, interacting with the community, and releasing the project
- A code of conduct which outlines what community members can expect and establishes an expectation of respect
- A Change log detailing the changes applied within each release of the project
- If breaking changes have been made in the project's history, information on how to migrate from older to newer versions
- Projects follow semantic versioning: no breaking changes are made except across major release numbers, and with prior warning/documentation via deprecation or appropriate mechanisms
- Library releases should include source artifacts
- Releases should be communicated in a designated channel with information on the changes made
- Social media actions should be notified in a channel to allow everyone to keep tabs on what is being done
TODO
- Source file formatting, consistency, and copyright guidelines are enforced via Checkstyle
- Size of pull requests is monitored by maintainers
- Pull Requests are built via GitHub CI/CD
- TODOs are audited by maintainers
- External API documentation is audited by maintainers
- Code quality guidelines are audited by maintainers
- Test coverage is monitored via CodeCov
- Change log entries for production changes are enforced via Chronicler
- Breaking change documentation is audited by maintainers
- Files at the root of a project's repository
- README
- CHANGE_LOG
- Files in a
docs
folder- CONTRIBUTING
- Details expectations for contributors and how to setup development
- COLLABORATORS
- Details information such as handling contributions and releasing the projects
- Supporting documentation linked from the README
- CONTRIBUTING
TODO
Several steps of the code review/acceptance process could be better automated to take burden off of maintainers
- Size of pull requests could be automatically indicated with labels or similar, perhaps via a GitHub Action
- TODOs could be detected and commented on by an automated system, such as a GitHub Action
- External API documentation could be verified as present by automation
- Code quality guidelines could be automated via spotbugs as a build failure, and later as automated pull request comments
- Breaking change documentation could be detected for incompatible API changes in a way similar to Chronicler for some langauges