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
11b21512
Commit
11b21512
authored
Aug 14, 2019
by
GitLab Bot
Browse files
Options
Browse Files
Download
Plain Diff
Automatic merge of gitlab-org/gitlab-ce master
parents
c82ad2ce
ecee476a
Changes
12
Hide whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
215 additions
and
18 deletions
+215
-18
app/models/project.rb
app/models/project.rb
+8
-0
app/services/git/base_hooks_service.rb
app/services/git/base_hooks_service.rb
+33
-12
changelogs/unreleased/sh-optimize-commit-deltas-post-receive.yml
...ogs/unreleased/sh-optimize-commit-deltas-post-receive.yml
+5
-0
doc/user/permissions.md
doc/user/permissions.md
+10
-0
lib/gitlab/data_builder/push.rb
lib/gitlab/data_builder/push.rb
+3
-2
spec/lib/gitlab/data_builder/push_spec.rb
spec/lib/gitlab/data_builder/push_spec.rb
+34
-0
spec/models/project_spec.rb
spec/models/project_spec.rb
+33
-0
spec/services/git/base_hooks_service_spec.rb
spec/services/git/base_hooks_service_spec.rb
+72
-0
spec/services/git/branch_hooks_service_spec.rb
spec/services/git/branch_hooks_service_spec.rb
+3
-1
spec/services/git/branch_push_service_spec.rb
spec/services/git/branch_push_service_spec.rb
+8
-1
spec/services/git/tag_hooks_service_spec.rb
spec/services/git/tag_hooks_service_spec.rb
+4
-2
spec/workers/post_receive_spec.rb
spec/workers/post_receive_spec.rb
+2
-0
No files found.
app/models/project.rb
View file @
11b21512
...
...
@@ -1230,6 +1230,14 @@ class Project < ApplicationRecord
end
end
def
has_active_hooks?
(
hooks_scope
=
:push_hooks
)
hooks
.
hooks_for
(
hooks_scope
).
any?
||
SystemHook
.
hooks_for
(
hooks_scope
).
any?
end
def
has_active_services?
(
hooks_scope
=
:push_hooks
)
services
.
public_send
(
hooks_scope
).
any?
# rubocop:disable GitlabSecurity/PublicSend
end
def
valid_repo?
repository
.
exists?
rescue
...
...
app/services/git/base_hooks_service.rb
View file @
11b21512
...
...
@@ -19,7 +19,7 @@ module Git
update_remote_mirrors
push_data
success
end
private
...
...
@@ -33,7 +33,7 @@ module Git
end
def
limited_commits
commits
.
last
(
PROCESS_COMMIT_LIMIT
)
@limited_commits
||=
commits
.
last
(
PROCESS_COMMIT_LIMIT
)
end
def
commits_count
...
...
@@ -48,21 +48,25 @@ module Git
[]
end
# Push events in the activity feed only show information for the
# last commit.
def
create_events
EventCreateService
.
new
.
push
(
project
,
current_user
,
push_data
)
EventCreateService
.
new
.
push
(
project
,
current_user
,
event_
push_data
)
end
def
create_pipelines
return
unless
params
.
fetch
(
:create_pipelines
,
true
)
Ci
::
CreatePipelineService
.
new
(
project
,
current_user
,
push_data
)
.
new
(
project
,
current_user
,
base_params
)
.
execute
(
:push
,
pipeline_options
)
end
def
execute_project_hooks
project
.
execute_hooks
(
push_data
,
hook_name
)
project
.
execute_services
(
push_data
,
hook_name
)
# Creating push_data invokes one CommitDelta RPC per commit. Only
# build this data if we actually need it.
project
.
execute_hooks
(
push_data
,
hook_name
)
if
project
.
has_active_hooks?
(
hook_name
)
project
.
execute_services
(
push_data
,
hook_name
)
if
project
.
has_active_services?
(
hook_name
)
end
def
enqueue_invalidate_cache
...
...
@@ -73,18 +77,35 @@ module Git
)
end
def
push_data
@push_data
||=
Gitlab
::
DataBuilder
::
Push
.
build
(
project:
project
,
user:
current_user
,
def
base_params
{
oldrev:
params
[
:oldrev
],
newrev:
params
[
:newrev
],
ref:
params
[
:ref
],
commits:
limited_commits
,
push_options:
params
[
:push_options
]
||
{}
}
end
def
push_data_params
(
commits
:,
with_changed_files:
true
)
base_params
.
merge
(
project:
project
,
user:
current_user
,
commits:
commits
,
message:
event_message
,
commits_count:
commits_count
,
push_options:
params
[
:push_options
]
||
{}
with_changed_files:
with_changed_files
)
end
def
event_push_data
# We only need the last commit for the event push, and we don't
# need the full deltas either.
@event_push_data
||=
Gitlab
::
DataBuilder
::
Push
.
build
(
push_data_params
(
commits:
commits
.
last
,
with_changed_files:
false
))
end
def
push_data
@push_data
||=
Gitlab
::
DataBuilder
::
Push
.
build
(
push_data_params
(
commits:
limited_commits
))
# Dependent code may modify the push data, so return a duplicate each time
@push_data
.
dup
...
...
changelogs/unreleased/sh-optimize-commit-deltas-post-receive.yml
0 → 100644
View file @
11b21512
---
title
:
Reduce Gitaly calls in PostReceive
merge_request
:
31741
author
:
type
:
performance
doc/user/permissions.md
View file @
11b21512
...
...
@@ -233,6 +233,16 @@ nested groups if you have membership in one of its parents.
To learn more, read through the documentation on
[
subgroups memberships
](
group/subgroups/index.md#membership
)
.
## Guest User
Create a user and assign to a project with a role as
`Guest`
user, this user
will be considered as guest user by GitLab and will not take up the license.
There is no specific
`Guest`
role for newly created users. If this user will
be assigned a higher role to any of the projects and groups then this user will
take a license seat. If a user creates a project this user becomes a maintainer,
therefore, takes up a license seat as well, in order to prevent this you have
to go and edit user profile and mark the user as External.
## External users permissions
In cases where it is desired that a user has access only to some internal or
...
...
lib/gitlab/data_builder/push.rb
View file @
11b21512
...
...
@@ -60,7 +60,8 @@ module Gitlab
# rubocop:disable Metrics/ParameterLists
def
build
(
project
:,
user
:,
ref
:,
oldrev:
nil
,
newrev:
nil
,
commits:
[],
commits_count:
nil
,
message:
nil
,
push_options:
{})
commits:
[],
commits_count:
nil
,
message:
nil
,
push_options:
{},
with_changed_files:
true
)
commits
=
Array
(
commits
)
...
...
@@ -75,7 +76,7 @@ module Gitlab
# n+1: https://gitlab.com/gitlab-org/gitlab-ce/issues/38259
commit_attrs
=
Gitlab
::
GitalyClient
.
allow_n_plus_1_calls
do
commits_limited
.
map
do
|
commit
|
commit
.
hook_attrs
(
with_changed_files:
true
)
commit
.
hook_attrs
(
with_changed_files:
with_changed_files
)
end
end
...
...
spec/lib/gitlab/data_builder/push_spec.rb
View file @
11b21512
...
...
@@ -3,9 +3,43 @@
require
'spec_helper'
describe
Gitlab
::
DataBuilder
::
Push
do
include
RepoHelpers
let
(
:project
)
{
create
(
:project
,
:repository
)
}
let
(
:user
)
{
build
(
:user
,
public_email:
'public-email@example.com'
)
}
describe
'.build'
do
let
(
:sample
)
{
RepoHelpers
.
sample_compare
}
let
(
:commits
)
{
project
.
repository
.
commits_between
(
sample
.
commits
.
first
,
sample
.
commits
.
last
)
}
let
(
:subject
)
do
described_class
.
build
(
project:
project
,
user:
user
,
ref:
sample
.
target_branch
,
commits:
commits
,
commits_count:
commits
.
length
,
message:
'test message'
,
with_changed_files:
with_changed_files
)
end
context
'with changed files'
do
let
(
:with_changed_files
)
{
true
}
it
'returns commit hook data'
do
expect
(
subject
[
:project
]).
to
eq
(
project
.
hook_attrs
)
expect
(
subject
[
:commits
].
first
.
keys
).
to
include
(
*
%i(added removed modified)
)
end
end
context
'without changed files'
do
let
(
:with_changed_files
)
{
false
}
it
'returns commit hook data without include deltas'
do
expect
(
subject
[
:project
]).
to
eq
(
project
.
hook_attrs
)
expect
(
subject
[
:commits
].
first
.
keys
).
not_to
include
(
*
%i(added removed modified)
)
end
end
end
describe
'.build_sample'
do
let
(
:data
)
{
described_class
.
build_sample
(
project
,
user
)
}
...
...
spec/models/project_spec.rb
View file @
11b21512
...
...
@@ -4312,6 +4312,39 @@ describe Project do
end
end
describe
'#has_active_hooks?'
do
set
(
:project
)
{
create
(
:project
)
}
it
{
expect
(
project
.
has_active_hooks?
).
to
be_falsey
}
it
'returns true when a matching push hook exists'
do
create
(
:project_hook
,
push_events:
true
,
project:
project
)
expect
(
project
.
has_active_hooks?
(
:merge_request_events
)).
to
be_falsey
expect
(
project
.
has_active_hooks?
).
to
be_truthy
end
it
'returns true when a matching system hook exists'
do
create
(
:system_hook
,
push_events:
true
)
expect
(
project
.
has_active_hooks?
(
:merge_request_events
)).
to
be_falsey
expect
(
project
.
has_active_hooks?
).
to
be_truthy
end
end
describe
'#has_active_services?'
do
set
(
:project
)
{
create
(
:project
)
}
it
{
expect
(
project
.
has_active_services?
).
to
be_falsey
}
it
'returns true when a matching service exists'
do
create
(
:custom_issue_tracker_service
,
push_events:
true
,
merge_requests_events:
false
,
project:
project
)
expect
(
project
.
has_active_services?
(
:merge_request_hooks
)).
to
be_falsey
expect
(
project
.
has_active_services?
).
to
be_truthy
end
end
describe
'#badges'
do
let
(
:project_group
)
{
create
(
:group
)
}
let
(
:project
)
{
create
(
:project
,
path:
'avatar'
,
namespace:
project_group
)
}
...
...
spec/services/git/base_hooks_service_spec.rb
View file @
11b21512
...
...
@@ -14,6 +14,78 @@ describe Git::BaseHooksService do
let
(
:newrev
)
{
"8a2a6eb295bb170b34c24c76c49ed0e9b2eaf34b"
}
# gitlab-test: git rev-parse refs/tags/v1.1.0
let
(
:ref
)
{
'refs/tags/v1.1.0'
}
describe
'#execute_project_hooks'
do
class
TestService
<
described_class
def
hook_name
:push_hooks
end
def
commits
[]
end
end
let
(
:project
)
{
create
(
:project
,
:repository
)
}
subject
{
TestService
.
new
(
project
,
user
,
oldrev:
oldrev
,
newrev:
newrev
,
ref:
ref
)
}
context
'#execute_hooks'
do
before
do
expect
(
project
).
to
receive
(
:has_active_hooks?
).
and_return
(
active
)
end
context
'active hooks'
do
let
(
:active
)
{
true
}
it
'executes the hooks'
do
expect
(
subject
).
to
receive
(
:push_data
).
at_least
(
:once
).
and_call_original
expect
(
project
).
to
receive
(
:execute_hooks
)
subject
.
execute
end
end
context
'inactive hooks'
do
let
(
:active
)
{
false
}
it
'does not execute the hooks'
do
expect
(
subject
).
not_to
receive
(
:push_data
)
expect
(
project
).
not_to
receive
(
:execute_hooks
)
subject
.
execute
end
end
end
context
'#execute_services'
do
before
do
expect
(
project
).
to
receive
(
:has_active_services?
).
and_return
(
active
)
end
context
'active services'
do
let
(
:active
)
{
true
}
it
'executes the services'
do
expect
(
subject
).
to
receive
(
:push_data
).
at_least
(
:once
).
and_call_original
expect
(
project
).
to
receive
(
:execute_services
)
subject
.
execute
end
end
context
'inactive services'
do
let
(
:active
)
{
false
}
it
'does not execute the services'
do
expect
(
subject
).
not_to
receive
(
:push_data
)
expect
(
project
).
not_to
receive
(
:execute_services
)
subject
.
execute
end
end
end
end
describe
'with remote mirrors'
do
class
TestService
<
described_class
def
commits
...
...
spec/services/git/branch_hooks_service_spec.rb
View file @
11b21512
...
...
@@ -25,7 +25,7 @@ describe Git::BranchHooksService do
end
describe
"Git Push Data"
do
subject
(
:push_data
)
{
service
.
execute
}
subject
(
:push_data
)
{
service
.
send
(
:push_data
)
}
it
'has expected push data attributes'
do
is_expected
.
to
match
a_hash_including
(
...
...
@@ -109,6 +109,7 @@ describe Git::BranchHooksService do
expect
(
event
.
push_event_payload
).
to
be_an_instance_of
(
PushEventPayload
)
expect
(
event
.
push_event_payload
.
commit_from
).
to
eq
(
oldrev
)
expect
(
event
.
push_event_payload
.
commit_to
).
to
eq
(
newrev
)
expect
(
event
.
push_event_payload
.
commit_title
).
to
eq
(
'Change some files'
)
expect
(
event
.
push_event_payload
.
ref
).
to
eq
(
'master'
)
expect
(
event
.
push_event_payload
.
commit_count
).
to
eq
(
1
)
end
...
...
@@ -124,6 +125,7 @@ describe Git::BranchHooksService do
expect
(
event
.
push_event_payload
).
to
be_an_instance_of
(
PushEventPayload
)
expect
(
event
.
push_event_payload
.
commit_from
).
to
be_nil
expect
(
event
.
push_event_payload
.
commit_to
).
to
eq
(
newrev
)
expect
(
event
.
push_event_payload
.
commit_title
).
to
eq
(
'Initial commit'
)
expect
(
event
.
push_event_payload
.
ref
).
to
eq
(
'master'
)
expect
(
event
.
push_event_payload
.
commit_count
).
to
be
>
1
end
...
...
spec/services/git/branch_push_service_spec.rb
View file @
11b21512
...
...
@@ -78,7 +78,10 @@ describe Git::BranchPushService, services: true do
it
"creates a new pipeline"
do
expect
{
subject
}.
to
change
{
Ci
::
Pipeline
.
count
}
expect
(
Ci
::
Pipeline
.
last
).
to
be_push
pipeline
=
Ci
::
Pipeline
.
last
expect
(
pipeline
).
to
be_push
expect
(
Gitlab
::
Git
::
BRANCH_REF_PREFIX
+
pipeline
.
ref
).
to
eq
(
ref
)
end
end
...
...
@@ -123,6 +126,10 @@ describe Git::BranchPushService, services: true do
describe
"Webhooks"
do
context
"execute webhooks"
do
before
do
create
(
:project_hook
,
push_events:
true
,
project:
project
)
end
it
"when pushing a branch for the first time"
do
expect
(
project
).
to
receive
(
:execute_hooks
)
expect
(
project
.
default_branch
).
to
eq
(
"master"
)
...
...
spec/services/git/tag_hooks_service_spec.rb
View file @
11b21512
...
...
@@ -26,7 +26,8 @@ describe Git::TagHooksService, :service do
describe
'System hooks'
do
it
'Executes system hooks'
do
push_data
=
service
.
execute
push_data
=
service
.
send
(
:push_data
)
expect
(
project
).
to
receive
(
:has_active_hooks?
).
and_return
(
true
)
expect_next_instance_of
(
SystemHooksService
)
do
|
system_hooks_service
|
expect
(
system_hooks_service
)
...
...
@@ -40,6 +41,7 @@ describe Git::TagHooksService, :service do
describe
"Webhooks"
do
it
"executes hooks on the project"
do
expect
(
project
).
to
receive
(
:has_active_hooks?
).
and_return
(
true
)
expect
(
project
).
to
receive
(
:execute_hooks
)
service
.
execute
...
...
@@ -61,7 +63,7 @@ describe Git::TagHooksService, :service do
describe
'Push data'
do
shared_examples_for
'tag push data expectations'
do
subject
(
:push_data
)
{
service
.
execute
}
subject
(
:push_data
)
{
service
.
send
(
:push_data
)
}
it
'has expected push data attributes'
do
is_expected
.
to
match
a_hash_including
(
object_kind:
'tag_push'
,
...
...
spec/workers/post_receive_spec.rb
View file @
11b21512
...
...
@@ -273,6 +273,8 @@ describe PostReceive do
end
it
"asks the project to trigger all hooks"
do
create
(
:project_hook
,
push_events:
true
,
tag_push_events:
true
,
project:
project
)
create
(
:custom_issue_tracker_service
,
push_events:
true
,
merge_requests_events:
false
,
project:
project
)
allow
(
Project
).
to
receive
(
:find_by
).
and_return
(
project
)
expect
(
project
).
to
receive
(
:execute_hooks
).
twice
...
...
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