forked from GitTools/GitVersion
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathOtherScenarios.cs
92 lines (83 loc) · 3.88 KB
/
OtherScenarios.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
namespace GitVersionCore.Tests.IntegrationTests
{
using System.Linq;
using GitTools.Testing;
using GitVersion;
using LibGit2Sharp;
using NUnit.Framework;
[TestFixture]
public class OtherScenarios
{
// This is an attempt to automatically resolve the issue where you cannot build
// when multiple branches point at the same commit
// Current implementation favors master, then branches without - or / in their name
[Test]
public void DoNotBlowUpWhenMasterAndDevelopPointAtSameCommit()
{
using (var fixture = new RemoteRepositoryFixture())
{
fixture.Repository.MakeACommit();
fixture.Repository.MakeATaggedCommit("1.0.0");
fixture.Repository.MakeACommit();
fixture.Repository.CreateBranch("develop");
Commands.Fetch((Repository)fixture.LocalRepositoryFixture.Repository, fixture.LocalRepositoryFixture.Repository.Network.Remotes.First().Name, new string[0], new FetchOptions(), null);
fixture.LocalRepositoryFixture.Repository.Checkout(fixture.Repository.Head.Tip);
fixture.LocalRepositoryFixture.Repository.Branches.Remove("master");
fixture.InitialiseRepo();
fixture.AssertFullSemver("1.0.1+1");
}
}
[Test]
public void AllowNotHavingMaster()
{
using (var fixture = new EmptyRepositoryFixture())
{
fixture.Repository.MakeACommit();
fixture.Repository.MakeATaggedCommit("1.0.0");
fixture.Repository.MakeACommit();
fixture.Repository.Checkout(fixture.Repository.CreateBranch("develop"));
fixture.Repository.Branches.Remove(fixture.Repository.Branches["master"]);
fixture.AssertFullSemver("1.1.0-unstable.1");
}
}
[Test]
public void AllowHavingMainInsteadOfMaster()
{
var config = new Config();
config.Branches.Add("main", new BranchConfig
{
VersioningMode = VersioningMode.ContinuousDelivery,
Tag = "useBranchName",
Increment = IncrementStrategy.Patch,
PreventIncrementOfMergedBranchVersion = true,
TrackMergeTarget = false
});
using (var fixture = new EmptyRepositoryFixture())
{
fixture.Repository.MakeACommit();
fixture.Repository.Checkout(fixture.Repository.CreateBranch("develop"));
fixture.Repository.Checkout(fixture.Repository.CreateBranch("main"));
fixture.Repository.Branches.Remove(fixture.Repository.Branches["master"]);
fixture.AssertFullSemver(config, "0.1.0+0");
}
}
[Test]
public void DoNotBlowUpWhenDevelopAndFeatureBranchPointAtSameCommit()
{
using (var fixture = new RemoteRepositoryFixture())
{
fixture.Repository.MakeACommit();
fixture.Repository.Checkout(fixture.Repository.CreateBranch("develop"));
fixture.Repository.MakeACommit();
fixture.Repository.MakeATaggedCommit("1.0.0");
fixture.Repository.MakeACommit();
fixture.Repository.CreateBranch("feature/someFeature");
Commands.Fetch((Repository)fixture.LocalRepositoryFixture.Repository, fixture.LocalRepositoryFixture.Repository.Network.Remotes.First().Name, new string[0], new FetchOptions(), null);
fixture.LocalRepositoryFixture.Repository.Checkout(fixture.Repository.Head.Tip);
fixture.LocalRepositoryFixture.Repository.Branches.Remove("master");
fixture.InitialiseRepo();
fixture.AssertFullSemver("1.1.0-unstable.1");
}
}
}
}