Skip to content

Gitflow model

Peter Mai edited this page Jul 3, 2022 · 3 revisions

Screen Shot 2022-04-04 at 10 05 39 PM

Develop and main branches

  • master stores the official release history
  • koni-dev serves as an integration branch for features
  • tag all commits in the master branch with a version number
  • default branch: koni-dev

Issue branches

  • each new issue should reside in its own branch name koni/dev/issue-xxx (xxx is issue number)
  • koni/dev/issue-xxx branches are generally created off to the latest koni-dev branch
  • when a issue is resolved, it gets merged back into develop
  • koni/dev/issue-xxx should never interact directly with master

Pull Request

image

  1. When creating a pull request, you add a brief overview of your feature, select the branch to which the code needs to be merged, and select the assignee who will be reviewing it.
  2. Once it is created, it is open for discussion or modifications.
  3. Sometimes conflicts occur after creating a pull request, and you must resolve these conflicts by commit resolved code.
  4. Usually, the assigned person reviews the code, but it is not mandatory that only the assignee performs the review. Any team member can take part in the review process and give their feedback or discuss potential modifications to the code.
  5. Any feedback or modifications are added in the form of comments near the code line.
  6. The developer resolves comments and replies to the reviewer.
  7. This process continues until all comments are resolved.
  8. Once all discussions are resolved, the code is merged to the branch that was selected when the pull request was created.

Pull Requests in a Gitflow Model

  • Develop Branch: A pull request is created by developers from their respective feature branches to merge code to the develop branch. Usually, it is created after features are completed. A pull request is merged to the develop branch by the reviewer. In most cases, a reviewer is a technical lead.
  • Note: Although it is possible to skip pull requests and push code directly to branches, they shouldn’t be avoided as they provide better quality and stability for code.

Master branch

  • Master branch is config to build beta and stable version
  • Master branch only can be changed by admin of repository

Auto build with Github action

  • When push commit into special branch or create pull request github action will be triggered to create a dev, beta, or stable build depend on branch and commit content.
    • Dev version: Trigger any push on koni-dev or any pull request to koni-dev. Build with be named by last commit message on discord depend on config in github action.
    • Beta version: Any time push code to master with out change manual change version in main package.json file. Version will auto increase by add x.y.z-0 if current version is x.y.z or change to x.y.z-(n+1) if current versoin is x.y.z-n
    • Stable version:
      • Manual change version in main file package.json from x.y.z-n to x.y.z
      • Update CHANGELOG.md include version name
      • Build release with be push as draft in Github release.