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
07275dd7
Commit
07275dd7
authored
Oct 27, 2016
by
Ahmad Sherif
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Abstract the use of imported[!?] and {current,increment}_page in GitHub importer
parent
bc6302b9
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
34 additions
and
50 deletions
+34
-50
lib/gitlab/github_import/importer.rb
lib/gitlab/github_import/importer.rb
+34
-50
No files found.
lib/gitlab/github_import/importer.rb
View file @
07275dd7
...
...
@@ -20,13 +20,14 @@ module Gitlab
end
def
execute
import_labels
unless
imported?
(
:labels
)
import_milestones
unless
imported?
(
:milestones
)
import_issues
unless
imported?
(
:issues
)
import_pull_requests
unless
imported?
(
:pull_requests
)
import_comments
import_labels
import_milestones
import_issues
import_pull_requests
import_comments
(
:issues
)
import_comments
(
:pull_requests
)
import_wiki
import_releases
unless
imported?
(
:releases
)
import_releases
handle_errors
true
...
...
@@ -48,7 +49,7 @@ module Gitlab
end
def
import_labels
client
.
labels
(
repo
,
page:
current_page
(
:labels
)
,
per_page:
100
)
do
|
labels
|
fetch_resources
(
:labels
,
repo
,
per_page:
100
)
do
|
labels
|
labels
.
each
do
|
raw
|
begin
label
=
LabelFormatter
.
new
(
project
,
raw
).
create!
...
...
@@ -57,15 +58,11 @@ module Gitlab
errors
<<
{
type: :label
,
url:
Gitlab
::
UrlSanitizer
.
sanitize
(
raw
.
url
),
errors:
e
.
message
}
end
end
increment_page
(
:labels
)
end
imported!
(
:labels
)
end
def
import_milestones
client
.
milestones
(
repo
,
state: :all
,
page:
current_page
(
:milestones
)
,
per_page:
100
)
do
|
milestones
|
fetch_resources
(
:milestones
,
repo
,
state: :all
,
per_page:
100
)
do
|
milestones
|
milestones
.
each
do
|
raw
|
begin
MilestoneFormatter
.
new
(
project
,
raw
).
create!
...
...
@@ -73,15 +70,11 @@ module Gitlab
errors
<<
{
type: :milestone
,
url:
Gitlab
::
UrlSanitizer
.
sanitize
(
raw
.
url
),
errors:
e
.
message
}
end
end
increment_page
(
:milestones
)
end
imported!
(
:milestones
)
end
def
import_issues
client
.
issues
(
repo
,
state: :all
,
sort: :created
,
direction: :asc
,
page:
current_page
(
:issues
)
,
per_page:
100
)
do
|
issues
|
fetch_resources
(
:issues
,
repo
,
state: :all
,
sort: :created
,
direction: :asc
,
per_page:
100
)
do
|
issues
|
issues
.
each
do
|
raw
|
gh_issue
=
IssueFormatter
.
new
(
project
,
raw
)
...
...
@@ -94,15 +87,11 @@ module Gitlab
end
end
end
increment_page
(
:issues
)
end
imported!
(
:issues
)
end
def
import_pull_requests
client
.
pull_requests
(
repo
,
state: :all
,
sort: :created
,
direction: :asc
,
page:
current_page
(
:pull_requests
)
,
per_page:
100
)
do
|
pull_requests
|
fetch_resources
(
:pull_requests
,
repo
,
state: :all
,
sort: :created
,
direction: :asc
,
per_page:
100
)
do
|
pull_requests
|
pull_requests
.
each
do
|
raw
|
pull_request
=
PullRequestFormatter
.
new
(
project
,
raw
)
next
unless
pull_request
.
valid?
...
...
@@ -119,13 +108,9 @@ module Gitlab
clean_up_restored_branches
(
pull_request
)
end
end
increment_page
(
:pull_requests
)
end
project
.
repository
.
after_remove_branch
imported!
(
:pull_requests
)
end
def
restore_source_branch
(
pull_request
)
...
...
@@ -164,35 +149,25 @@ module Gitlab
end
end
def
import_comments
# We don't have a distinctive attribute for comments (unlike issues iid), so we fetch the last inserted note,
def
import_comments
(
issuable_type
)
resource_type
=
"
#{
issuable_type
}
_comments"
.
to_sym
# Two notes here:
# 1. We don't have a distinctive attribute for comments (unlike issues iid), so we fetch the last inserted note,
# compare it against every comment in the current imported page until we find match, and that's where start importing
last_note
=
Note
.
where
(
noteable_type:
'Issue'
).
last
# 2. GH returns comments for _both_ issues and PRs through issues_comments API, while pull_requests_comments returns
# only comments on diffs, so select last note not based on noteable_type but on line_code
line_code_is
=
issuable_type
==
:pull_requests
?
'NOT NULL'
:
'NULL'
last_note
=
project
.
notes
.
where
(
"line_code IS
#{
line_code_is
}
"
).
last
client
.
issues_comments
(
repo
,
page:
current_page
(
:issue_comments
)
,
per_page:
100
)
do
|
comments
|
fetch_resources
(
resource_type
,
repo
,
per_page:
100
)
do
|
comments
|
if
last_note
discard_inserted_comments
(
comments
,
last_note
)
last_note
=
nil
end
create_comments
(
comments
)
increment_page
(
:issue_comments
)
end
unless
imported?
(
:issue_comments
)
imported!
(
:issue_comments
)
last_note
=
Note
.
where
(
noteable_type:
'MergeRequest'
).
last
client
.
pull_requests_comments
(
repo
,
page:
current_page
(
:pull_request_comments
),
per_page:
100
)
do
|
comments
|
if
last_note
discard_inserted_comments
(
comments
,
last_note
)
last_note
=
nil
end
create_comments
(
comments
)
increment_page
(
:pull_request_comments
)
end
unless
imported?
(
:pull_request_comments
)
imported!
(
:pull_request_comments
)
end
def
create_comments
(
comments
)
...
...
@@ -247,7 +222,7 @@ module Gitlab
end
def
import_releases
client
.
releases
(
repo
,
page:
current_page
(
:releases
)
,
per_page:
100
)
do
|
releases
|
fetch_resources
(
:releases
,
repo
,
per_page:
100
)
do
|
releases
|
releases
.
each
do
|
raw
|
begin
gh_release
=
ReleaseFormatter
.
new
(
project
,
raw
)
...
...
@@ -256,11 +231,20 @@ module Gitlab
errors
<<
{
type: :release
,
url:
Gitlab
::
UrlSanitizer
.
sanitize
(
raw
.
url
),
errors:
e
.
message
}
end
end
end
end
def
fetch_resources
(
resource_type
,
*
opts
)
return
if
imported?
(
resource_type
)
opts
.
last
.
merge!
(
page:
current_page
(
resource_type
))
increment_page
(
:releases
)
client
.
public_send
(
resource_type
,
*
opts
)
do
|
resources
|
yield
resources
increment_page
(
resource_type
)
end
imported!
(
:releases
)
imported!
(
resource_type
)
end
def
imported?
(
resource_type
)
...
...
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