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
5728ffbf
Commit
5728ffbf
authored
Jun 27, 2018
by
Stan Hu
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Import standalone pull request comments
parent
4a6ed479
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
125 additions
and
19 deletions
+125
-19
lib/bitbucket_server/client.rb
lib/bitbucket_server/client.rb
+1
-1
lib/bitbucket_server/representation/activity.rb
lib/bitbucket_server/representation/activity.rb
+84
-0
lib/bitbucket_server/representation/pull_request.rb
lib/bitbucket_server/representation/pull_request.rb
+4
-0
lib/gitlab/bitbucket_server_import/importer.rb
lib/gitlab/bitbucket_server_import/importer.rb
+36
-18
No files found.
lib/bitbucket_server/client.rb
View file @
5728ffbf
...
...
@@ -24,7 +24,7 @@ module BitbucketServer
def
activities
(
project_key
,
repo
,
pull_request
)
path
=
"/projects/
#{
project_key
}
/repos/
#{
repo
}
/pull-requests/
#{
pull_request
}
/activities"
collection
=
get_collection
(
path
,
:activit
ies
)
collection
=
get_collection
(
path
,
:activit
y
)
end
def
pull_request_diff
(
project_key
,
repo
,
pull_request
)
...
...
lib/bitbucket_server/representation/activity.rb
0 → 100644
View file @
5728ffbf
module
BitbucketServer
module
Representation
class
Activity
<
Representation
::
Base
def
action
raw
[
'action'
]
end
def
comment?
action
==
'COMMENTED'
.
freeze
end
def
inline_comment?
comment?
&&
raw
[
'commentAnchor'
]
end
def
id
raw
[
'id'
]
end
def
note
comment
[
'text'
]
end
def
author_username
author
[
'name'
]
end
def
author_email
author
[
'emailAddress'
]
end
def
merge_event?
action
==
'MERGED'
end
def
commiter_user
commit
.
fetch
(
'committer'
,
{})[
'displayName'
]
end
def
commiter_email
commit
.
fetch
(
'committer'
,
{})[
'emailAddress'
]
end
def
merge_timestamp
timestamp
=
commit
.
fetch
(
'committer'
,
{})[
'commiterTimestamp'
]
Time
.
at
(
timestamp
/
1000.0
)
if
timestamp
.
is_a?
(
Integer
)
end
def
commit
raw
.
fetch
(
'commit'
,
{})
end
def
created_at
Time
.
at
(
created_date
/
1000
)
if
created_date
.
is_a?
(
Integer
)
end
def
updated_at
Time
.
at
(
updated_date
/
1000
)
if
created_date
.
is_a?
(
Integer
)
end
private
def
comment
raw
.
fetch
(
'comment'
,
{})
end
def
author
comment
.
fetch
(
'author'
,
{})
end
# Anchor hash:
# {u'toHash': u'a4c2164330f2549f67c13f36a93884cf66e976be', u'fromHash': u'c5f4288162e2e6218180779c7f6ac1735bb56eab', u'fileType': u'FROM', u'diffType': u'EFFECTIVE', u'lineType': u'CONTEXT', u'path': u'CHANGELOG.md', u'line': 3, u'orphaned': False}
def
created_date
comment
[
'createdDate'
]
end
def
updated_date
comment
[
'updatedDate'
]
end
end
end
end
lib/bitbucket_server/representation/pull_request.rb
View file @
5728ffbf
...
...
@@ -5,6 +5,10 @@ module BitbucketServer
raw
.
fetch
(
'author'
,
{}).
fetch
(
'user'
,
{}).
fetch
(
'name'
)
end
def
author_email
raw
.
fetch
(
'author'
,
{}).
fetch
(
'user'
,
{}).
fetch
(
'emailAddress'
)
end
def
description
raw
[
'description'
]
end
...
...
lib/gitlab/bitbucket_server_import/importer.rb
View file @
5728ffbf
...
...
@@ -8,7 +8,7 @@ module Gitlab
{
title:
'proposal'
,
color:
'#69D100'
},
{
title:
'task'
,
color:
'#7F8C8D'
}].
freeze
attr_reader
:project_key
,
:repository_slug
,
:client
,
:errors
,
:users
attr_reader
:project
,
:project
_key
,
:repository_slug
,
:client
,
:errors
,
:users
def
initialize
(
project
)
@project
=
project
...
...
@@ -39,23 +39,20 @@ module Gitlab
}.
to_json
)
end
def
gitlab_user_id
(
project
,
username
)
find_user_id
(
username
)
||
project
.
creator_id
def
gitlab_user_id
(
project
,
email
)
find_user_id
(
email
)
||
project
.
creator_id
end
def
find_user_id
(
username
)
return
nil
unless
username
def
find_user_id
(
email
)
return
nil
unless
email
return
users
[
username
]
if
users
.
key?
(
username
)
return
users
[
email
]
if
users
.
key?
(
email
)
users
[
username
]
=
User
.
select
(
:id
)
.
joins
(
:identities
)
.
find_by
(
"identities.extern_uid = ? AND identities.provider = 'bitbucket_server'"
,
username
)
.
try
(
:id
)
users
[
email
]
=
User
.
find_by_any_email
(
email
)
end
def
repo
@repo
||=
client
.
repo
(
project
.
import_source
)
@repo
||=
client
.
repo
(
project
_key
,
repository_slug
)
end
def
import_pull_requests
...
...
@@ -64,13 +61,14 @@ module Gitlab
pull_requests
.
each
do
|
pull_request
|
begin
description
=
''
description
+=
@formatter
.
author_line
(
pull_request
.
author
)
unless
find_user_id
(
pull_request
.
author
)
description
+=
@formatter
.
author_line
(
pull_request
.
author
)
unless
find_user_id
(
pull_request
.
author
_email
)
description
+=
pull_request
.
description
source_branch_sha
=
pull_request
.
source_branch_sha
target_branch_sha
=
pull_request
.
target_branch_sha
source_branch_sha
=
project
.
repository
.
commit
(
source_branch_sha
)
&
.
sha
||
source_branch_sha
target_branch_sha
=
project
.
repository
.
commit
(
target_branch_sha
)
&
.
sha
||
target_branch_sha
project
.
merge_requests
.
find_by
(
iid:
pull_request
.
iid
)
&
.
destroy
merge_request
=
project
.
merge_requests
.
create!
(
iid:
pull_request
.
iid
,
...
...
@@ -83,13 +81,13 @@ module Gitlab
target_branch:
pull_request
.
target_branch_name
,
target_branch_sha:
target_branch_sha
,
state:
pull_request
.
state
,
author_id:
gitlab_user_id
(
project
,
pull_request
.
author
),
author_id:
gitlab_user_id
(
project
,
pull_request
.
author
_email
),
assignee_id:
nil
,
created_at:
pull_request
.
created_at
,
updated_at:
pull_request
.
updated_at
)
#
import_pull_request_comments(pull_request, merge_request) if merge_request.persisted?
import_pull_request_comments
(
pull_request
,
merge_request
)
if
merge_request
.
persisted?
rescue
StandardError
=>
e
errors
<<
{
type: :pull_request
,
iid:
pull_request
.
iid
,
errors:
e
.
message
,
trace:
e
.
backtrace
.
join
(
"
\n
"
),
raw_response:
pull_request
.
raw
}
end
...
...
@@ -97,14 +95,33 @@ module Gitlab
end
def
import_pull_request_comments
(
pull_request
,
merge_request
)
comments
=
client
.
activities
(
repo
,
pull_request
.
iid
).
select
(
&
:commment?
)
# XXX This is inefficient since we are making multiple requests to the activities endpoint
merge_event
=
client
.
activities
(
project_key
,
repository_slug
,
pull_request
.
iid
).
find
(
&
:merge_event?
)
import_merge_event
(
merge_request
,
merge_event
)
if
merge_event
comments
=
client
.
activities
(
project_key
,
repository_slug
,
pull_request
.
iid
).
select
(
&
:comment?
)
inline_comments
,
pr_comments
=
comments
.
partition
(
&
:inline_comment?
)
import_inline_comments
(
inline_comments
,
pull_request
,
merge_request
)
#
import_inline_comments(inline_comments, pull_request, merge_request)
import_standalone_pr_comments
(
pr_comments
,
merge_request
)
end
def
import_merge_event
(
merge_request
,
merge_event
)
committer
=
merge_event
.
commiter_email
return
unless
committer
user_id
=
find_user_id
(
committer
)
if
committer
timestamp
=
merge_event
.
merge_timestamp
return
unless
user_id
event
=
Event
.
create
(
merged_by_id:
user_id
,
merged_at:
timestamp
)
MergeRequestMetricsService
.
new
(
merge_request
.
metrics
).
merge
(
event
)
end
def
import_inline_comments
(
inline_comments
,
pull_request
,
merge_request
)
line_code_map
=
{}
...
...
@@ -153,7 +170,7 @@ module Gitlab
begin
merge_request
.
notes
.
create!
(
pull_request_comment_attributes
(
comment
))
rescue
StandardError
=>
e
errors
<<
{
type: :pull_request
,
iid:
comment
.
i
i
d
,
errors:
e
.
message
}
errors
<<
{
type: :pull_request
,
iid:
comment
.
id
,
errors:
e
.
message
}
end
end
end
...
...
@@ -163,10 +180,11 @@ module Gitlab
end
def
pull_request_comment_attributes
(
comment
)
byebug
{
project:
project
,
note:
comment
.
note
,
author_id:
gitlab_user_id
(
project
,
comment
.
author
),
author_id:
gitlab_user_id
(
project
,
comment
.
author
_email
),
created_at:
comment
.
created_at
,
updated_at:
comment
.
updated_at
}
...
...
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