rosa-build/spec/jobs/dependent_packages_job_spec.rb

65 lines
2.4 KiB
Ruby
Raw Normal View History

2014-06-16 21:23:17 +01:00
require 'spec_helper'
2014-06-18 21:40:22 +01:00
describe BuildLists::DependentPackagesJob do
2014-06-16 21:23:17 +01:00
let(:build_list) { FactoryGirl.build(:build_list, id: 123) }
let(:user) { build_list.user }
let(:project) { build_list.project }
let(:project_ids) { [build_list.project_id] }
let(:arch_ids) { [build_list.arch_id] }
let(:options) { {
'auto_publish_status' => 'none',
'auto_create_container' => '0',
'include_testing_subrepository' => '0',
'use_cached_chroot' => '0',
'use_extra_tests' => '0'
} }
2014-06-16 21:23:17 +01:00
before do
stub_symlink_methods
allow(BuildList).to receive(:find).with(123).and_return(build_list)
2015-04-07 21:44:39 +01:00
allow(Project).to receive_message_chain(:where, :to_a).and_return([project])
allow(Arch).to receive_message_chain(:where, :to_a).and_return([build_list.arch])
2014-06-16 21:23:17 +01:00
2015-06-05 20:08:15 +01:00
allow_any_instance_of(BuildList).to receive(:update_statistic)
2015-04-07 21:44:39 +01:00
allow_any_instance_of(BuildListPolicy).to receive(:show?).and_return(true)
allow_any_instance_of(ProjectPolicy).to receive(:write?).and_return(true)
allow_any_instance_of(BuildListPolicy).to receive(:create?).and_return(true)
2014-06-16 21:23:17 +01:00
end
2014-06-18 21:40:22 +01:00
subject { BuildLists::DependentPackagesJob }
2014-06-16 21:23:17 +01:00
it 'ensures that not raises error' do
expect do
subject.perform build_list.id, user.id, project_ids, arch_ids, options
2014-06-16 21:23:17 +01:00
end.to_not raise_exception
end
it 'ensures that creates build_list' do
expect do
subject.perform build_list.id, user.id, project_ids, arch_ids, options
2014-06-16 21:23:17 +01:00
end.to change(BuildList, :count).by(1)
end
it 'ensures that do nothing if user has no access for show of build_list' do
2015-04-07 21:44:39 +01:00
allow_any_instance_of(BuildListPolicy).to receive(:show?).and_return(false)
2014-06-16 21:23:17 +01:00
expect do
subject.perform build_list.id, user.id, project_ids, arch_ids, options
2014-06-16 21:23:17 +01:00
end.to change(BuildList, :count).by(0)
end
it 'ensures that do nothing if user has no access for write of project' do
2015-04-07 21:44:39 +01:00
allow_any_instance_of(ProjectPolicy).to receive(:write?).and_return(false)
2014-06-16 21:23:17 +01:00
expect do
subject.perform build_list.id, user.id, project_ids, arch_ids, options
2014-06-16 21:23:17 +01:00
end.to change(BuildList, :count).by(0)
end
it 'ensures that do nothing if user has no access for create of build_list' do
2015-04-07 21:44:39 +01:00
allow_any_instance_of(BuildListPolicy).to receive(:create?).and_return(false)
2014-06-16 21:23:17 +01:00
expect do
subject.perform build_list.id, user.id, project_ids, arch_ids, options
2014-06-16 21:23:17 +01:00
end.to change(BuildList, :count).by(0)
end
end