-
Notifications
You must be signed in to change notification settings - Fork 19
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Git workflow (+Release process) #301
Comments
@moul @michelleellen @zivkovicmilos @clockworkgr Please check the above release process of Adena. For the final review by the Gno team before releasing a new version of Adena to the public, how about we request a review when the QA is complete in the EDIT: Add |
I would suggest adding a different label like code review or code release. I would also add deadline, linked to each release. |
In my opinion, your process is too complex. It resembles an advanced git-flow. I recommend considering the github-flow instead. The github-flow primarily involves a main branch where you attempt to merge the current state. You then create branches for PRs. To simplify things, try to use git tags exclusively on the main branch whenever possible. This can serve two purposes: freezing the git at a specific hash for review (share us the link), or marking an official release (after review). For example, you can use tags like v0.0.1-prerelease for review and then v0.0.1 for the final release. In certain cases, you may have dedicated branches for special releases. For instance, we use this approach for each testnet. It allows us to add additional commits, such as hotfixes or configuration changes. However, the main focus should always be on the main branch. Git tags are used either to freeze the code or to make a release. In other words, I would:
|
Hello everyone, I agree with Manfred that a simplified flow would be better. Specifically, when it comes to a chrome extension, the concept of an "earlier" version does not exist. Hence hotfixes or backports to earlier versions are of absolutely no use since users are ALWAYS at latest version. Thus @moul 's suggestion of using tags (imho using semver) is the most appropriate. The only addition that MAY be useful is release branches once you hiit RC level near a release assuming the scenario that there are people continuing implementing/merging features that will NOT be included in the release. Thus any bug-fixes or adjustments that result from testing should be done on that release branch until you get to the final submitted release and then merged back to main. However the size of the project and team does not warrant that imo. |
Git Workflow
main
: This branch stores the source code of the latest released version of Adena.release/*
: Release branch for a specific version, including QA and final review.hotfix/*
: Branch for critical bugs.develop
: Branch for ongoing development.feature branches
: Branches for specific features or enhancements.Release Process
develop
branch (following the work process in #300).release/*
branch for QA.release/*
branch intomain
upon approval, submit a review to the Chrome Web Store.feature branch
, fix the issue, and resubmit for review.The text was updated successfully, but these errors were encountered: