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
Jérome Perrin
gitlab-ce
Commits
6d6f7536
Commit
6d6f7536
authored
Jan 23, 2018
by
Jacob Vosmaer
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Look for rugged with static analysis
parent
1f5af51b
Changes
13
Show whitespace changes
Inline
Side-by-side
Showing
13 changed files
with
75 additions
and
73 deletions
+75
-73
app/models/ci/pipeline.rb
app/models/ci/pipeline.rb
+1
-1
app/models/deployment.rb
app/models/deployment.rb
+1
-8
app/workers/repository_check/single_repository_worker.rb
app/workers/repository_check/single_repository_worker.rb
+1
-4
config/initializers/rugged_use_gitlab_git_attributes.rb
config/initializers/rugged_use_gitlab_git_attributes.rb
+0
-28
lib/gitlab/bare_repository_import/repository.rb
lib/gitlab/bare_repository_import/repository.rb
+2
-0
lib/gitlab/git/repository.rb
lib/gitlab/git/repository.rb
+2
-0
lib/gitlab/gitaly_client/commit_service.rb
lib/gitlab/gitaly_client/commit_service.rb
+14
-6
lib/gitlab/github_import/importer/pull_requests_importer.rb
lib/gitlab/github_import/importer/pull_requests_importer.rb
+1
-4
lib/tasks/gitlab/cleanup.rake
lib/tasks/gitlab/cleanup.rake
+2
-0
scripts/lint-rugged
scripts/lint-rugged
+36
-0
scripts/static-analysis
scripts/static-analysis
+2
-1
spec/lib/gitlab/github_import/importer/pull_requests_importer_spec.rb
...lab/github_import/importer/pull_requests_importer_spec.rb
+3
-3
spec/models/repository_spec.rb
spec/models/repository_spec.rb
+10
-18
No files found.
app/models/ci/pipeline.rb
View file @
6d6f7536
...
@@ -524,7 +524,7 @@ module Ci
...
@@ -524,7 +524,7 @@ module Ci
return
unless
sha
return
unless
sha
project
.
repository
.
gitlab_ci_yml_for
(
sha
,
ci_yaml_file_path
)
project
.
repository
.
gitlab_ci_yml_for
(
sha
,
ci_yaml_file_path
)
rescue
GRPC
::
NotFound
,
Rugged
::
ReferenceError
,
GRPC
::
Internal
rescue
GRPC
::
NotFound
,
GRPC
::
Internal
nil
nil
end
end
...
...
app/models/deployment.rb
View file @
6d6f7536
...
@@ -45,14 +45,7 @@ class Deployment < ActiveRecord::Base
...
@@ -45,14 +45,7 @@ class Deployment < ActiveRecord::Base
def
includes_commit?
(
commit
)
def
includes_commit?
(
commit
)
return
false
unless
commit
return
false
unless
commit
# Before 8.10, deployments didn't have keep-around refs. Any deployment
# created before then could have a `sha` referring to a commit that no
# longer exists in the repository, so just ignore those.
begin
project
.
repository
.
ancestor?
(
commit
.
id
,
sha
)
project
.
repository
.
ancestor?
(
commit
.
id
,
sha
)
rescue
Rugged
::
OdbError
false
end
end
end
def
update_merge_request_metrics!
def
update_merge_request_metrics!
...
...
app/workers/repository_check/single_repository_worker.rb
View file @
6d6f7536
...
@@ -20,10 +20,7 @@ module RepositoryCheck
...
@@ -20,10 +20,7 @@ module RepositoryCheck
# Historically some projects never had their wiki repos initialized;
# Historically some projects never had their wiki repos initialized;
# this happens on project creation now. Let's initialize an empty repo
# this happens on project creation now. Let's initialize an empty repo
# if it is not already there.
# if it is not already there.
begin
project
.
create_wiki
project
.
create_wiki
rescue
Rugged
::
RepositoryError
end
git_fsck
(
project
.
wiki
.
repository
)
git_fsck
(
project
.
wiki
.
repository
)
else
else
...
...
config/initializers/rugged_use_gitlab_git_attributes.rb
deleted
100644 → 0
View file @
1f5af51b
# We don't want to ever call Rugged::Repository#fetch_attributes, because it has
# a lot of I/O overhead:
# <https://gitlab.com/gitlab-org/gitlab_git/commit/340e111e040ae847b614d35b4d3173ec48329015>
#
# While we don't do this from within the GitLab source itself, the Linguist gem
# has a dependency on Rugged and uses the gitattributes file when calculating
# repository-wide language statistics:
# <https://github.com/github/linguist/blob/v4.7.0/lib/linguist/lazy_blob.rb#L33-L36>
#
# The options passed by Linguist are those assumed by Gitlab::Git::InfoAttributes
# anyway, and there is no great efficiency gain from just fetching the listed
# attributes with our implementation, so we ignore the additional arguments.
#
module
Rugged
class
Repository
module
UseGitlabGitAttributes
def
fetch_attributes
(
name
,
*
)
attributes
.
attributes
(
name
)
end
def
attributes
@attributes
||=
Gitlab
::
Git
::
InfoAttributes
.
new
(
path
)
end
end
prepend
UseGitlabGitAttributes
end
end
lib/gitlab/bare_repository_import/repository.rb
View file @
6d6f7536
# Gitaly migration: https://gitlab.com/gitlab-org/gitaly/issues/953
#
module
Gitlab
module
Gitlab
module
BareRepositoryImport
module
BareRepositoryImport
class
Repository
class
Repository
...
...
lib/gitlab/git/repository.rb
View file @
6d6f7536
...
@@ -563,6 +563,8 @@ module Gitlab
...
@@ -563,6 +563,8 @@ module Gitlab
return
false
if
ancestor_id
.
nil?
||
descendant_id
.
nil?
return
false
if
ancestor_id
.
nil?
||
descendant_id
.
nil?
merge_base_commit
(
ancestor_id
,
descendant_id
)
==
ancestor_id
merge_base_commit
(
ancestor_id
,
descendant_id
)
==
ancestor_id
rescue
Rugged
::
OdbError
false
end
end
# Returns true is +from+ is direct ancestor to +to+, otherwise false
# Returns true is +from+ is direct ancestor to +to+, otherwise false
...
...
lib/gitlab/gitaly_client/commit_service.rb
View file @
6d6f7536
...
@@ -38,20 +38,28 @@ module Gitlab
...
@@ -38,20 +38,28 @@ module Gitlab
from_id
=
case
from
from_id
=
case
from
when
NilClass
when
NilClass
EMPTY_TREE_ID
EMPTY_TREE_ID
when
Rugged
::
Commit
else
if
from
.
respond_to?
(
:oid
)
# This is meant to match a Rugged::Commit. This should be impossible in
# the future.
from
.
oid
from
.
oid
else
else
from
from
end
end
end
to_id
=
case
to
to_id
=
case
to
when
NilClass
when
NilClass
EMPTY_TREE_ID
EMPTY_TREE_ID
when
Rugged
::
Commit
else
if
to
.
respond_to?
(
:oid
)
# This is meant to match a Rugged::Commit. This should be impossible in
# the future.
to
.
oid
to
.
oid
else
else
to
to
end
end
end
request_params
=
diff_between_commits_request_params
(
from_id
,
to_id
,
options
)
request_params
=
diff_between_commits_request_params
(
from_id
,
to_id
,
options
)
...
...
lib/gitlab/github_import/importer/pull_requests_importer.rb
View file @
6d6f7536
...
@@ -57,10 +57,7 @@ module Gitlab
...
@@ -57,10 +57,7 @@ module Gitlab
end
end
def
commit_exists?
(
sha
)
def
commit_exists?
(
sha
)
project
.
repository
.
lookup
(
sha
)
project
.
repository
.
commit
(
sha
).
present?
true
rescue
Rugged
::
Error
false
end
end
def
collection_method
def
collection_method
...
...
lib/tasks/gitlab/cleanup.rake
View file @
6d6f7536
# Gitaly migration: https://gitlab.com/gitlab-org/gitaly/issues/954
#
namespace
:gitlab
do
namespace
:gitlab
do
namespace
:cleanup
do
namespace
:cleanup
do
HASHED_REPOSITORY_NAME
=
'@hashed'
.
freeze
HASHED_REPOSITORY_NAME
=
'@hashed'
.
freeze
...
...
scripts/lint-rugged
0 → 100755
View file @
6d6f7536
#!/usr/bin/env ruby
ALLOWED
=
[
# Can be deleted (?) once rugged is no longer used in production. Doesn't make Rugged calls.
'config/initializers/8_metrics.rb'
,
# Can be deleted once wiki's are fully (mandatory) migrated
'config/initializers/gollum.rb'
,
# Needs to be migrated, https://gitlab.com/gitlab-org/gitaly/issues/953
'lib/gitlab/bare_repository_import/repository.rb'
,
# Needs to be migrated, https://gitlab.com/gitlab-org/gitaly/issues/954
'lib/tasks/gitlab/cleanup.rake'
,
# https://gitlab.com/gitlab-org/gitaly/issues/961
'app/models/repository.rb'
,
# The only place where Rugged code is still allowed in production
'lib/gitlab/git/'
].
freeze
rugged_lines
=
IO
.
popen
(
%w[git grep -i -n rugged -- app config lib]
,
&
:read
).
lines
rugged_lines
=
rugged_lines
.
reject
{
|
l
|
l
.
start_with?
(
*
ALLOWED
)
}
rugged_lines
=
rugged_lines
.
reject
do
|
line
|
code
,
_comment
=
line
.
split
(
'# '
,
2
)
code
!~
/rugged/i
end
exit
if
rugged_lines
.
empty?
puts
"Using Rugged is only allowed in test and
#{
ALLOWED
}
\n\n
"
puts
rugged_lines
exit
(
false
)
scripts/static-analysis
View file @
6d6f7536
...
@@ -13,7 +13,8 @@ tasks = [
...
@@ -13,7 +13,8 @@ tasks = [
%w[bundle exec rake gettext:lint]
,
%w[bundle exec rake gettext:lint]
,
%w[bundle exec rake lint:static_verification]
,
%w[bundle exec rake lint:static_verification]
,
%w[scripts/lint-changelog-yaml]
,
%w[scripts/lint-changelog-yaml]
,
%w[scripts/lint-conflicts.sh]
%w[scripts/lint-conflicts.sh]
,
%w[scripts/lint-rugged]
]
]
failed_tasks
=
tasks
.
reduce
({})
do
|
failures
,
task
|
failed_tasks
=
tasks
.
reduce
({})
do
|
failures
,
task
|
...
...
spec/lib/gitlab/github_import/importer/pull_requests_importer_spec.rb
View file @
6d6f7536
...
@@ -244,7 +244,7 @@ describe Gitlab::GithubImport::Importer::PullRequestsImporter do
...
@@ -244,7 +244,7 @@ describe Gitlab::GithubImport::Importer::PullRequestsImporter do
it
'returns true when a commit exists'
do
it
'returns true when a commit exists'
do
expect
(
project
.
repository
)
expect
(
project
.
repository
)
.
to
receive
(
:
lookup
)
.
to
receive
(
:
commit
)
.
with
(
'123'
)
.
with
(
'123'
)
.
and_return
(
double
(
:commit
))
.
and_return
(
double
(
:commit
))
...
@@ -253,9 +253,9 @@ describe Gitlab::GithubImport::Importer::PullRequestsImporter do
...
@@ -253,9 +253,9 @@ describe Gitlab::GithubImport::Importer::PullRequestsImporter do
it
'returns false when a commit does not exist'
do
it
'returns false when a commit does not exist'
do
expect
(
project
.
repository
)
expect
(
project
.
repository
)
.
to
receive
(
:
lookup
)
.
to
receive
(
:
commit
)
.
with
(
'123'
)
.
with
(
'123'
)
.
and_r
aise
(
Rugged
::
OdbError
)
.
and_r
eturn
(
nil
)
expect
(
importer
.
commit_exists?
(
'123'
)).
to
eq
(
false
)
expect
(
importer
.
commit_exists?
(
'123'
)).
to
eq
(
false
)
end
end
...
...
spec/models/repository_spec.rb
View file @
6d6f7536
...
@@ -2356,7 +2356,7 @@ describe Repository do
...
@@ -2356,7 +2356,7 @@ describe Repository do
let
(
:commit
)
{
repository
.
commit
}
let
(
:commit
)
{
repository
.
commit
}
let
(
:ancestor
)
{
commit
.
parents
.
first
}
let
(
:ancestor
)
{
commit
.
parents
.
first
}
context
'with Gitaly enabled
'
do
shared_examples
'#ancestor?
'
do
it
'it is an ancestor'
do
it
'it is an ancestor'
do
expect
(
repository
.
ancestor?
(
ancestor
.
id
,
commit
.
id
)).
to
eq
(
true
)
expect
(
repository
.
ancestor?
(
ancestor
.
id
,
commit
.
id
)).
to
eq
(
true
)
end
end
...
@@ -2370,27 +2370,19 @@ describe Repository do
...
@@ -2370,27 +2370,19 @@ describe Repository do
expect
(
repository
.
ancestor?
(
ancestor
.
id
,
nil
)).
to
eq
(
false
)
expect
(
repository
.
ancestor?
(
ancestor
.
id
,
nil
)).
to
eq
(
false
)
expect
(
repository
.
ancestor?
(
nil
,
nil
)).
to
eq
(
false
)
expect
(
repository
.
ancestor?
(
nil
,
nil
)).
to
eq
(
false
)
end
end
end
context
'with Gitaly disabled'
do
it
'returns false for invalid commit IDs'
do
before
do
expect
(
repository
.
ancestor?
(
commit
.
id
,
Gitlab
::
Git
::
BLANK_SHA
)).
to
eq
(
false
)
allow
(
Gitlab
::
GitalyClient
).
to
receive
(
:enabled?
).
and_return
(
false
)
expect
(
repository
.
ancestor?
(
Gitlab
::
Git
::
BLANK_SHA
,
commit
.
id
)).
to
eq
(
false
)
allow
(
Gitlab
::
GitalyClient
).
to
receive
(
:feature_enabled?
).
with
(
:is_ancestor
).
and_return
(
false
)
end
end
it
'it is an ancestor'
do
expect
(
repository
.
ancestor?
(
ancestor
.
id
,
commit
.
id
)).
to
eq
(
true
)
end
end
it
'it is not an ancestor
'
do
context
'with Gitaly enabled
'
do
expect
(
repository
.
ancestor?
(
commit
.
id
,
ancestor
.
id
)).
to
eq
(
false
)
it_behaves_like
(
'#ancestor?'
)
end
end
it
'returns false on nil-values'
do
context
'with Gitaly disabled'
,
:skip_gitaly_mock
do
expect
(
repository
.
ancestor?
(
nil
,
commit
.
id
)).
to
eq
(
false
)
it_behaves_like
(
'#ancestor?'
)
expect
(
repository
.
ancestor?
(
ancestor
.
id
,
nil
)).
to
eq
(
false
)
expect
(
repository
.
ancestor?
(
nil
,
nil
)).
to
eq
(
false
)
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