summaryrefslogtreecommitdiff
path: root/spec/services/lfs
diff options
context:
space:
mode:
authorJames Edwards-Jones <jedwardsjones@gitlab.com>2018-01-11 23:12:34 +0000
committerJames Edwards-Jones <jedwardsjones@gitlab.com>2018-03-15 02:39:08 +0000
commit1baac9211238f60d2d2a50cccd0bea6979bfa6ba (patch)
tree7f07f3d1eb65f31f01c52973d115d349a95e3de2 /spec/services/lfs
parentffb1c65b0ba7fa8a4ea7e128cb47449f04837869 (diff)
downloadgitlab-ce-1baac9211238f60d2d2a50cccd0bea6979bfa6ba.tar.gz
Multi-file upload and Commit API obey LFS filters
Updates Files::MultiService for the commits API which is in turn used by the multi-file upload web UI Ensures that files which should be in LFS are transformed into LFS pointers Uses Lfs::Transformer which then links LfsObjectProjects on success
Diffstat (limited to 'spec/services/lfs')
-rw-r--r--spec/services/lfs/file_transformer_spec.rb100
1 files changed, 100 insertions, 0 deletions
diff --git a/spec/services/lfs/file_transformer_spec.rb b/spec/services/lfs/file_transformer_spec.rb
new file mode 100644
index 00000000000..f469f5e76dd
--- /dev/null
+++ b/spec/services/lfs/file_transformer_spec.rb
@@ -0,0 +1,100 @@
+require "spec_helper"
+
+describe Lfs::FileTransformer do
+ let(:project) { create(:project, :repository) }
+ let(:repository) { project.repository }
+ let(:file_content) { 'Test file content' }
+ let(:branch_name) { 'lfs' }
+ let(:file_path) { 'test_file.lfs' }
+
+ subject { described_class.new(project, branch_name) }
+
+ describe '#new_file' do
+ context 'with lfs disabled' do
+ it 'skips gitattributes check' do
+ expect(repository.raw).not_to receive(:blob_at)
+
+ subject.new_file(file_path, file_content)
+ end
+ end
+
+ context 'with lfs enabled' do
+ before do
+ allow(project).to receive(:lfs_enabled?).and_return(true)
+ end
+
+ it 'reuses cached gitattributes' do
+ second_file = 'another_file.lfs'
+
+ expect(repository.raw).to receive(:blob_at).with(branch_name, '.gitattributes').once
+
+ subject.new_file(file_path, file_content)
+ subject.new_file(second_file, file_content)
+ end
+
+ it "creates an LfsObject with the file's content" do
+ subject.new_file(file_path, file_content)
+
+ expect(LfsObject.last.file.read).to eq file_content
+ end
+
+ it 'creates an LFS pointer' do
+ new_content = subject.new_file(file_path, file_content)
+
+ expect(new_content).to start_with('version https://git-lfs.github.com/spec/v1')
+ end
+
+ context "when doesn't use LFS" do
+ let(:file_path) { 'other.filetype' }
+
+ it "doesn't create LFS pointers" do
+ new_content = subject.new_file(file_path, file_content)
+
+ expect(new_content).not_to start_with('version https://git-lfs.github.com/spec/v1')
+ expect(new_content).to eq(file_content)
+ end
+ end
+
+ it 'sets up after_transform! to link LfsObjects to project' do
+ subject.new_file(file_path, file_content)
+
+ expect { subject.after_transform! }.to change { project.lfs_objects.count }.by(1)
+ end
+ end
+ end
+
+ describe '.link_lfs_objects' do
+ context 'with lfs enabled' do
+ before do
+ allow(project).to receive(:lfs_enabled?).and_return(true)
+ end
+
+ context 'when given a block' do
+ it 'links LfsObject to the project automatically' do
+ expect do
+ described_class.link_lfs_objects(project, branch_name) do |t|
+ t.new_file(file_path, file_content)
+ end
+ end.to change { project.lfs_objects.count }.by(1)
+ end
+
+ it 'skips linking LfsObjects if the block returns falsey' do
+ expect do
+ described_class.link_lfs_objects(project, branch_name) do |t|
+ t.new_file(file_path, file_content)
+ false
+ end
+ end.not_to change { project.lfs_objects.count }
+ end
+
+ it 'returns the result of the block' do
+ result = described_class.link_lfs_objects(project, branch_name) do |t|
+ :dummy_commit
+ end
+
+ expect(result).to eq :dummy_commit
+ end
+ end
+ end
+ end
+end