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
b82f415f
Commit
b82f415f
authored
Nov 22, 2016
by
Lin Jen-Shin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Move all branch creation to raw_ensure_branch,
and keep it only called in update_branch_with_hooks.
parent
d4d138ee
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
69 additions
and
49 deletions
+69
-49
app/models/project.rb
app/models/project.rb
+0
-11
app/models/repository.rb
app/models/repository.rb
+65
-20
app/services/create_branch_service.rb
app/services/create_branch_service.rb
+2
-6
app/services/files/base_service.rb
app/services/files/base_service.rb
+1
-12
app/services/files/update_service.rb
app/services/files/update_service.rb
+1
-0
No files found.
app/models/project.rb
View file @
b82f415f
...
@@ -998,17 +998,6 @@ class Project < ActiveRecord::Base
...
@@ -998,17 +998,6 @@ class Project < ActiveRecord::Base
Gitlab
::
UploadsTransfer
.
new
.
rename_project
(
path_was
,
path
,
namespace
.
path
)
Gitlab
::
UploadsTransfer
.
new
.
rename_project
(
path_was
,
path
,
namespace
.
path
)
end
end
def
fetch_ref
(
source_project
,
branch_name
,
ref
)
repository
.
fetch_ref
(
source_project
.
repository
.
path_to_repo
,
"refs/heads/
#{
ref
}
"
,
"refs/heads/
#{
branch_name
}
"
)
repository
.
after_create_branch
repository
.
find_branch
(
branch_name
)
end
# Expires various caches before a project is renamed.
# Expires various caches before a project is renamed.
def
expire_caches_before_rename
(
old_path
)
def
expire_caches_before_rename
(
old_path
)
repo
=
Repository
.
new
(
old_path
,
self
)
repo
=
Repository
.
new
(
old_path
,
self
)
...
...
app/models/repository.rb
View file @
b82f415f
...
@@ -784,13 +784,16 @@ class Repository
...
@@ -784,13 +784,16 @@ class Repository
@tags
||=
raw_repository
.
tags
@tags
||=
raw_repository
.
tags
end
end
# rubocop:disable Metrics/ParameterLists
def
commit_dir
(
def
commit_dir
(
user
,
path
,
message
,
branch
,
user
,
path
,
message
,
branch
,
author_email:
nil
,
author_name:
nil
,
source_branch:
nil
)
author_email:
nil
,
author_name:
nil
,
source_branch:
nil
,
source_project:
project
)
update_branch_with_hooks
(
update_branch_with_hooks
(
user
,
user
,
branch
,
branch
,
source_branch:
source_branch
)
do
|
ref
|
source_branch:
source_branch
,
source_project:
source_project
)
do
|
ref
|
options
=
{
options
=
{
commit:
{
commit:
{
branch:
ref
,
branch:
ref
,
...
@@ -804,15 +807,18 @@ class Repository
...
@@ -804,15 +807,18 @@ class Repository
raw_repository
.
mkdir
(
path
,
options
)
raw_repository
.
mkdir
(
path
,
options
)
end
end
end
end
# rubocop:enable Metrics/ParameterLists
# rubocop:disable Metrics/ParameterLists
# rubocop:disable Metrics/ParameterLists
def
commit_file
(
def
commit_file
(
user
,
path
,
content
,
message
,
branch
,
update
,
user
,
path
,
content
,
message
,
branch
,
update
,
author_email:
nil
,
author_name:
nil
,
source_branch:
nil
)
author_email:
nil
,
author_name:
nil
,
source_branch:
nil
,
source_project:
project
)
update_branch_with_hooks
(
update_branch_with_hooks
(
user
,
user
,
branch
,
branch
,
source_branch:
source_branch
)
do
|
ref
|
source_branch:
source_branch
,
source_project:
source_project
)
do
|
ref
|
options
=
{
options
=
{
commit:
{
commit:
{
branch:
ref
,
branch:
ref
,
...
@@ -837,11 +843,13 @@ class Repository
...
@@ -837,11 +843,13 @@ class Repository
def
update_file
(
def
update_file
(
user
,
path
,
content
,
user
,
path
,
content
,
branch
:,
previous_path
:,
message
:,
branch
:,
previous_path
:,
message
:,
author_email:
nil
,
author_name:
nil
,
source_branch:
nil
)
author_email:
nil
,
author_name:
nil
,
source_branch:
nil
,
source_project:
project
)
update_branch_with_hooks
(
update_branch_with_hooks
(
user
,
user
,
branch
,
branch
,
source_branch:
source_branch
)
do
|
ref
|
source_branch:
source_branch
,
source_project:
source_project
)
do
|
ref
|
options
=
{
options
=
{
commit:
{
commit:
{
branch:
ref
,
branch:
ref
,
...
@@ -867,13 +875,16 @@ class Repository
...
@@ -867,13 +875,16 @@ class Repository
end
end
# rubocop:enable Metrics/ParameterLists
# rubocop:enable Metrics/ParameterLists
# rubocop:disable Metrics/ParameterLists
def
remove_file
(
def
remove_file
(
user
,
path
,
message
,
branch
,
user
,
path
,
message
,
branch
,
author_email:
nil
,
author_name:
nil
,
source_branch:
nil
)
author_email:
nil
,
author_name:
nil
,
source_branch:
nil
,
source_project:
project
)
update_branch_with_hooks
(
update_branch_with_hooks
(
user
,
user
,
branch
,
branch
,
source_branch:
source_branch
)
do
|
ref
|
source_branch:
source_branch
,
source_project:
source_project
)
do
|
ref
|
options
=
{
options
=
{
commit:
{
commit:
{
branch:
ref
,
branch:
ref
,
...
@@ -890,14 +901,18 @@ class Repository
...
@@ -890,14 +901,18 @@ class Repository
Gitlab
::
Git
::
Blob
.
remove
(
raw_repository
,
options
)
Gitlab
::
Git
::
Blob
.
remove
(
raw_repository
,
options
)
end
end
end
end
# rubocop:enable Metrics/ParameterLists
# rubocop:disable Metrics/ParameterLists
def
multi_action
(
def
multi_action
(
user
:,
branch
:,
message
:,
actions
:,
user
:,
branch
:,
message
:,
actions
:,
author_email:
nil
,
author_name:
nil
,
source_branch:
nil
)
author_email:
nil
,
author_name:
nil
,
source_branch:
nil
,
source_project:
project
)
update_branch_with_hooks
(
update_branch_with_hooks
(
user
,
user
,
branch
,
branch
,
source_branch:
source_branch
)
do
|
ref
|
source_branch:
source_branch
,
source_project:
source_project
)
do
|
ref
|
index
=
rugged
.
index
index
=
rugged
.
index
branch_commit
=
find_branch
(
ref
)
branch_commit
=
find_branch
(
ref
)
...
@@ -942,6 +957,7 @@ class Repository
...
@@ -942,6 +957,7 @@ class Repository
Rugged
::
Commit
.
create
(
rugged
,
options
)
Rugged
::
Commit
.
create
(
rugged
,
options
)
end
end
end
end
# rubocop:enable Metrics/ParameterLists
def
get_committer_and_author
(
user
,
email:
nil
,
name:
nil
)
def
get_committer_and_author
(
user
,
email:
nil
,
name:
nil
)
committer
=
user_to_committer
(
user
)
committer
=
user_to_committer
(
user
)
...
@@ -991,8 +1007,6 @@ class Repository
...
@@ -991,8 +1007,6 @@ class Repository
end
end
def
revert
(
user
,
commit
,
base_branch
,
revert_tree_id
=
nil
)
def
revert
(
user
,
commit
,
base_branch
,
revert_tree_id
=
nil
)
source_sha
=
raw_ensure_branch
(
base_branch
,
source_commit:
commit
).
first
.
dereferenced_target
.
sha
revert_tree_id
||=
check_revert_content
(
commit
,
base_branch
)
revert_tree_id
||=
check_revert_content
(
commit
,
base_branch
)
return
false
unless
revert_tree_id
return
false
unless
revert_tree_id
...
@@ -1000,8 +1014,11 @@ class Repository
...
@@ -1000,8 +1014,11 @@ class Repository
update_branch_with_hooks
(
update_branch_with_hooks
(
user
,
user
,
base_branch
,
base_branch
,
source_branch:
revert_tree_id
)
do
source_commit:
commit
)
do
source_sha
=
find_branch
(
base_branch
).
dereferenced_target
.
sha
committer
=
user_to_committer
(
user
)
committer
=
user_to_committer
(
user
)
Rugged
::
Commit
.
create
(
rugged
,
Rugged
::
Commit
.
create
(
rugged
,
message:
commit
.
revert_message
,
message:
commit
.
revert_message
,
author:
committer
,
author:
committer
,
...
@@ -1012,8 +1029,6 @@ class Repository
...
@@ -1012,8 +1029,6 @@ class Repository
end
end
def
cherry_pick
(
user
,
commit
,
base_branch
,
cherry_pick_tree_id
=
nil
)
def
cherry_pick
(
user
,
commit
,
base_branch
,
cherry_pick_tree_id
=
nil
)
source_sha
=
raw_ensure_branch
(
base_branch
,
source_commit:
commit
).
first
.
dereferenced_target
.
sha
cherry_pick_tree_id
||=
check_cherry_pick_content
(
commit
,
base_branch
)
cherry_pick_tree_id
||=
check_cherry_pick_content
(
commit
,
base_branch
)
return
false
unless
cherry_pick_tree_id
return
false
unless
cherry_pick_tree_id
...
@@ -1021,8 +1036,11 @@ class Repository
...
@@ -1021,8 +1036,11 @@ class Repository
update_branch_with_hooks
(
update_branch_with_hooks
(
user
,
user
,
base_branch
,
base_branch
,
source_branch:
cherry_pick_tree_id
)
do
source_commit:
commit
)
do
source_sha
=
find_branch
(
base_branch
).
dereferenced_target
.
sha
committer
=
user_to_committer
(
user
)
committer
=
user_to_committer
(
user
)
Rugged
::
Commit
.
create
(
rugged
,
Rugged
::
Commit
.
create
(
rugged
,
message:
commit
.
message
,
message:
commit
.
message
,
author:
{
author:
{
...
@@ -1130,12 +1148,19 @@ class Repository
...
@@ -1130,12 +1148,19 @@ class Repository
# Whenever `source_branch` is passed, if `branch` doesn't exist, it would
# Whenever `source_branch` is passed, if `branch` doesn't exist, it would
# be created from `source_branch`.
# be created from `source_branch`.
def
update_branch_with_hooks
(
current_user
,
branch
,
source_branch:
nil
)
def
update_branch_with_hooks
(
current_user
,
branch
,
source_branch:
nil
,
source_commit:
nil
,
source_project:
project
)
update_autocrlf_option
update_autocrlf_option
ref
=
Gitlab
::
Git
::
BRANCH_REF_PREFIX
+
branch
target_branch
,
new_branch_added
=
target_branch
,
new_branch_added
=
raw_ensure_branch
(
branch
,
source_branch:
source_branch
)
raw_ensure_branch
(
branch
,
source_branch:
source_branch
,
source_project:
source_project
)
ref
=
Gitlab
::
Git
::
BRANCH_REF_PREFIX
+
branch
was_empty
=
empty?
was_empty
=
empty?
# Make commit
# Make commit
...
@@ -1244,11 +1269,31 @@ class Repository
...
@@ -1244,11 +1269,31 @@ class Repository
Gitlab
::
Metrics
.
add_event
(
event
,
{
path:
path_with_namespace
}.
merge
(
tags
))
Gitlab
::
Metrics
.
add_event
(
event
,
{
path:
path_with_namespace
}.
merge
(
tags
))
end
end
def
raw_ensure_branch
(
branch_name
,
source_commit:
nil
,
source_branch:
nil
)
def
raw_ensure_branch
(
branch_name
,
source_commit:
nil
,
source_branch:
nil
,
source_project:
nil
)
old_branch
=
find_branch
(
branch_name
)
old_branch
=
find_branch
(
branch_name
)
if
source_commit
&&
source_branch
raise
ArgumentError
,
'Should only pass either :source_branch or :source_commit, not both'
end
if
old_branch
if
old_branch
[
old_branch
,
false
]
[
old_branch
,
false
]
elsif
project
!=
source_project
unless
source_branch
raise
ArgumentError
,
'Should also pass :source_branch if'
+
' :source_project is different from current project'
end
fetch_ref
(
source_project
.
repository
.
path_to_repo
,
"
#{
Gitlab
::
Git
::
BRANCH_REF_PREFIX
}#{
source_branch
}
"
,
"
#{
Gitlab
::
Git
::
BRANCH_REF_PREFIX
}#{
branch
}
"
)
[
find_branch
(
branch_name
),
true
]
elsif
source_commit
||
source_branch
elsif
source_commit
||
source_branch
oldrev
=
Gitlab
::
Git
::
BLANK_SHA
oldrev
=
Gitlab
::
Git
::
BLANK_SHA
ref
=
Gitlab
::
Git
::
BRANCH_REF_PREFIX
+
branch_name
ref
=
Gitlab
::
Git
::
BRANCH_REF_PREFIX
+
branch_name
...
...
app/services/create_branch_service.rb
View file @
b82f415f
require_relative
'base_service'
require_relative
'base_service'
class
CreateBranchService
<
BaseService
class
CreateBranchService
<
BaseService
def
execute
(
branch_name
,
ref
,
source_project:
@project
)
def
execute
(
branch_name
,
ref
)
failure
=
validate_new_branch
(
branch_name
)
failure
=
validate_new_branch
(
branch_name
)
return
failure
if
failure
return
failure
if
failure
new_branch
=
if
source_project
!=
@project
new_branch
=
repository
.
add_branch
(
current_user
,
branch_name
,
ref
)
@project
.
fetch_ref
(
source_project
,
branch_name
,
ref
)
else
repository
.
add_branch
(
current_user
,
branch_name
,
ref
)
end
if
new_branch
if
new_branch
success
(
new_branch
)
success
(
new_branch
)
...
...
app/services/files/base_service.rb
View file @
b82f415f
...
@@ -23,7 +23,7 @@ module Files
...
@@ -23,7 +23,7 @@ module Files
validate
validate
# Create new branch if it different from source_branch
# Create new branch if it different from source_branch
ensur
e_target_branch
if
different_branch?
validat
e_target_branch
if
different_branch?
result
=
commit
result
=
commit
if
result
if
result
...
@@ -71,17 +71,6 @@ module Files
...
@@ -71,17 +71,6 @@ module Files
end
end
end
end
def
ensure_target_branch
validate_target_branch
if
@source_project
!=
project
# Make sure we have the source_branch in target project,
# and use source_branch as target_branch directly to avoid
# unnecessary source branch in target project.
@project
.
fetch_ref
(
@source_project
,
@target_branch
,
@source_branch
)
end
end
def
validate_target_branch
def
validate_target_branch
result
=
ValidateNewBranchService
.
new
(
project
,
current_user
).
result
=
ValidateNewBranchService
.
new
(
project
,
current_user
).
execute
(
@target_branch
)
execute
(
@target_branch
)
...
...
app/services/files/update_service.rb
View file @
b82f415f
...
@@ -11,6 +11,7 @@ module Files
...
@@ -11,6 +11,7 @@ module Files
message:
@commit_message
,
message:
@commit_message
,
author_email:
@author_email
,
author_email:
@author_email
,
author_name:
@author_name
,
author_name:
@author_name
,
source_project:
@source_project
,
source_branch:
@source_branch
)
source_branch:
@source_branch
)
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