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
Léo-Paul Géneau
gitlab-ce
Commits
e9b5b10a
Commit
e9b5b10a
authored
Dec 28, 2018
by
Francisco Javier López
Committed by
Douwe Maan
Dec 28, 2018
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Skip per-commit validations which have already passed on another change/branch
parent
cf200b64
Changes
7
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
90 additions
and
16 deletions
+90
-16
app/models/commit.rb
app/models/commit.rb
+4
-0
changelogs/unreleased/fj-44679-skip-per-commit-validations.yml
...elogs/unreleased/fj-44679-skip-per-commit-validations.yml
+5
-0
lib/gitlab/checks/base_checker.rb
lib/gitlab/checks/base_checker.rb
+16
-0
lib/gitlab/checks/diff_check.rb
lib/gitlab/checks/diff_check.rb
+11
-13
lib/gitlab/checks/lfs_check.rb
lib/gitlab/checks/lfs_check.rb
+1
-0
spec/lib/gitlab/checks/diff_check_spec.rb
spec/lib/gitlab/checks/diff_check_spec.rb
+38
-0
spec/lib/gitlab/git_access_spec.rb
spec/lib/gitlab/git_access_spec.rb
+15
-3
No files found.
app/models/commit.rb
View file @
e9b5b10a
...
@@ -469,6 +469,10 @@ class Commit
...
@@ -469,6 +469,10 @@ class Commit
!!
merged_merge_request
(
user
)
!!
merged_merge_request
(
user
)
end
end
def
cache_key
"commit:
#{
sha
}
"
end
private
private
def
commit_reference
(
from
,
referable_commit_id
,
full:
false
)
def
commit_reference
(
from
,
referable_commit_id
,
full:
false
)
...
...
changelogs/unreleased/fj-44679-skip-per-commit-validations.yml
0 → 100644
View file @
e9b5b10a
---
title
:
Skip per-commit validations already evaluated
merge_request
:
23984
author
:
type
:
performance
lib/gitlab/checks/base_checker.rb
View file @
e9b5b10a
...
@@ -33,6 +33,22 @@ module Gitlab
...
@@ -33,6 +33,22 @@ module Gitlab
def
tag_exists?
def
tag_exists?
project
.
repository
.
tag_exists?
(
tag_name
)
project
.
repository
.
tag_exists?
(
tag_name
)
end
end
def
validate_once
(
resource
)
Gitlab
::
SafeRequestStore
.
fetch
(
cache_key_for_resource
(
resource
))
do
yield
(
resource
)
true
end
end
def
cache_key_for_resource
(
resource
)
"git_access:
#{
checker_cache_key
}
:
#{
resource
.
cache_key
}
"
end
def
checker_cache_key
self
.
class
.
name
.
demodulize
.
underscore
end
end
end
end
end
end
end
lib/gitlab/checks/diff_check.rb
View file @
e9b5b10a
...
@@ -14,13 +14,17 @@ module Gitlab
...
@@ -14,13 +14,17 @@ module Gitlab
return
if
deletion?
||
newrev
.
nil?
return
if
deletion?
||
newrev
.
nil?
return
unless
should_run_diff_validations?
return
unless
should_run_diff_validations?
return
if
commits
.
empty?
return
if
commits
.
empty?
return
unless
uses_raw_delta_validations?
file_paths
=
[]
file_paths
=
[]
process_raw_deltas
do
|
diff
|
file_paths
<<
(
diff
.
new_path
||
diff
.
old_path
)
validate_diff
(
diff
)
process_commits
do
|
commit
|
validate_once
(
commit
)
do
commit
.
raw_deltas
.
each
do
|
diff
|
file_paths
<<
(
diff
.
new_path
||
diff
.
old_path
)
validate_diff
(
diff
)
end
end
end
end
validate_file_paths
(
file_paths
)
validate_file_paths
(
file_paths
)
...
@@ -28,17 +32,13 @@ module Gitlab
...
@@ -28,17 +32,13 @@ module Gitlab
private
private
def
should_run_diff_validations?
validate_lfs_file_locks?
end
def
validate_lfs_file_locks?
def
validate_lfs_file_locks?
strong_memoize
(
:validate_lfs_file_locks
)
do
strong_memoize
(
:validate_lfs_file_locks
)
do
project
.
lfs_enabled?
&&
project
.
any_lfs_file_locks?
project
.
lfs_enabled?
&&
project
.
any_lfs_file_locks?
end
end
end
end
def
uses_raw_delta
_validations?
def
should_run_diff
_validations?
validations_for_diff
.
present?
||
path_validations
.
present?
validations_for_diff
.
present?
||
path_validations
.
present?
end
end
...
@@ -59,16 +59,14 @@ module Gitlab
...
@@ -59,16 +59,14 @@ module Gitlab
validate_lfs_file_locks?
?
[
lfs_file_locks_validation
]
:
[]
validate_lfs_file_locks?
?
[
lfs_file_locks_validation
]
:
[]
end
end
def
process_
raw_delta
s
def
process_
commit
s
logger
.
log_timed
(
LOG_MESSAGES
[
:diff_content_check
])
do
logger
.
log_timed
(
LOG_MESSAGES
[
:diff_content_check
])
do
# n+1: https://gitlab.com/gitlab-org/gitlab-ee/issues/3593
# n+1: https://gitlab.com/gitlab-org/gitlab-ee/issues/3593
::
Gitlab
::
GitalyClient
.
allow_n_plus_1_calls
do
::
Gitlab
::
GitalyClient
.
allow_n_plus_1_calls
do
commits
.
each
do
|
commit
|
commits
.
each
do
|
commit
|
logger
.
check_timeout_reached
logger
.
check_timeout_reached
commit
.
raw_deltas
.
each
do
|
diff
|
yield
(
commit
)
yield
(
diff
)
end
end
end
end
end
end
end
...
...
lib/gitlab/checks/lfs_check.rb
View file @
e9b5b10a
...
@@ -7,6 +7,7 @@ module Gitlab
...
@@ -7,6 +7,7 @@ module Gitlab
ERROR_MESSAGE
=
'LFS objects are missing. Ensure LFS is properly set up or try a manual "git lfs push --all".'
.
freeze
ERROR_MESSAGE
=
'LFS objects are missing. Ensure LFS is properly set up or try a manual "git lfs push --all".'
.
freeze
def
validate!
def
validate!
return
unless
project
.
lfs_enabled?
return
if
skip_lfs_integrity_check
return
if
skip_lfs_integrity_check
logger
.
log_timed
(
LOG_MESSAGE
)
do
logger
.
log_timed
(
LOG_MESSAGE
)
do
...
...
spec/lib/gitlab/checks/diff_check_spec.rb
View file @
e9b5b10a
...
@@ -47,5 +47,43 @@ describe Gitlab::Checks::DiffCheck do
...
@@ -47,5 +47,43 @@ describe Gitlab::Checks::DiffCheck do
end
end
end
end
end
end
context
'commit diff validations'
do
before
do
allow
(
subject
).
to
receive
(
:validations_for_diff
).
and_return
([
lambda
{
|
diff
|
return
}])
expect_any_instance_of
(
Commit
).
to
receive
(
:raw_deltas
).
and_call_original
subject
.
validate!
end
context
'when request store is inactive'
do
it
'are run for every commit'
do
expect_any_instance_of
(
Commit
).
to
receive
(
:raw_deltas
).
and_call_original
subject
.
validate!
end
end
context
'when request store is active'
,
:request_store
do
it
'are cached for every commit'
do
expect_any_instance_of
(
Commit
).
not_to
receive
(
:raw_deltas
)
subject
.
validate!
end
it
'are run for not cached commits'
do
allow
(
project
.
repository
).
to
receive
(
:new_commits
).
and_return
(
project
.
repository
.
commits_between
(
'be93687618e4b132087f430a4d8fc3a609c9b77c'
,
'a5391128b0ef5d21df5dd23d98557f4ef12fae20'
)
)
change_access
.
instance_variable_set
(
:@commits
,
project
.
repository
.
new_commits
)
expect
(
project
.
repository
.
new_commits
.
first
).
not_to
receive
(
:raw_deltas
).
and_call_original
expect
(
project
.
repository
.
new_commits
.
last
).
to
receive
(
:raw_deltas
).
and_call_original
subject
.
validate!
end
end
end
end
end
end
end
spec/lib/gitlab/git_access_spec.rb
View file @
e9b5b10a
...
@@ -709,10 +709,22 @@ describe Gitlab::GitAccess do
...
@@ -709,10 +709,22 @@ describe Gitlab::GitAccess do
project
.
add_developer
(
user
)
project
.
add_developer
(
user
)
end
end
it
'checks LFS integrity only for first change'
do
context
'when LFS is not enabled'
do
expect_any_instance_of
(
Gitlab
::
Checks
::
LfsIntegrity
).
to
receive
(
:objects_missing?
).
exactly
(
1
).
times
it
'does not run LFSIntegrity check'
do
expect
(
Gitlab
::
Checks
::
LfsIntegrity
).
not_to
receive
(
:new
)
push_access_check
push_access_check
end
end
context
'when LFS is enabled'
do
it
'checks LFS integrity only for first change'
do
allow
(
project
).
to
receive
(
:lfs_enabled?
).
and_return
(
true
)
expect_any_instance_of
(
Gitlab
::
Checks
::
LfsIntegrity
).
to
receive
(
:objects_missing?
).
exactly
(
1
).
times
push_access_check
end
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