Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJames Lopez <james@jameslopez.es>2018-06-20 12:57:22 +0300
committerJames Lopez <james@jameslopez.es>2018-06-20 12:57:22 +0300
commitcc061cd1c664f2003d4c7abb3930834704d2eb9e (patch)
treee809e1cdf307f735b47ca7823332a9be8626614f /lib/gitlab/import_export/relation_factory.rb
parent4e9b094b29c225878dfe15a200dd60f0bc1fdd67 (diff)
fix some more edge cases
Diffstat (limited to 'lib/gitlab/import_export/relation_factory.rb')
-rw-r--r--lib/gitlab/import_export/relation_factory.rb15
1 files changed, 10 insertions, 5 deletions
diff --git a/lib/gitlab/import_export/relation_factory.rb b/lib/gitlab/import_export/relation_factory.rb
index 516f3bdbd4e..ff3873bc8ed 100644
--- a/lib/gitlab/import_export/relation_factory.rb
+++ b/lib/gitlab/import_export/relation_factory.rb
@@ -80,8 +80,7 @@ module Gitlab
case @relation_name
when :merge_request_diff_files then setup_diff
when :notes then setup_note
- when :milestone, :milestones,
- :project_label, :project_labels then setup_project_group
+ when *(EXISTING_OBJECT_CHECK - [:project_feature]) then setup_project_group
when 'Ci::Pipeline' then setup_pipeline
else
@relation_hash['project_id'] = @project.id
@@ -275,7 +274,11 @@ module Gitlab
end
def find_or_create_object!
- finder_hash = parsed_relation_hash.slice('title', 'project_id', 'group_id')
+ # Can't use IDs as validation exists calilng `.group` or `.project`
+ finder_hash = { project: @project }.tap do |hash|
+ hash[:group] = @project.group if relation_class.attribute_method?('group_id')
+ hash[:title] = parsed_relation_hash['title'] if parsed_relation_hash['title']
+ end
if label?
label = GroupProjectFinder.find_or_new(Label, finder_hash)
@@ -288,8 +291,10 @@ module Gitlab
object = GroupProjectFinder.find_or_create(relation_class, finder_hash)
if milestone?
- parsed_relation_hash.delete('group_id') if object.project_id
- parsed_relation_hash.delete('project_id') if object.group_id
+ parsed_relation_hash.delete('group_id') if object.project
+ parsed_relation_hash.delete('project_id') if object.group
+ parsed_relation_hash.delete('iid')
+ parsed_relation_hash.delete('id')
end
object