Browse Source

CLDC 1863: Prevent non-stock organisations appearing in search for who owns property questions. (#1748)

* CLDC-1863: orgs must own stock to show as option WIP

* CLDC-1863: Test updated

* CLDC-1863: removed test of no longer relevant behaviour
pull/1757/head
Aaron Spencer 2 years ago committed by GitHub
parent
commit
9349b6718d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 2
      app/models/form/lettings/questions/stock_owner.rb
  2. 24
      spec/features/lettings_log_spec.rb
  3. 6
      spec/models/form/lettings/questions/stock_owner_spec.rb

2
app/models/form/lettings/questions/stock_owner.rb

@ -24,7 +24,7 @@ class Form::Lettings::Questions::StockOwner < ::Form::Question
end end
stock_owners_answer_options = if user.support? stock_owners_answer_options = if user.support?
Organisation Organisation.where(holds_own_stock: true)
else else
user.organisation.stock_owners user.organisation.stock_owners
end.pluck(:id, :name).to_h end.pluck(:id, :name).to_h

24
spec/features/lettings_log_spec.rb

@ -132,30 +132,6 @@ RSpec.describe "Lettings Log Features" do
end end
context "when the owning organisation question is answered" do context "when the owning organisation question is answered" do
context "and the owning organisation doesn't hold stock" do
let(:managing_org) { create(:organisation, name: "Managing org") }
let!(:org_rel) { create(:organisation_relationship, parent_organisation: support_user.organisation, child_organisation: managing_org) }
before do
support_user.organisation.update!(holds_own_stock: false)
end
it "shows the managing organisation question" do
visit("/lettings-logs")
click_button("Create a new lettings log")
click_link("Set up this lettings log")
log_id = page.current_path.scan(/\d/).join
select(support_user.organisation.name, from: "lettings-log-owning-organisation-id-field")
click_button("Save and continue")
expect(page).to have_current_path("/lettings-logs/#{log_id}/managing-organisation")
select(managing_org.name, from: "lettings-log-managing-organisation-id-field")
click_button("Save and continue")
visit("lettings-logs/#{log_id}/setup/check-answers")
expect(page).to have_content("Managing agent Managing org", normalize_ws: true)
expect(support_user.organisation.managing_agents).to eq([org_rel.child_organisation])
end
end
context "and the owning organisation does hold stock" do context "and the owning organisation does hold stock" do
before do before do
support_user.organisation.update!(holds_own_stock: true) support_user.organisation.update!(holds_own_stock: true)

6
spec/models/form/lettings/questions/stock_owner_spec.rb

@ -107,15 +107,17 @@ RSpec.describe Form::Lettings::Questions::StockOwner, type: :model do
let(:log) { create(:lettings_log) } let(:log) { create(:lettings_log) }
let(:non_stock_organisation) { create(:organisation, holds_own_stock: false) }
let(:expected_opts) do let(:expected_opts) do
Organisation.all.each_with_object(options) do |organisation, hsh| Organisation.where(holds_own_stock: true).each_with_object(options) do |organisation, hsh|
hsh[organisation.id] = organisation.name hsh[organisation.id] = organisation.name
hsh hsh
end end
end end
it "shows all orgs" do it "shows orgs where organisation holds own stock" do
expect(question.displayed_answer_options(log, user)).to eq(expected_opts) expect(question.displayed_answer_options(log, user)).to eq(expected_opts)
expect(question.displayed_answer_options(log, user)).not_to include(non_stock_organisation.id)
end end
end end
end end

Loading…
Cancel
Save