Skip to content

Commit

Permalink
Documenting the git flow workflow and create sequence diagrams
Browse files Browse the repository at this point in the history
  • Loading branch information
HHobeck committed May 28, 2024
1 parent 3c7c22a commit a9cc731
Show file tree
Hide file tree
Showing 18 changed files with 166 additions and 53 deletions.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
102 changes: 57 additions & 45 deletions docs/input/docs/learn/branching-strategies/gitflow/examples.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,61 +6,79 @@ RedirectFrom:
- docs/git-branching-strategies/gitflow-examples
---

These examples are using the _default_ configuration with GitVersion. Which is
[continuous deployment](/docs/reference/modes/continuous-deployment) mode for
`develop` and [continuous delivery](/docs/reference/modes/continuous-delivery) mode
for all other branches.

This default configuration allows you to publish CI builds from develop to a CI
MyGet feed, or another CI feed. Then all other branches are manually released
then tagged. Read more about this at [version increments](/docs/reference/version-increments).
These examples are illustrating the usage of the supported `GitFlow` workflow in GitVersion.
To enable this workflow, the build-in template [GitFlow/v1](/docs/workflows/GitFlow/v1.json) needs to be referenced in the configuration as following:
```yaml
workflow: GitFlow/v1
mode: ContinuousDelivery
```
Where
the [continuous deployment](/docs/reference/modes/continuous-deployment) mode for no branches,
the [continuous delivery](/docs/reference/modes/continuous-delivery) mode for `main`, `support` and `develop` branches and
the [manual deployment](/docs/reference/modes/manual-deployment) mode for `release`, `feature`, `hotfix` and `unknown` branches
are specified.

This configuration allows you to publish CI (Continuous Integration) builds from `main`, `support` and `develop` branches to an artifact repository.
All other branches are manually published. Read more about this at [version increments](/docs/reference/version-increments).

__Notice:__ The _continuous delivery_ mode has been used for the `main` and the `support` branch in this examples (specified as a fallback on the root configuration layer)
to illustrate how the version increments are applying. In production context the _continuous deployment_ mode might be a better option when e.g.
the releasing process is automated or the commits are tagged by the pipeline automatically.

## Feature Branches

Feature branches will take the feature branch name and use that as the
pre-release tag.
Feature branches can be used in the `GitFlow` workflow to implement a feature in an isolated environement. Feature branches will take the feature branch name and use that
as the pre-release label. Will be created from `develop`, `release`, `main`, `support` or `hotfix` branches.

![GitFlow](/docs/img/05119d0cd4ecaaefff94\_feature-branch.png)
### Create feature branch from main

Notice after the feature branch is merged, the version on `develop` is
`1.3.0-alpha.3`. This is due to `develop` running in _continuous deployment_
mode. If you configured `develop` to use _continuous delivery_ the version would
still be `1.3.0-alpha.1` and you would have to use release tags to increment the
`alpha.1`.
![GitFlow](/docs/img/DocumentationSamplesForGitFlow\_FeatureFromMainBranch.png)

You can see the difference on the feature branch itself, notice the version is
the same before and after the commit on the feature branch? Only the metadata
has changed. If you released the feature branch artifacts then tagged the
commit, the following commit would increase to `-beta.2`.
__Notice:__ After the feature branch is merged, the version on `main` is
`2.0.0-5`. This is due to `main` running in _continuous delivery_
mode. If you configured `main` to use _continuous deployment_ the version would
be `2.0.0`.

## Pull Request
### Create feature branch from develop

Because feature branches are most likely pushed to a fork, we are showing the
pull request branch name which is created when you submit a pull request
![GitFlow](/docs/img/DocumentationSamplesForGitFlow\_FeatureFromDevelopBranch.png)

![GitFlow](/docs/img/09fdf46995b771f3164a_pull-request.png)
__Notice:__ After the feature branch is merged, the version on `develop` is
`1.3.0-alpha.3`. This is due to `develop` running in _continuous delivery_
mode. If you configure `develop` to use _manual deployment_ the version would
still be `1.3.0-alpha.1` and you would have to use pre-release tags to increment the
`alpha.1`.

## Hotfix Branches

Hotfix branches are used when you need to do a _patch_ release in GitFlow and
are always created off `main`
Hotfix branches are used when you need to do a _patch_ release in the `GitFlow` workflow and are always created from `main` branch.

### Create hotfix branch

![GitFlow](/docs/img/DocumentationSamplesForGitFlow\_HotfixBranch.png)

![GitFlow](/docs/img/f26ae57adbd9b74f74c4\_hotfix.png)
### Create hotfix branch with version number

## Minor Release Branches
![GitFlow](/docs/img/DocumentationSamplesForGitFlow\_VersionedHotfixBranch.png)

