2016-04-13 13:56:05 +00:00
|
|
|
module RepositoryCheck
|
|
|
|
class SingleRepositoryWorker
|
|
|
|
include Sidekiq::Worker
|
2016-10-21 16:13:41 +00:00
|
|
|
include RepositoryCheckQueue
|
2016-04-26 14:56:14 +00:00
|
|
|
|
2016-04-13 13:56:05 +00:00
|
|
|
def perform(project_id)
|
|
|
|
project = Project.find(project_id)
|
|
|
|
project.update_columns(
|
|
|
|
last_repository_check_failed: !check(project),
|
2017-05-03 11:27:17 +00:00
|
|
|
last_repository_check_at: Time.now
|
2016-04-13 13:56:05 +00:00
|
|
|
)
|
|
|
|
end
|
2016-04-26 14:56:14 +00:00
|
|
|
|
2016-04-13 13:56:05 +00:00
|
|
|
private
|
2016-04-26 14:56:14 +00:00
|
|
|
|
2016-04-13 13:56:05 +00:00
|
|
|
def check(project)
|
2016-06-15 17:11:25 +00:00
|
|
|
if has_pushes?(project) && !git_fsck(project.repository)
|
2016-04-26 14:56:14 +00:00
|
|
|
false
|
|
|
|
elsif project.wiki_enabled?
|
|
|
|
# Historically some projects never had their wiki repos initialized;
|
|
|
|
# this happens on project creation now. Let's initialize an empty repo
|
|
|
|
# if it is not already there.
|
|
|
|
begin
|
|
|
|
project.create_wiki
|
|
|
|
rescue Rugged::RepositoryError
|
|
|
|
end
|
|
|
|
|
|
|
|
git_fsck(project.wiki.repository)
|
|
|
|
else
|
|
|
|
true
|
|
|
|
end
|
2016-04-13 13:56:05 +00:00
|
|
|
end
|
2016-04-26 14:56:14 +00:00
|
|
|
|
|
|
|
def git_fsck(repository)
|
|
|
|
path = repository.path_to_repo
|
2016-04-13 13:56:05 +00:00
|
|
|
cmd = %W(nice git --git-dir=#{path} fsck)
|
|
|
|
output, status = Gitlab::Popen.popen(cmd)
|
2016-04-26 14:56:14 +00:00
|
|
|
|
2016-04-13 13:56:05 +00:00
|
|
|
if status.zero?
|
|
|
|
true
|
|
|
|
else
|
|
|
|
Gitlab::RepositoryCheckLogger.error("command failed: #{cmd.join(' ')}\n#{output}")
|
|
|
|
false
|
|
|
|
end
|
|
|
|
end
|
2016-06-15 17:11:25 +00:00
|
|
|
|
|
|
|
def has_pushes?(project)
|
|
|
|
Project.with_push.exists?(project.id)
|
|
|
|
end
|
2016-04-13 13:56:05 +00:00
|
|
|
end
|
|
|
|
end
|