This document describes the problem that branching strategies should resolve, how to present a strategy definition document and provides links to our current defined strategies. We will continuously review and revise this document and the strategy definitions to ensure they serve their purpose. If you have any suggestions, please make a pull request or create an issue.
As our projects and team grow, our codebases and repositories risk becoming disorganized, making the process of managing changes and delivering software increasingly complex. A well-defined branching strategy will help us keep things organized and consistent, avoid conflicts, and increase the team's productivity as long as every contributor abides by it.
We initially planned a strategy that accommodates all types of current and future projects. But after research, we found that many other companies have attempted to do the same, but none have found a single viable solution. Therefore, we decided to look into the top commonly used strategies and choose the best fit for each project type we are currently working on. Then, we adopt that strategy and may change it slightly according to our needs, but in a way that doesn't impose any unnecessary overhead on new contributors; we should try our best to keep it as close as possible to common practices.
A strategy definition document should cover the following:
- Introduction
- Branch types
- Development instructions:
- Create a new feature
- Manage hotfixes
- Undo mistakes
- Create a release
- Create a deployment
- Benefits and limitations
- Resources
- Examples
- CI/CD setup instruction
Choose a strategy based on the project's type or delivery method.