Release branches are used for both major and minor releases for stabilisation
before a release. Release branches are taken off `develop` then merged to both
`develop` and `main`. Finally `main` is tagged with the released version.
## Release Branches

![GitFlow](/docs/img/6d33d35a70a777608fa1\_minor-release.png)
Release branches are used for major and minor releases to stabilize a RC (Release Candidate) or to integrate
features (in parallel) targeting different iterations. Release branches are taken from `main` (or from `develop`)
and will be merged back afterwards. Finally the `main` branch is tagged with the released version.

## Major Release Branches
### Create release branch

Major releases are just like minor releases, the difference is you bump the
major in the release branch name.
![GitFlow](/docs/img/DocumentationSamplesForGitFlow\_ReleaseBranch.png)

![GitFlow](/docs/img/39f9d8b8b007c82f1f80\_major-release.png)
### Create release branch with version

![GitFlow](/docs/img/DocumentationSamplesForGitFlow\_VersionedReleaseBranch.png)

## Develop Branch

![GitFlow](/docs/img/DocumentationSamplesForGitFlow\_DevelopBranch.png)

## Support Branches

Expand All @@ -71,23 +89,17 @@ majors, then name your branch `support/<major>.x` (i.e `support/1.x`), to
support minors use `support/<major>.<minor>.x` or `support/<major>.<minor>.0`.
(i.e `support/1.3.x` or `support/1.3.0`)

### Hotfix
![GitFlow](/docs/img/DocumentationSamplesForGitFlow\_SupportBranch.png)

Depending on what you name your support branch, you may or may not need a hotfix
__Notice:__ Depending on what you name your support branch, you may or may not need a hotfix
branch. Naming it `support/1.x` will automatically bump the patch, if you name
it `support/1.3.0` then the version in branch name rule will kick in and the
patch _will not_ automatically bump, meaning you have to use hotfix branches.
![GitFlow](/docs/img/b035b8ca99bd34239518\_support-hotfix.png)

### Minor Release

![GitFlow](/docs/img/2167fb1c4a5cf84edfd8\_support-minor.png)

## To Contribute

See [contributing examples](/docs/learn/branching-strategies/contribute-examples).

### Source

