diff options
author | Kim "BKC" Carlbäcker <kim.carlbacker@gmail.com> | 2018-01-22 15:40:38 +0100 |
---|---|---|
committer | Kim "BKC" Carlbäcker <kim.carlbacker@gmail.com> | 2018-01-22 15:40:38 +0100 |
commit | 728d7e0cf7b1570bc53f143a69612365e493d7a8 (patch) | |
tree | ad2e050df01fca8f843063b6c9491987b8dc1ac3 | |
parent | 58aa32bceab1483897f3e898151e60b0cf917f68 (diff) | |
download | gitlab-ce-728d7e0cf7b1570bc53f143a69612365e493d7a8.tar.gz |
Move error-handling to lib/gitlab/git
-rw-r--r-- | app/models/repository.rb | 12 | ||||
-rw-r--r-- | lib/gitlab/git/repository.rb | 6 |
2 files changed, 5 insertions, 13 deletions
diff --git a/app/models/repository.rb b/app/models/repository.rb index f717d248615..73c4899cb9b 100644 --- a/app/models/repository.rb +++ b/app/models/repository.rb @@ -259,17 +259,7 @@ class Repository return if kept_around?(sha) # This will still fail if the file is corrupted (e.g. 0 bytes) - begin - raw_repository.write_ref(keep_around_ref_name(sha), sha, shell: false) - rescue Gitlab::Git::CommandError => ex - if ex.message.start_with?("ReferenceError: ") - Rails.logger.error "Unable to create #{REF_KEEP_AROUND} reference for repository #{path}: #{ex}" - elsif ex.message.start_with?("OSError: ") - raise unless ex.message =~ /Failed to create locked file/ && ex.message =~ /File exists/ - - Rails.logger.error "Unable to create #{REF_KEEP_AROUND} reference for repository #{path}: #{ex}" - end - end + raw_repository.write_ref(keep_around_ref_name(sha), sha, shell: false) end def kept_around?(sha) diff --git a/lib/gitlab/git/repository.rb b/lib/gitlab/git/repository.rb index e36ab2e32f6..27037af55c6 100644 --- a/lib/gitlab/git/repository.rb +++ b/lib/gitlab/git/repository.rb @@ -1395,9 +1395,11 @@ module Gitlab def rugged_write_ref(ref_path, ref) rugged.references.create(ref_path, ref, force: true) rescue Rugged::ReferenceError => ex - raise CommandError, "ReferenceError: #{ex}" + Rails.logger.error "Unable to create #{ref_path} reference for repository #{path}: #{ex}" rescue Rugged::OSError => ex - raise CommandError, "OSError: #{ex}" + raise unless ex.message =~ /Failed to create locked file/ && ex.message =~ /File exists/ + + Rails.logger.error "Unable to create #{ref_path} reference for repository #{path}: #{ex}" end def fresh_worktree?(path) |