You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
93 lines
2.9 KiB
93 lines
2.9 KiB
7 months ago
|
require "rails_helper"
|
||
|
|
||
|
RSpec.describe LocationPolicy do
|
||
|
subject(:policy) { described_class }
|
||
|
|
||
|
let(:data_provider) { FactoryBot.create(:user, :data_provider) }
|
||
|
let(:data_coordinator) { FactoryBot.create(:user, :data_coordinator) }
|
||
|
let(:support) { FactoryBot.create(:user, :support) }
|
||
|
|
||
|
permissions :delete? do
|
||
|
let(:location) { FactoryBot.create(:location) }
|
||
|
|
||
|
context "with active location" do
|
||
|
it "does not allow deleting a location as a provider" do
|
||
|
expect(policy).not_to permit(data_provider, location)
|
||
|
end
|
||
|
|
||
|
it "does not allow allows deleting a location as a coordinator" do
|
||
|
expect(policy).not_to permit(data_coordinator, location)
|
||
|
end
|
||
|
|
||
|
it "does not allow deleting a location as a support user" do
|
||
|
expect(policy).not_to permit(support, location)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "with incomplete location" do
|
||
|
before do
|
||
|
location.update!(units: nil)
|
||
|
end
|
||
|
|
||
|
it "does not allow deleting a location as a provider" do
|
||
|
expect(policy).not_to permit(data_provider, location)
|
||
|
end
|
||
|
|
||
|
it "does not allow allows deleting a location as a coordinator" do
|
||
|
expect(policy).not_to permit(data_coordinator, location)
|
||
|
end
|
||
|
|
||
|
it "allows deleting a location as a support user" do
|
||
|
expect(policy).to permit(support, location)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "with deactivated location" do
|
||
|
before do
|
||
|
location.location_deactivation_periods << create(:location_deactivation_period, deactivation_date: Time.zone.local(2024, 4, 10), location:)
|
||
|
location.save!
|
||
|
Timecop.freeze(Time.utc(2024, 4, 10))
|
||
|
log = create(:lettings_log, scheme: location.scheme, location:)
|
||
|
log.startdate = Time.zone.local(2022, 10, 10)
|
||
|
log.save!(validate: false)
|
||
|
end
|
||
|
|
||
|
after do
|
||
|
Timecop.unfreeze
|
||
|
end
|
||
|
|
||
|
context "and associated logs in editable collection period" do
|
||
|
before do
|
||
|
create(:lettings_log, scheme: location.scheme, location:)
|
||
|
end
|
||
|
|
||
|
it "does not allow deleting a location as a provider" do
|
||
|
expect(policy).not_to permit(data_provider, location)
|
||
|
end
|
||
|
|
||
|
it "does not allow allows deleting a location as a coordinator" do
|
||
|
expect(policy).not_to permit(data_coordinator, location)
|
||
|
end
|
||
|
|
||
|
it "does not allow deleting a location as a support user" do
|
||
|
expect(policy).not_to permit(support, location)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "and no associated logs in editable collection period" do
|
||
|
it "does not allow deleting a location as a provider" do
|
||
|
expect(policy).not_to permit(data_provider, location)
|
||
|
end
|
||
|
|
||
|
it "does not allow allows deleting a location as a coordinator" do
|
||
|
expect(policy).not_to permit(data_coordinator, location)
|
||
|
end
|
||
|
|
||
|
it "allows deleting a location as a support user" do
|
||
|
expect(policy).to permit(support, location)
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|