Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Boxiang Sun
gitlab-ce
Commits
d86751d8
Commit
d86751d8
authored
Jan 17, 2018
by
Alejandro Rodríguez
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Incorporate Gitaly's RemoteService.UpdateRemoteMirror RPC
parent
7fa0a3e7
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
61 additions
and
6 deletions
+61
-6
GITALY_SERVER_VERSION
GITALY_SERVER_VERSION
+1
-1
lib/gitlab/git/remote_mirror.rb
lib/gitlab/git/remote_mirror.rb
+19
-5
lib/gitlab/gitaly_client/remote_service.rb
lib/gitlab/gitaly_client/remote_service.rb
+27
-0
spec/lib/gitlab/gitaly_client/remote_service_spec.rb
spec/lib/gitlab/gitaly_client/remote_service_spec.rb
+14
-0
No files found.
GITALY_SERVER_VERSION
View file @
d86751d8
0.7
0
.0
0.7
2
.0
lib/gitlab/git/remote_mirror.rb
View file @
d86751d8
...
@@ -6,7 +6,23 @@ module Gitlab
...
@@ -6,7 +6,23 @@ module Gitlab
@ref_name
=
ref_name
@ref_name
=
ref_name
end
end
def
update
(
only_branches_matching:
[],
only_tags_matching:
[])
def
update
(
only_branches_matching:
[])
@repository
.
gitaly_migrate
(
:remote_update_remote_mirror
)
do
|
is_enabled
|
if
is_enabled
gitaly_update
(
only_branches_matching
)
else
rugged_update
(
only_branches_matching
)
end
end
end
private
def
gitaly_update
(
only_branches_matching
)
@repository
.
gitaly_remote_client
.
update_remote_mirror
(
@ref_name
,
only_branches_matching
)
end
def
rugged_update
(
only_branches_matching
)
local_branches
=
refs_obj
(
@repository
.
local_branches
,
only_refs_matching:
only_branches_matching
)
local_branches
=
refs_obj
(
@repository
.
local_branches
,
only_refs_matching:
only_branches_matching
)
remote_branches
=
refs_obj
(
@repository
.
remote_branches
(
@ref_name
),
only_refs_matching:
only_branches_matching
)
remote_branches
=
refs_obj
(
@repository
.
remote_branches
(
@ref_name
),
only_refs_matching:
only_branches_matching
)
...
@@ -15,8 +31,8 @@ module Gitlab
...
@@ -15,8 +31,8 @@ module Gitlab
delete_refs
(
local_branches
,
remote_branches
)
delete_refs
(
local_branches
,
remote_branches
)
local_tags
=
refs_obj
(
@repository
.
tags
,
only_refs_matching:
only_tags_matching
)
local_tags
=
refs_obj
(
@repository
.
tags
)
remote_tags
=
refs_obj
(
@repository
.
remote_tags
(
@ref_name
)
,
only_refs_matching:
only_tags_matching
)
remote_tags
=
refs_obj
(
@repository
.
remote_tags
(
@ref_name
))
updated_tags
=
changed_refs
(
local_tags
,
remote_tags
)
updated_tags
=
changed_refs
(
local_tags
,
remote_tags
)
@repository
.
push_remote_branches
(
@ref_name
,
updated_tags
.
keys
)
if
updated_tags
.
present?
@repository
.
push_remote_branches
(
@ref_name
,
updated_tags
.
keys
)
if
updated_tags
.
present?
...
@@ -24,8 +40,6 @@ module Gitlab
...
@@ -24,8 +40,6 @@ module Gitlab
delete_refs
(
local_tags
,
remote_tags
)
delete_refs
(
local_tags
,
remote_tags
)
end
end
private
def
refs_obj
(
refs
,
only_refs_matching:
[])
def
refs_obj
(
refs
,
only_refs_matching:
[])
refs
.
each_with_object
({})
do
|
ref
,
refs
|
refs
.
each_with_object
({})
do
|
ref
,
refs
|
next
if
only_refs_matching
.
present?
&&
!
only_refs_matching
.
include?
(
ref
.
name
)
next
if
only_refs_matching
.
present?
&&
!
only_refs_matching
.
include?
(
ref
.
name
)
...
...
lib/gitlab/gitaly_client/remote_service.rb
View file @
d86751d8
module
Gitlab
module
Gitlab
module
GitalyClient
module
GitalyClient
class
RemoteService
class
RemoteService
MAX_MSG_SIZE
=
128
.
kilobytes
.
freeze
def
initialize
(
repository
)
def
initialize
(
repository
)
@repository
=
repository
@repository
=
repository
@gitaly_repo
=
repository
.
gitaly_repository
@gitaly_repo
=
repository
.
gitaly_repository
...
@@ -38,6 +40,31 @@ module Gitlab
...
@@ -38,6 +40,31 @@ module Gitlab
response
.
result
response
.
result
end
end
def
update_remote_mirror
(
ref_name
,
only_branches_matching
)
req_enum
=
Enumerator
.
new
do
|
y
|
y
.
yield
Gitaly
::
UpdateRemoteMirrorRequest
.
new
(
repository:
@gitaly_repo
,
ref_name:
ref_name
)
current_size
=
0
slices
=
only_branches_matching
.
slice_before
do
|
branch_name
|
current_size
+=
branch_name
.
bytesize
next
false
if
current_size
<
MAX_MSG_SIZE
current_size
=
0
end
slices
.
each
do
|
slice
|
y
.
yield
Gitaly
::
UpdateRemoteMirrorRequest
.
new
(
only_branches_matching:
slice
)
end
end
GitalyClient
.
call
(
@storage
,
:remote_service
,
:update_remote_mirror
,
req_enum
)
end
end
end
end
end
end
end
spec/lib/gitlab/gitaly_client/remote_service_spec.rb
View file @
d86751d8
...
@@ -44,4 +44,18 @@ describe Gitlab::GitalyClient::RemoteService do
...
@@ -44,4 +44,18 @@ describe Gitlab::GitalyClient::RemoteService do
expect
(
client
.
fetch_internal_remote
(
remote_repository
)).
to
be
(
true
)
expect
(
client
.
fetch_internal_remote
(
remote_repository
)).
to
be
(
true
)
end
end
end
end
describe
'#update_remote_mirror'
do
let
(
:ref_name
)
{
'remote_mirror_1'
}
let
(
:only_branches_matching
)
{
[
'my-branch'
,
'master'
]
}
it
'sends an update_remote_mirror message'
do
expect_any_instance_of
(
Gitaly
::
RemoteService
::
Stub
)
.
to
receive
(
:update_remote_mirror
)
.
with
(
kind_of
(
Enumerator
),
kind_of
(
Hash
))
.
and_return
(
double
(
:update_remote_mirror_response
))
client
.
update_remote_mirror
(
ref_name
,
only_branches_matching
)
end
end
end
end
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment