diff options
author | Ahmad Sherif <me@ahmadsherif.com> | 2016-10-27 15:07:18 +0200 |
---|---|---|
committer | Ahmad Sherif <me@ahmadsherif.com> | 2016-10-27 15:42:28 +0200 |
commit | 4259334fb64ef49580e58d434bc63d3c4738a77c (patch) | |
tree | 73507592fb4ab7311a1c9032978d62b2981e4217 /lib | |
parent | b5797168ec529c179342b8c292c2b52f0cbe41ee (diff) | |
download | gitlab-ce-4259334fb64ef49580e58d434bc63d3c4738a77c.tar.gz |
Fix applying labels for GitHub-imported MRs
Diffstat (limited to 'lib')
-rw-r--r-- | lib/gitlab/github_import/client.rb | 12 | ||||
-rw-r--r-- | lib/gitlab/github_import/importer.rb | 11 |
2 files changed, 16 insertions, 7 deletions
diff --git a/lib/gitlab/github_import/client.rb b/lib/gitlab/github_import/client.rb index 7f424b74efb..348005d5659 100644 --- a/lib/gitlab/github_import/client.rb +++ b/lib/gitlab/github_import/client.rb @@ -105,18 +105,20 @@ module Gitlab data = api.send(method, *args) return data unless data.is_a?(Array) + last_response = api.last_response + if block_given? yield data - each_response_page(&block) + # api.last_response could change while we're yielding (e.g. fetching labels for each PR) + # so we cache our own last request + each_response_page(last_response, &block) else - each_response_page { |page| data.concat(page) } + each_response_page(last_response) { |page| data.concat(page) } data end end - def each_response_page - last_response = api.last_response - + def each_response_page(last_response) while last_response.rels[:next] sleep rate_limit_sleep_time if rate_limit_exceed? last_response = last_response.rels[:next].get diff --git a/lib/gitlab/github_import/importer.rb b/lib/gitlab/github_import/importer.rb index 4b70f33a851..4ac932dc213 100644 --- a/lib/gitlab/github_import/importer.rb +++ b/lib/gitlab/github_import/importer.rb @@ -132,8 +132,15 @@ module Gitlab end def apply_labels(issuable, raw_issuable) - if raw_issuable.labels.count > 0 - label_ids = raw_issuable.labels + # GH returns labels for issues but not for pull requests! + labels = if issuable.is_a?(MergeRequest) + client.labels_for_issue(repo, raw_issuable.number) + else + raw_issuable.labels + end + + if labels.count > 0 + label_ids = labels .map { |attrs| @labels[attrs.name] } .compact |