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
d3c75ea4
Commit
d3c75ea4
authored
Jul 03, 2018
by
Stan Hu
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Support creating a remote branch to import closed pull requests
parent
5f362686
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
82 additions
and
2 deletions
+82
-2
lib/bitbucket_server/client.rb
lib/bitbucket_server/client.rb
+10
-0
lib/bitbucket_server/connection.rb
lib/bitbucket_server/connection.rb
+15
-1
lib/gitlab/bitbucket_server_import/importer.rb
lib/gitlab/bitbucket_server_import/importer.rb
+57
-1
No files found.
lib/bitbucket_server/client.rb
View file @
d3c75ea4
...
@@ -27,6 +27,16 @@ module BitbucketServer
...
@@ -27,6 +27,16 @@ module BitbucketServer
get_collection
(
path
,
:repo
)
get_collection
(
path
,
:repo
)
end
end
def
create_branch
(
project_key
,
repo
,
branch_name
,
sha
)
payload
=
{
name:
branch_name
,
startPoint:
sha
,
message:
'GitLab temporary branch for import'
}
connection
.
post
(
"/projects/
#{
project_key
}
/repos/
#{
repo
}
/branches"
,
payload
.
to_json
)
end
private
private
def
get_collection
(
path
,
type
)
def
get_collection
(
path
,
type
)
...
...
lib/bitbucket_server/connection.rb
View file @
d3c75ea4
...
@@ -12,7 +12,6 @@ module BitbucketServer
...
@@ -12,7 +12,6 @@ module BitbucketServer
end
end
def
get
(
path
,
extra_query
=
{})
def
get
(
path
,
extra_query
=
{})
auth
=
{
username:
username
,
password:
token
}
response
=
Gitlab
::
HTTP
.
get
(
build_url
(
path
),
response
=
Gitlab
::
HTTP
.
get
(
build_url
(
path
),
basic_auth:
auth
,
basic_auth:
auth
,
params:
extra_query
)
params:
extra_query
)
...
@@ -20,8 +19,23 @@ module BitbucketServer
...
@@ -20,8 +19,23 @@ module BitbucketServer
response
.
parsed_response
response
.
parsed_response
end
end
def
post
(
path
,
body
)
Gitlab
::
HTTP
.
post
(
build_url
(
path
),
basic_auth:
auth
,
headers:
post_headers
,
body:
body
)
end
private
private
def
auth
@auth
||=
{
username:
username
,
password:
token
}
end
def
post_headers
@post_headers
||=
{
'Content-Type'
=>
'application/json'
}
end
def
build_url
(
path
)
def
build_url
(
path
)
return
path
if
path
.
starts_with?
(
root_url
)
return
path
if
path
.
starts_with?
(
root_url
)
...
...
lib/gitlab/bitbucket_server_import/importer.rb
View file @
d3c75ea4
...
@@ -4,6 +4,16 @@ module Gitlab
...
@@ -4,6 +4,16 @@ module Gitlab
include
Gitlab
::
ShellAdapter
include
Gitlab
::
ShellAdapter
attr_reader
:project
,
:project_key
,
:repository_slug
,
:client
,
:errors
,
:users
attr_reader
:project
,
:project_key
,
:repository_slug
,
:client
,
:errors
,
:users
REMOTE_NAME
=
'bitbucket_server'
.
freeze
def
self
.
imports_repository?
true
end
def
self
.
refmap
[
:heads
,
:tags
,
'+refs/pull-requests/*/to:refs/merge-requests/*/head'
]
end
def
initialize
(
project
)
def
initialize
(
project
)
@project
=
project
@project
=
project
@project_key
=
project
.
import_data
.
data
[
'project_key'
]
@project_key
=
project
.
import_data
.
data
[
'project_key'
]
...
@@ -12,9 +22,11 @@ module Gitlab
...
@@ -12,9 +22,11 @@ module Gitlab
@formatter
=
Gitlab
::
ImportFormatter
.
new
@formatter
=
Gitlab
::
ImportFormatter
.
new
@errors
=
[]
@errors
=
[]
@users
=
{}
@users
=
{}
@temp_branches
=
[]
end
end
def
execute
def
execute
import_repository
import_pull_requests
import_pull_requests
handle_errors
handle_errors
...
@@ -48,11 +60,55 @@ module Gitlab
...
@@ -48,11 +60,55 @@ module Gitlab
@repo
||=
client
.
repo
(
project_key
,
repository_slug
)
@repo
||=
client
.
repo
(
project_key
,
repository_slug
)
end
end
def
sha_exists?
(
sha
)
project
.
repository
.
commit
(
sha
)
end
def
track_temp_branch
(
pull_request
,
index
)
temp_branch_name
=
"gitlab/import/pull-request/
#{
pull_request
.
iid
}
-
#{
index
}
"
@temp_branches
<<
temp_branch_name
temp_branch_name
end
def
restore_branches
(
pull_request
)
shas_to_restore
=
[
pull_request
.
source_branch_sha
,
pull_request
.
target_branch_sha
]
resync
=
false
shas_to_restore
.
each_with_index
do
|
sha
,
index
|
next
if
sha_exists?
(
sha
)
branch_name
=
track_temp_branch
(
pull_request
,
index
)
response
=
client
.
create_branch
(
project_key
,
repository_slug
,
branch_name
,
sha
)
if
response
.
success?
resync
=
true
else
Rails
.
logger
.
warn
(
"BitbucketServerImporter: Unable to recreate branch for SHA
#{
sha
}
:
#{
response
.
code
}
"
)
end
end
import_repository
if
resync
end
def
import_repository
project
.
ensure_repository
project
.
repository
.
fetch_as_mirror
(
project
.
import_url
,
refmap:
self
.
class
.
refmap
,
remote_name:
REMOTE_NAME
)
rescue
Gitlab
::
Shell
::
Error
,
Gitlab
::
Git
::
RepositoryMirroring
::
RemoteError
=>
e
# Expire cache to prevent scenarios such as:
# 1. First import failed, but the repo was imported successfully, so +exists?+ returns true
# 2. Retried import, repo is broken or not imported but +exists?+ still returns true
project
.
repository
.
expire_content_cache
if
project
.
repository_exists?
raise
RuntimeError
,
e
.
message
end
def
import_pull_requests
def
import_pull_requests
pull_requests
=
client
.
pull_requests
(
project_key
,
repository_slug
)
pull_requests
=
client
.
pull_requests
(
project_key
,
repository_slug
)
pull_requests
.
each
do
|
pull_request
|
pull_requests
.
each
do
|
pull_request
|
begin
begin
restore_branches
(
pull_request
)
description
=
''
description
=
''
description
+=
@formatter
.
author_line
(
pull_request
.
author
)
unless
find_user_id
(
pull_request
.
author_email
)
description
+=
@formatter
.
author_line
(
pull_request
.
author
)
unless
find_user_id
(
pull_request
.
author_email
)
description
+=
pull_request
.
description
description
+=
pull_request
.
description
...
...
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