2020-07-28 23:09:34 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
RSpec.describe Packages::CreatePackageFileService do
|
2021-01-29 00:20:46 +05:30
|
|
|
let_it_be(:package) { create(:maven_package) }
|
|
|
|
let_it_be(:user) { create(:user) }
|
|
|
|
|
|
|
|
subject { described_class.new(package, params) }
|
2020-07-28 23:09:34 +05:30
|
|
|
|
|
|
|
describe '#execute' do
|
|
|
|
context 'with valid params' do
|
|
|
|
let(:params) do
|
|
|
|
{
|
|
|
|
file: Tempfile.new,
|
|
|
|
file_name: 'foo.jar'
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates a new package file' do
|
2021-01-29 00:20:46 +05:30
|
|
|
package_file = subject.execute
|
2020-07-28 23:09:34 +05:30
|
|
|
|
|
|
|
expect(package_file).to be_valid
|
|
|
|
expect(package_file.file_name).to eq('foo.jar')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'file is missing' do
|
|
|
|
let(:params) do
|
|
|
|
{
|
|
|
|
file_name: 'foo.jar'
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'raises an error' do
|
2021-01-29 00:20:46 +05:30
|
|
|
expect { subject.execute }.to raise_error(ActiveRecord::RecordInvalid)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with a build' do
|
|
|
|
let_it_be(:pipeline) { create(:ci_pipeline, user: user) }
|
|
|
|
let(:build) { double('build', pipeline: pipeline) }
|
|
|
|
let(:params) { { file: Tempfile.new, file_name: 'foo.jar', build: build } }
|
2020-07-28 23:09:34 +05:30
|
|
|
|
2021-01-29 00:20:46 +05:30
|
|
|
it 'creates a build_info' do
|
|
|
|
expect { subject.execute }.to change { Packages::PackageFileBuildInfo.count }.by(1)
|
2020-07-28 23:09:34 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|