Commit fce7464c authored by Stan Hu's avatar Stan Hu

Fix delta size check to handle commit or nil objects

Closes #3446
parent 1a5db2eb
---
title: Fix delta size check to handle commit or nil objects
merge_request:
author:
type: fixed
...@@ -10,9 +10,14 @@ module EE ...@@ -10,9 +10,14 @@ module EE
diff = tree_a.diff(tree_b) diff = tree_a.diff(tree_b)
diff.each_delta do |d| diff.each_delta do |d|
new_file_size = d.deleted? ? 0 : ::Gitlab::Git::Blob.raw(repo, d.new_file[:oid]).size next if d.deleted?
size_of_deltas += new_file_size blob = ::Gitlab::Git::Blob.raw(repo, d.new_file[:oid])
# It's possible the OID points to a commit or empty object
next unless blob
size_of_deltas += blob.size
end end
size_of_deltas size_of_deltas
......
...@@ -32,6 +32,8 @@ module Gitlab ...@@ -32,6 +32,8 @@ module Gitlab
else else
blob = repository.lookup(sha) blob = repository.lookup(sha)
next unless blob.is_a?(Rugged::Blob)
new( new(
id: blob.oid, id: blob.oid,
size: blob.size, size: blob.size,
......
require 'spec_helper'
describe EE::Gitlab::Deltas do
let(:project) { create(:project, :repository) }
describe '.delta_size_check' do
it 'returns a non-zero file size' do
change = {
oldrev: TestEnv::BRANCH_SHA['feature'],
newrev: TestEnv::BRANCH_SHA['master']
}
expect(described_class.delta_size_check(change, project.repository)).to be > 0
end
end
end
...@@ -119,10 +119,13 @@ describe Gitlab::Git::Blob, seed_helper: true do ...@@ -119,10 +119,13 @@ describe Gitlab::Git::Blob, seed_helper: true do
shared_examples 'finding blobs by ID' do shared_examples 'finding blobs by ID' do
let(:raw_blob) { Gitlab::Git::Blob.raw(repository, SeedRepo::RubyBlob::ID) } let(:raw_blob) { Gitlab::Git::Blob.raw(repository, SeedRepo::RubyBlob::ID) }
let(:bad_blob) { Gitlab::Git::Blob.raw(repository, SeedRepo::BigCommit::ID) }
it { expect(raw_blob.id).to eq(SeedRepo::RubyBlob::ID) } it { expect(raw_blob.id).to eq(SeedRepo::RubyBlob::ID) }
it { expect(raw_blob.data[0..10]).to eq("require \'fi") } it { expect(raw_blob.data[0..10]).to eq("require \'fi") }
it { expect(raw_blob.size).to eq(669) } it { expect(raw_blob.size).to eq(669) }
it { expect(raw_blob.truncated?).to be_falsey } it { expect(raw_blob.truncated?).to be_falsey }
it { expect(bad_blob).to be_nil }
context 'large file' do context 'large file' do
it 'limits the size of a large file' do it 'limits the size of a large file' do
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment