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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
|
package remote
import (
"strings"
"testing"
"github.com/stretchr/testify/require"
"gitlab.com/gitlab-org/gitaly-proto/go/gitalypb"
"gitlab.com/gitlab-org/gitaly/internal/testhelper"
"golang.org/x/net/context"
"google.golang.org/grpc/codes"
)
func TestSuccessfulUpdateRemoteMirrorRequest(t *testing.T) {
server, serverSocketPath := runRemoteServiceServer(t)
defer server.Stop()
client, conn := NewRemoteClient(t, serverSocketPath)
defer conn.Close()
testRepo, testRepoPath, cleanupFn := testhelper.NewTestRepo(t)
defer cleanupFn()
_, mirrorPath, mirrorCleanupFn := testhelper.NewTestRepo(t)
defer mirrorCleanupFn()
remoteName := "remote_mirror_1"
// Preconditions
testhelper.MustRunCommand(t, nil, "git", "-C", mirrorPath, "tag", "v0.0.1", "master") // I needed another tag for the tests
testhelper.MustRunCommand(t, nil, "git", "-C", testRepoPath, "remote", "add", remoteName, mirrorPath)
testhelper.MustRunCommand(t, nil, "git", "-C", testRepoPath, "fetch", remoteName)
// Updates
testhelper.MustRunCommand(t, nil, "git", "-C", testRepoPath, "branch", "new-branch", "60ecb67744cb56576c30214ff52294f8ce2def98") // Add branch
testhelper.MustRunCommand(t, nil, "git", "-C", testRepoPath, "branch", "ignored-branch", "60ecb67744cb56576c30214ff52294f8ce2def98") // Add branch not matching branch list
testhelper.MustRunCommand(t, nil, "git", "-C", testRepoPath, "update-ref", "refs/heads/empty-branch", "0b4bc9a49b562e85de7cc9e834518ea6828729b9") // Update branch
testhelper.MustRunCommand(t, nil, "git", "-C", testRepoPath, "branch", "-D", "not-merged-branch") // Delete branch
testhelper.MustRunCommand(t, nil, "git", "-C", testRepoPath, "tag", "new-tag", "60ecb67744cb56576c30214ff52294f8ce2def98") // Add tag
testhelper.MustRunCommand(t, nil, "git", "-C", testRepoPath, "tag", "-fam", "Overriding tag", "v1.0.0", "0b4bc9a49b562e85de7cc9e834518ea6828729b9") // Update tag
testhelper.MustRunCommand(t, nil, "git", "-C", testRepoPath, "tag", "-d", "v0.0.1") // Delete tag
newTagOid := string(testhelper.MustRunCommand(t, nil, "git", "-C", testRepoPath, "rev-parse", "v1.0.0"))
newTagOid = strings.TrimSpace(newTagOid)
require.NotEqual(t, newTagOid, "f4e6814c3e4e7a0de82a9e7cd20c626cc963a2f8") // Sanity check that the tag did in fact change
ctx, cancel := testhelper.Context()
defer cancel()
firstRequest := &gitalypb.UpdateRemoteMirrorRequest{
Repository: testRepo,
RefName: remoteName,
OnlyBranchesMatching: nil,
}
matchingRequest1 := &gitalypb.UpdateRemoteMirrorRequest{
OnlyBranchesMatching: [][]byte{[]byte("new-branch"), []byte("empty-branch")},
}
matchingRequest2 := &gitalypb.UpdateRemoteMirrorRequest{
OnlyBranchesMatching: [][]byte{[]byte("not-merged-branch"), []byte("matcher-without-matches")},
}
stream, err := client.UpdateRemoteMirror(ctx)
require.NoError(t, err)
require.NoError(t, stream.Send(firstRequest))
require.NoError(t, stream.Send(matchingRequest1))
require.NoError(t, stream.Send(matchingRequest2))
_, err = stream.CloseAndRecv()
require.NoError(t, err)
mirrorRefs := string(testhelper.MustRunCommand(t, nil, "git", "-C", mirrorPath, "for-each-ref"))
require.Contains(t, mirrorRefs, "60ecb67744cb56576c30214ff52294f8ce2def98 commit\trefs/heads/new-branch")
require.NotContains(t, mirrorRefs, "refs/heads/ignored-branch")
require.Contains(t, mirrorRefs, "0b4bc9a49b562e85de7cc9e834518ea6828729b9 commit\trefs/heads/empty-branch")
require.NotContains(t, mirrorRefs, "refs/heads/not-merged-branch")
require.Contains(t, mirrorRefs, "60ecb67744cb56576c30214ff52294f8ce2def98 commit\trefs/tags/new-tag")
require.Contains(t, mirrorRefs, newTagOid+" tag\trefs/tags/v1.0.0")
require.NotContains(t, mirrorRefs, "refs/tags/v0.0.1")
}
func TestFailedUpdateRemoteMirrorRequestDueToValidation(t *testing.T) {
server, serverSocketPath := runRemoteServiceServer(t)
defer server.Stop()
client, conn := NewRemoteClient(t, serverSocketPath)
defer conn.Close()
testRepo, _, cleanupFn := testhelper.NewTestRepo(t)
defer cleanupFn()
testCases := []struct {
desc string
request *gitalypb.UpdateRemoteMirrorRequest
}{
{
desc: "empty Repository",
request: &gitalypb.UpdateRemoteMirrorRequest{
Repository: nil,
RefName: "remote_mirror_1",
},
},
{
desc: "empty RefName",
request: &gitalypb.UpdateRemoteMirrorRequest{
Repository: testRepo,
RefName: "",
},
},
}
for _, tc := range testCases {
t.Run(tc.desc, func(t *testing.T) {
ctx, cancel := context.WithCancel(context.Background())
defer cancel()
stream, err := client.UpdateRemoteMirror(ctx)
require.NoError(t, err)
require.NoError(t, stream.Send(tc.request))
_, err = stream.CloseAndRecv()
testhelper.RequireGrpcError(t, err, codes.InvalidArgument)
require.Contains(t, err.Error(), tc.desc)
})
}
}
|