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
1
Merge Requests
1
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
nexedi
gitlab-ce
Commits
5e5f39a3
Commit
5e5f39a3
authored
Aug 12, 2019
by
GitLab Bot
Browse files
Options
Browse Files
Download
Plain Diff
Automatic merge of gitlab-org/gitlab-ce master
parents
b80e349c
37496d59
Changes
10
Hide whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
55 additions
and
21 deletions
+55
-21
changelogs/unreleased/georgekoltsov-63408-user-mapping.yml
changelogs/unreleased/georgekoltsov-63408-user-mapping.yml
+5
-0
doc/user/project/import/bitbucket.md
doc/user/project/import/bitbucket.md
+6
-6
lib/bitbucket/representation/comment.rb
lib/bitbucket/representation/comment.rb
+1
-1
lib/bitbucket/representation/issue.rb
lib/bitbucket/representation/issue.rb
+1
-1
lib/bitbucket/representation/pull_request.rb
lib/bitbucket/representation/pull_request.rb
+1
-1
lib/gitlab/bitbucket_import/importer.rb
lib/gitlab/bitbucket_import/importer.rb
+7
-1
spec/lib/bitbucket/representation/comment_spec.rb
spec/lib/bitbucket/representation/comment_spec.rb
+1
-1
spec/lib/bitbucket/representation/issue_spec.rb
spec/lib/bitbucket/representation/issue_spec.rb
+1
-1
spec/lib/bitbucket/representation/pull_request_spec.rb
spec/lib/bitbucket/representation/pull_request_spec.rb
+1
-1
spec/lib/gitlab/bitbucket_import/importer_spec.rb
spec/lib/gitlab/bitbucket_import/importer_spec.rb
+31
-8
No files found.
changelogs/unreleased/georgekoltsov-63408-user-mapping.yml
0 → 100644
View file @
5e5f39a3
---
title
:
'
Fix
missing
author
line
(`Created
by:
<user>`)
in
MRs/issues/comments
of
imported
Bitbucket
Cloud
project'
merge_request
:
31579
author
:
type
:
fixed
doc/user/project/import/bitbucket.md
View file @
5e5f39a3
...
...
@@ -31,12 +31,12 @@ to enable this if not already.
## How it works
When issues/pull requests are being imported, the Bitbucket importer tries to find
the Bitbucket author/assignee in GitLab's database using the Bitbucket
ID. For this
to work, the Bitbucket author/assignee should have signed in beforehand in GitLab
and
**associated their Bitbucket account**
.
If the user is no
t
found in GitLab's database, the project creator (most of the times the current
user that started the import process) is set as the author, but a reference on
the issue about the original Bitbucket author is kept.
the Bitbucket author/assignee in GitLab's database using the Bitbucket
`nickname`
.
For this
to work, the Bitbucket author/assignee should have signed in beforehand in GitLab
and
**associated their Bitbucket account**
.
Their
`nickname`
must also match their Bitbucke
t
`username.`
. If the user is not found in GitLab's database, the project creator
(most of the times the current user that started the import process) is set as the author,
but a reference on
the issue about the original Bitbucket author is kept.
The importer will create any new namespaces (groups) if they don't exist or in
the case the namespace is taken, the repository will be imported under the user's
...
...
lib/bitbucket/representation/comment.rb
View file @
5e5f39a3
...
...
@@ -4,7 +4,7 @@ module Bitbucket
module
Representation
class
Comment
<
Representation
::
Base
def
author
user
[
'
user
name'
]
user
[
'
nick
name'
]
end
def
note
...
...
lib/bitbucket/representation/issue.rb
View file @
5e5f39a3
...
...
@@ -14,7 +14,7 @@ module Bitbucket
end
def
author
raw
.
dig
(
'reporter'
,
'
user
name'
)
raw
.
dig
(
'reporter'
,
'
nick
name'
)
end
def
description
...
...
lib/bitbucket/representation/pull_request.rb
View file @
5e5f39a3
...
...
@@ -4,7 +4,7 @@ module Bitbucket
module
Representation
class
PullRequest
<
Representation
::
Base
def
author
raw
.
fetch
(
'author'
,
{}).
fetch
(
'
user
name'
,
nil
)
raw
.
fetch
(
'author'
,
{}).
fetch
(
'
nick
name'
,
nil
)
end
def
description
...
...
lib/gitlab/bitbucket_import/importer.rb
View file @
5e5f39a3
...
...
@@ -262,13 +262,19 @@ module Gitlab
def
pull_request_comment_attributes
(
comment
)
{
project:
project
,
note:
comment
.
note
,
author_id:
gitlab_user_id
(
project
,
comment
.
author
),
note:
comment_note
(
comment
),
created_at:
comment
.
created_at
,
updated_at:
comment
.
updated_at
}
end
def
comment_note
(
comment
)
author
=
@formatter
.
author_line
(
comment
.
author
)
unless
find_user_id
(
comment
.
author
)
author
.
to_s
+
comment
.
note
.
to_s
end
def
log_error
(
details
)
logger
.
error
(
log_base_data
.
merge
(
details
))
end
...
...
spec/lib/bitbucket/representation/comment_spec.rb
View file @
5e5f39a3
...
...
@@ -4,7 +4,7 @@ require 'spec_helper'
describe
Bitbucket
::
Representation
::
Comment
do
describe
'#author'
do
it
{
expect
(
described_class
.
new
(
'user'
=>
{
'
user
name'
=>
'Ben'
}).
author
).
to
eq
(
'Ben'
)
}
it
{
expect
(
described_class
.
new
(
'user'
=>
{
'
nick
name'
=>
'Ben'
}).
author
).
to
eq
(
'Ben'
)
}
it
{
expect
(
described_class
.
new
({}).
author
).
to
be_nil
}
end
...
...
spec/lib/bitbucket/representation/issue_spec.rb
View file @
5e5f39a3
...
...
@@ -17,7 +17,7 @@ describe Bitbucket::Representation::Issue do
end
describe
'#author'
do
it
{
expect
(
described_class
.
new
({
'reporter'
=>
{
'
user
name'
=>
'Ben'
}
}).
author
).
to
eq
(
'Ben'
)
}
it
{
expect
(
described_class
.
new
({
'reporter'
=>
{
'
nick
name'
=>
'Ben'
}
}).
author
).
to
eq
(
'Ben'
)
}
it
{
expect
(
described_class
.
new
({}).
author
).
to
be_nil
}
end
...
...
spec/lib/bitbucket/representation/pull_request_spec.rb
View file @
5e5f39a3
...
...
@@ -8,7 +8,7 @@ describe Bitbucket::Representation::PullRequest do
end
describe
'#author'
do
it
{
expect
(
described_class
.
new
({
'author'
=>
{
'
user
name'
=>
'Ben'
}
}).
author
).
to
eq
(
'Ben'
)
}
it
{
expect
(
described_class
.
new
({
'author'
=>
{
'
nick
name'
=>
'Ben'
}
}).
author
).
to
eq
(
'Ben'
)
}
it
{
expect
(
described_class
.
new
({}).
author
).
to
be_nil
}
end
...
...
spec/lib/gitlab/bitbucket_import/importer_spec.rb
View file @
5e5f39a3
...
...
@@ -25,12 +25,12 @@ describe Gitlab::BitbucketImport::Importer do
let
(
:reporters
)
do
[
nil
,
{
"
user
name"
=>
"reporter1"
},
{
"
nick
name"
=>
"reporter1"
},
nil
,
{
"
user
name"
=>
"reporter2"
},
{
"
user
name"
=>
"reporter1"
},
{
"
nick
name"
=>
"reporter2"
},
{
"
nick
name"
=>
"reporter1"
},
nil
,
{
"
user
name"
=>
"reporter3"
}
{
"
nick
name"
=>
"reporter3"
}
]
end
...
...
@@ -115,6 +115,7 @@ describe Gitlab::BitbucketImport::Importer do
created_at:
Time
.
now
,
updated_at:
Time
.
now
)
end
let
(
:author_line
)
{
"*Created by: someuser*
\n\n
"
}
before
do
allow
(
subject
).
to
receive
(
:import_wiki
)
...
...
@@ -128,7 +129,7 @@ describe Gitlab::BitbucketImport::Importer do
old_pos:
nil
,
new_pos:
4
,
note:
'Hello world'
,
author:
'
root
'
,
author:
'
someuser
'
,
created_at:
Time
.
now
,
updated_at:
Time
.
now
,
inline?:
true
,
...
...
@@ -139,7 +140,7 @@ describe Gitlab::BitbucketImport::Importer do
iid:
3
,
file_path:
'.gitmodules'
,
note:
'Hello world'
,
author:
'
root
'
,
author:
'
someuser
'
,
created_at:
Time
.
now
,
updated_at:
Time
.
now
,
inline?:
true
,
...
...
@@ -163,11 +164,33 @@ describe Gitlab::BitbucketImport::Importer do
notes
=
merge_request
.
notes
.
order
(
:id
).
to_a
start_note
=
notes
.
first
expect
(
start_note
).
to
be_a
(
DiffNote
)
expect
(
start_note
.
note
).
to
eq
(
@inline_note
.
note
)
expect
(
start_note
.
note
).
to
include
(
@inline_note
.
note
)
expect
(
start_note
.
note
).
to
include
(
author_line
)
reply_note
=
notes
.
last
expect
(
reply_note
).
to
be_a
(
DiffNote
)
expect
(
reply_note
.
note
).
to
eq
(
@reply
.
note
)
expect
(
reply_note
.
note
).
to
include
(
@reply
.
note
)
expect
(
reply_note
.
note
).
to
include
(
author_line
)
end
context
'when user exists in GitLab'
do
let!
(
:existing_user
)
{
create
(
:user
,
username:
'someuser'
)
}
let!
(
:identity
)
{
create
(
:identity
,
provider:
'bitbucket'
,
extern_uid:
existing_user
.
username
,
user:
existing_user
)
}
it
'does not add author line to comments'
do
expect
{
subject
.
execute
}.
to
change
{
MergeRequest
.
count
}.
by
(
1
)
merge_request
=
MergeRequest
.
first
notes
=
merge_request
.
notes
.
order
(
:id
).
to_a
start_note
=
notes
.
first
expect
(
start_note
.
note
).
to
eq
(
@inline_note
.
note
)
expect
(
start_note
.
note
).
not_to
include
(
author_line
)
reply_note
=
notes
.
last
expect
(
reply_note
.
note
).
to
eq
(
@reply
.
note
)
expect
(
reply_note
.
note
).
not_to
include
(
author_line
)
end
end
context
'when importing a pull request throws an exception'
do
...
...
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