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
c49990ce
Commit
c49990ce
authored
Aug 26, 2018
by
GitLab Bot
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'upstream/master' into ce-to-ee-2018-08-26
parents
f19dc6c5
68b84d81
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
98 additions
and
8 deletions
+98
-8
changelogs/unreleased/sh-insert-git-data-in-separate-transaction.yml
...unreleased/sh-insert-git-data-in-separate-transaction.yml
+5
-0
lib/gitlab/bitbucket_server_import/importer.rb
lib/gitlab/bitbucket_server_import/importer.rb
+10
-8
lib/gitlab/import/merge_request_creator.rb
lib/gitlab/import/merge_request_creator.rb
+40
-0
spec/lib/gitlab/import/merge_request_creator_spec.rb
spec/lib/gitlab/import/merge_request_creator_spec.rb
+43
-0
No files found.
changelogs/unreleased/sh-insert-git-data-in-separate-transaction.yml
0 → 100644
View file @
c49990ce
---
title
:
'
Bitbucket
Server
importer:
Eliminate
most
idle-in-transaction
issues'
merge_request
:
author
:
type
:
performance
lib/gitlab/bitbucket_server_import/importer.rb
View file @
c49990ce
# frozen_string_literal: true
module
Gitlab
module
Gitlab
module
BitbucketServerImport
module
BitbucketServerImport
class
Importer
class
Importer
include
Gitlab
::
ShellAdapter
include
Gitlab
::
ShellAdapter
attr_reader
:recover_missing_commits
attr_reader
:recover_missing_commits
attr_reader
:project
,
:project_key
,
:repository_slug
,
:client
,
:errors
,
:users
attr_reader
:project
,
:project_key
,
:repository_slug
,
:client
,
:errors
,
:users
...
@@ -175,21 +178,18 @@ module Gitlab
...
@@ -175,21 +178,18 @@ module Gitlab
description
=
''
description
=
''
description
+=
@formatter
.
author_line
(
pull_request
.
author
)
unless
find_user_id
(
pull_request
.
author_email
)
description
+=
@formatter
.
author_line
(
pull_request
.
author
)
unless
find_user_id
(
pull_request
.
author_email
)
description
+=
pull_request
.
description
if
pull_request
.
description
description
+=
pull_request
.
description
if
pull_request
.
description
source_branch_sha
=
pull_request
.
source_branch_sha
target_branch_sha
=
pull_request
.
target_branch_sha
author_id
=
gitlab_user_id
(
pull_request
.
author_email
)
author_id
=
gitlab_user_id
(
pull_request
.
author_email
)
attributes
=
{
attributes
=
{
iid:
pull_request
.
iid
,
iid:
pull_request
.
iid
,
title:
pull_request
.
title
,
title:
pull_request
.
title
,
description:
description
,
description:
description
,
source_project
:
project
,
source_project
_id:
project
.
id
,
source_branch:
Gitlab
::
Git
.
ref_name
(
pull_request
.
source_branch_name
),
source_branch:
Gitlab
::
Git
.
ref_name
(
pull_request
.
source_branch_name
),
source_branch_sha:
source_branch_sha
,
source_branch_sha:
pull_request
.
source_branch_sha
,
target_project
:
project
,
target_project
_id:
project
.
id
,
target_branch:
Gitlab
::
Git
.
ref_name
(
pull_request
.
target_branch_name
),
target_branch:
Gitlab
::
Git
.
ref_name
(
pull_request
.
target_branch_name
),
target_branch_sha:
target_branch_sha
,
target_branch_sha:
pull_request
.
target_branch_sha
,
state:
pull_request
.
state
,
state:
pull_request
.
state
,
author_id:
author_id
,
author_id:
author_id
,
assignee_id:
nil
,
assignee_id:
nil
,
...
@@ -197,7 +197,9 @@ module Gitlab
...
@@ -197,7 +197,9 @@ module Gitlab
updated_at:
pull_request
.
updated_at
updated_at:
pull_request
.
updated_at
}
}
merge_request
=
project
.
merge_requests
.
create!
(
attributes
)
creator
=
Gitlab
::
Import
::
MergeRequestCreator
.
new
(
project
)
merge_request
=
creator
.
execute
(
attributes
)
import_pull_request_comments
(
pull_request
,
merge_request
)
if
merge_request
.
persisted?
import_pull_request_comments
(
pull_request
,
merge_request
)
if
merge_request
.
persisted?
end
end
...
...
lib/gitlab/import/merge_request_creator.rb
0 → 100644
View file @
c49990ce
# frozen_string_literal: true
# This module is designed for importers that need to create many merge
# requests quickly. When creating merge requests there are a lot of hooks
# that may run, for many different reasons. Many of these hooks (e.g. the ones
# used for rendering Markdown) are completely unnecessary and may even lead to
# transaction timeouts.
#
# To ensure importing merge requests requests has a minimal impact and can
# complete in a reasonable time we bypass all the hooks by inserting the row
# and then retrieving it. We then only perform the additional work that is
# strictly necessary.
module
Gitlab
module
Import
class
MergeRequestCreator
include
::
Gitlab
::
Import
::
DatabaseHelpers
include
::
Gitlab
::
Import
::
MergeRequestHelpers
attr_accessor
:project
def
initialize
(
project
)
@project
=
project
end
def
execute
(
attributes
)
source_branch_sha
=
attributes
.
delete
(
:source_branch_sha
)
target_branch_sha
=
attributes
.
delete
(
:target_branch_sha
)
iid
=
attributes
[
:iid
]
merge_request
,
already_exists
=
create_merge_request_without_hooks
(
project
,
attributes
,
iid
)
if
merge_request
insert_or_replace_git_data
(
merge_request
,
source_branch_sha
,
target_branch_sha
,
already_exists
)
end
merge_request
end
end
end
end
spec/lib/gitlab/import/merge_request_creator_spec.rb
0 → 100644
View file @
c49990ce
# frozen_string_literal: true
require
'spec_helper'
describe
Gitlab
::
Import
::
MergeRequestCreator
do
let
(
:project
)
{
create
(
:project
,
:repository
)
}
subject
{
described_class
.
new
(
project
)
}
describe
'#execute'
do
context
'merge request already exists'
do
let
(
:merge_request
)
{
create
(
:merge_request
,
target_project:
project
,
source_project:
project
)
}
let
(
:commits
)
{
merge_request
.
merge_request_diffs
.
first
.
commits
}
let
(
:attributes
)
{
HashWithIndifferentAccess
.
new
(
merge_request
.
attributes
)
}
it
'updates the data'
do
commits_count
=
commits
.
count
merge_request
.
merge_request_diffs
.
destroy_all
# rubocop: disable DestroyAll
expect
(
merge_request
.
merge_request_diffs
.
count
).
to
eq
(
0
)
subject
.
execute
(
attributes
)
expect
(
merge_request
.
reload
.
merge_request_diffs
.
count
).
to
eq
(
1
)
expect
(
merge_request
.
reload
.
merge_request_diffs
.
first
.
commits
.
count
).
to
eq
(
commits_count
)
end
end
context
'new merge request'
do
let
(
:merge_request
)
{
build
(
:merge_request
,
target_project:
project
,
source_project:
project
)
}
let
(
:attributes
)
{
HashWithIndifferentAccess
.
new
(
merge_request
.
attributes
)
}
it
'creates a new merge request'
do
attributes
.
delete
(
:id
)
expect
{
subject
.
execute
(
attributes
)
}.
to
change
{
MergeRequest
.
count
}.
by
(
1
)
new_mr
=
MergeRequest
.
last
expect
(
new_mr
.
merge_request_diffs
.
count
).
to
eq
(
1
)
end
end
end
end
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