See `DocumentationSamples.GitFlowExample`. To update, modify then run test.
Update <https://gist.github.com/JakeGinnivan/cf053d7f5d336ae9f7bb>
See `DocumentationSamplesForGitFlow.cs`. To update, modify then run test.
1 change: 1 addition & 0 deletions docs/input/docs/reference/configuration.md
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,7 @@ strategies:
- VersionInBranchName
branches:
develop:
mode: ContinuousDelivery
label: alpha
increment: Minor
prevent-increment:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ strategies:
- VersionInBranchName
branches:
develop:
mode: ContinuousDelivery
label: alpha
increment: Minor
prevent-increment:
Expand Down
File renamed without changes.
File renamed without changes.
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ strategies:
- VersionInBranchName
branches:
develop:
mode: ContinuousDelivery
label: alpha
increment: Minor
prevent-increment:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ public void OverwritesDefaultsWithProvidedConfig()
developConfiguration.Increment.ShouldBe(IncrementStrategy.Major);
developConfiguration.Increment.ShouldNotBe(defaultConfiguration.Branches["develop"].Increment);
developConfiguration.DeploymentMode.ShouldBe(DeploymentMode.ContinuousDelivery);
developConfiguration.DeploymentMode.ShouldNotBe(defaultConfiguration.Branches["develop"].DeploymentMode);
developConfiguration.DeploymentMode.ShouldNotBe(defaultConfiguration.Branches["feature"].DeploymentMode);
developConfiguration.Label.ShouldBe("dev");
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ private GitFlowConfigurationBuilder()
WithBranch(DevelopBranch.Name).WithConfiguration(new BranchConfiguration
{
Increment = IncrementStrategy.Minor,
DeploymentMode = DeploymentMode.ContinuousDelivery,
RegularExpression = DevelopBranch.RegexPattern,
SourceBranches = [this.MainBranch.Name],
Label = "alpha",
Expand Down
26 changes: 19 additions & 7 deletions src/GitVersion.Configuration/GitVersion.Configuration.csproj
Original file line number Diff line number Diff line change
Expand Up @@ -9,16 +9,10 @@
</ItemGroup>

<ItemGroup>
<PackageReference Include="System.Text.Json"/>
<PackageReference Include="System.Text.Json" />
<PackageReference Include="YamlDotNet" />
</ItemGroup>

<ItemGroup>
<EmbeddedResource Include="Workflows\GitFlow\v1.yml" />
<EmbeddedResource Include="Workflows\GitHubFlow\v1.yml" />
<EmbeddedResource Include="Workflows\TrunkBased\v1.yml" />
</ItemGroup>

<ItemGroup>
<InternalsVisibleTo Include="schema" />
<InternalsVisibleTo Include="gitversion" />
Expand All @@ -34,4 +28,22 @@
<InternalsVisibleTo Include="GitVersion.App.Tests" />
<InternalsVisibleTo Include="GitVersion.MsBuild.Tests" />
</ItemGroup>

<ItemGroup>
<Folder Include="Workflows\GitFlow\" />
<Folder Include="Workflows\GitHubFlow\" />
<Folder Include="Workflows\TrunkBased\" />
</ItemGroup>

<ItemGroup>
<EmbeddedResource Include="..\..\docs\input\docs\workflows\GitHubFlow\v1.yml" Link="Workflows\GitHubFlow\v1.yml" />
</ItemGroup>

<ItemGroup>
<EmbeddedResource Include="..\..\docs\input\docs\workflows\TrunkBased\v1.yml" Link="Workflows\TrunkBased\v1.yml" />
</ItemGroup>

<ItemGroup>
<EmbeddedResource Include="..\..\docs\input\docs\workflows\GitFlow\v1.yml" Link="Workflows\GitFlow\v1.yml" />
</ItemGroup>
</Project>
Original file line number Diff line number Diff line change
Expand Up @@ -148,6 +148,91 @@ public void FeatureFromMainBranchWithMainline(bool withPullRequestIntoMain)
fixture.AssertFullSemver("2.0.1-1", configuration);
}

[TestCase(false)]
[TestCase(true)]
public void FeatureFromDevelopBranch(bool withPullRequestIntoDevelop)
{
var configuration = GitFlowConfigurationBuilder.New.Build();

using var fixture = new EmptyRepositoryFixture();

fixture.SequenceDiagram.Participant("main");
fixture.SequenceDiagram.Participant("develop");

// GitFlow setup
fixture.SequenceDiagram.Activate("main");
fixture.Repository.MakeACommit();
fixture.ApplyTag("1.2.0");
fixture.AssertFullSemver("1.2.0", configuration);

// Branch from main to develop
fixture.BranchTo("develop", "develop");
fixture.SequenceDiagram.Activate("develop");
fixture.SequenceDiagram.Deactivate("main");
fixture.AssertFullSemver("1.3.0-alpha.0", configuration);

// Branch from develop to feature
const string branchName = "feature/foo";
fixture.BranchTo(branchName, "feature");
fixture.SequenceDiagram.Activate("feature");
fixture.SequenceDiagram.Deactivate("develop");
fixture.AssertFullSemver("1.3.0-foo.1+0", configuration);
fixture.MakeACommit();
fixture.AssertFullSemver("1.3.0-foo.1+1", configuration);

// Create hotfix on main branch
fixture.Checkout("main");
fixture.SequenceDiagram.Activate("main");
fixture.MakeACommit("+semver: minor");
fixture.AssertFullSemver("1.3.0-1", configuration);
fixture.ApplyTag("1.3.0");
fixture.AssertFullSemver("1.3.0", configuration);

// Merge main to develop branch
fixture.MergeTo("develop");
fixture.SequenceDiagram.Deactivate("main");
fixture.SequenceDiagram.Activate("develop");
fixture.AssertFullSemver("1.4.0-alpha.1", configuration);

// Merge develop to feature branch
fixture.MergeTo(branchName);
fixture.SequenceDiagram.Deactivate("develop");
fixture.AssertFullSemver("1.4.0-foo.1+3", configuration);

// Bump to major version increment
fixture.MakeACommit("+semver: major");
fixture.AssertFullSemver("2.0.0-foo.1+4", configuration);

// Create pre-release on feature branch
fixture.ApplyTag("2.1.0-foo.1");
fixture.AssertFullSemver("2.1.0-foo.2+0", configuration);
fixture.MakeACommit();
fixture.AssertFullSemver("2.1.0-foo.2+1", configuration);
fixture.Checkout("develop");

if (withPullRequestIntoDevelop)
{
// Create a PullRequest into develop
fixture.BranchTo("pull/2/merge", "pull");
fixture.SequenceDiagram.Activate("pull/2/merge");
fixture.MergeNoFF(branchName);
fixture.AssertFullSemver("2.1.0-PullRequest2.6", configuration);
fixture.Checkout("develop");
fixture.Remove("pull/2/merge");
}

// Merge feature into develop branch
fixture.MergeNoFF(branchName);
fixture.Remove(branchName);
fixture.SequenceDiagram.NoteOver("Feature branches should\r\nbe deleted once merged", branchName);
fixture.AssertFullSemver("2.1.0-alpha.6", configuration);

// Commit on develop branch
fixture.SequenceDiagram.Activate("develop");
fixture.MakeACommit();
fixture.AssertFullSemver("2.1.0-alpha.7", configuration);
}

[TestCase(false)]
[TestCase(true)]
public void HotfixBranch(bool withPullRequestIntoMain)
Expand Down

0 comments on commit a9cc731

Please sign in to comment.