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.
407 lines
15 KiB
407 lines
15 KiB
require "rails_helper" |
|
|
|
RSpec.describe StartController, type: :request do |
|
let(:user) { create(:user) } |
|
let(:page) { Capybara::Node::Simple.new(response.body) } |
|
let(:notify_client) { instance_double(Notifications::Client) } |
|
let(:devise_notify_mailer) { DeviseNotifyMailer.new } |
|
|
|
before do |
|
allow(DeviseNotifyMailer).to receive(:new).and_return(devise_notify_mailer) |
|
allow(devise_notify_mailer).to receive(:notify_client).and_return(notify_client) |
|
allow(notify_client).to receive(:send_email).and_return(true) |
|
end |
|
|
|
describe "GET" do |
|
context "when the user is not signed in" do |
|
it "routes user to the start page" do |
|
get root_path |
|
expect(path).to eq("/") |
|
expect(page).to have_content("Start now") |
|
end |
|
end |
|
|
|
context "when the user is signed in" do |
|
before do |
|
allow(user).to receive(:need_two_factor_authentication?).and_return(false) |
|
sign_in user |
|
end |
|
|
|
it "routes user to the home page" do |
|
get root_path |
|
expect(page).to have_content("Welcome back") |
|
end |
|
|
|
describe "the data displayed at the top of the home page" do |
|
let(:current_year) { FormHandler.instance.current_collection_start_year } |
|
let(:in_crossover_period) { false } |
|
|
|
before do |
|
allow(FormHandler.instance).to receive(:in_crossover_period?).and_return in_crossover_period |
|
end |
|
|
|
context "when in the crossover period" do |
|
let(:in_crossover_period) { true } |
|
|
|
it "shows both open collection years with last year first" do |
|
get root_path |
|
|
|
logs_headers = page.find_all("h2").map(&:text).select { |header| header.include? "Logs" } |
|
|
|
expected_headers = [ |
|
"#{current_year - 1} to #{current_year} Logs", |
|
"#{current_year} to #{current_year + 1} Logs", |
|
] |
|
|
|
expect(logs_headers).to eq expected_headers |
|
end |
|
end |
|
|
|
context "when not in the crossover period" do |
|
let(:in_crossover_period) { false } |
|
|
|
it "shows this year first, with last year's after marked as closed" do |
|
get root_path |
|
|
|
logs_headers = page.find_all("h2").map(&:text).select { |header| header.include? "Logs" } |
|
|
|
expected_headers = [ |
|
"#{current_year} to #{current_year + 1} Logs", |
|
"#{current_year - 1} to #{current_year} Logs (Closed collection year)", |
|
] |
|
|
|
expect(logs_headers).to eq expected_headers |
|
end |
|
end |
|
|
|
context "when the user's org has never submitted sales" do |
|
it "does not display data related to sales" do |
|
get root_path |
|
|
|
databox_texts = page.find_all(".app-data-box__upper").map(&:text) |
|
any_sales_boxes = databox_texts.map(&:downcase).any? { |text| text.include? "sales" } |
|
|
|
expect(any_sales_boxes).to be false |
|
end |
|
end |
|
|
|
context "when the user's org has submitted sales logs" do |
|
before do |
|
create(:sales_log, assigned_to: user) |
|
end |
|
|
|
it "displays data related to sales" do |
|
get root_path |
|
|
|
databox_texts = page.find_all(".app-data-box__upper").map(&:text) |
|
any_sales_boxes = databox_texts.map(&:downcase).any? { |text| text.include? "sales" } |
|
|
|
expect(any_sales_boxes).to be true |
|
end |
|
end |
|
|
|
context "when the user is a data provider" do |
|
let(:user) { create(:user, :data_provider) } |
|
|
|
it "does not display data related to schemes" do |
|
get root_path |
|
|
|
databox_texts = page.find_all(".app-data-box__upper").map(&:text) |
|
any_schemes_boxes = databox_texts.map(&:downcase).any? { |text| text.include? "schemes" } |
|
|
|
expect(any_schemes_boxes).to be false |
|
end |
|
end |
|
|
|
context "when the user is a data coordinator" do |
|
let(:user) { create(:user, :data_coordinator) } |
|
|
|
it "does display data related to schemes" do |
|
get root_path |
|
|
|
databox_texts = page.find_all(".app-data-box__upper").map(&:text) |
|
any_schemes_boxes = databox_texts.map(&:downcase).any? { |text| text.include? "schemes" } |
|
|
|
expect(any_schemes_boxes).to be true |
|
end |
|
end |
|
|
|
context "when the user is a support user" do |
|
let(:user) { create(:user, :support) } |
|
|
|
it "does display data related to schemes" do |
|
get root_path |
|
|
|
databox_texts = page.find_all(".app-data-box__upper").map(&:text) |
|
any_schemes_boxes = databox_texts.map(&:downcase).any? { |text| text.include? "schemes" } |
|
|
|
expect(any_schemes_boxes).to be true |
|
end |
|
end |
|
|
|
describe "the links in the data boxes" do |
|
let(:user) { create(:user, :data_coordinator) } |
|
let(:in_crossover_period) { true } |
|
|
|
before do |
|
create(:sales_log, assigned_to: user) |
|
get root_path |
|
end |
|
|
|
[ |
|
{ type: "lettings", status: "in_progress" }, |
|
{ type: "lettings", status: "completed" }, |
|
{ type: "sales", status: "in_progress" }, |
|
{ type: "sales", status: "completed" }, |
|
].each do |test_case| |
|
it "shows the correct links for #{test_case[:status]} #{test_case[:type]}" do |
|
databoxes = all_databoxes(test_case[:type], test_case[:status]) |
|
|
|
expect(databoxes.count).to be 2 |
|
|
|
links = databoxes.map { |databox| link_from_databox databox } |
|
|
|
expect(links.map(&:path)).to all eq send("#{test_case[:type]}_logs_path") |
|
|
|
params = links.map { |link| CGI.parse(link.query) } |
|
|
|
expect(params.map { |prms| prms["status[]"] }).to all eq [test_case[:status]] |
|
expect(params.first["years[]"]).to eq [(current_year - 1).to_s] |
|
expect(params.second["years[]"]).to eq [current_year.to_s] |
|
end |
|
end |
|
|
|
it "shows the correct links for incomplete schemes" do |
|
type = "schemes" |
|
status = "incomplete" |
|
databoxes = all_databoxes(type, status) |
|
|
|
expect(databoxes.count).to be 1 |
|
|
|
link = databoxes.map { |databox| link_from_databox databox }.first |
|
|
|
expect(link.path).to eq schemes_path |
|
|
|
params = CGI.parse(link.query) |
|
|
|
expect(params["status[]"]).to eq [status] |
|
end |
|
end |
|
|
|
describe "the counts displayed" do |
|
let(:in_crossover_period) { true } |
|
let(:org_1) { create(:organisation) } |
|
let(:org_2) { create(:organisation) } |
|
let(:provider_1) { create(:user, :data_provider, organisation: org_1) } |
|
let(:provider_2) { create(:user, :data_provider, organisation: org_2) } |
|
let(:coordinator) { create(:user, :data_coordinator, organisation: org_1) } |
|
let(:support_user) { create(:user, :support) } |
|
|
|
context "and logged in as a provider" do |
|
let(:user) { provider_1 } |
|
|
|
it "shows the correct counts of logs created by them" do |
|
last_year_in_progress_count = 2 |
|
this_year_in_progress_count = 3 |
|
create_list(:lettings_log, last_year_in_progress_count, :in_progress, :ignore_validation_errors, assigned_to: provider_1, startdate: Time.zone.today - 1.year) |
|
create_list(:lettings_log, this_year_in_progress_count, :in_progress, assigned_to: provider_1, startdate: Time.zone.today) |
|
|
|
get root_path |
|
|
|
type = "lettings" |
|
status = "in_progress" |
|
databoxes = all_databoxes(type, status) |
|
counts = databoxes.map { |databox| count_from_databox databox } |
|
|
|
expect(counts).to eq [last_year_in_progress_count, this_year_in_progress_count] |
|
end |
|
|
|
it "does not include logs created by other users in the count, whether in their organisation or not" do |
|
create(:lettings_log, :in_progress, :ignore_validation_errors, assigned_to: coordinator, startdate: Time.zone.today - 1.year) |
|
create(:lettings_log, :in_progress, assigned_to: provider_2, startdate: Time.zone.today) |
|
|
|
get root_path |
|
|
|
type = "lettings" |
|
status = "in_progress" |
|
databoxes = all_databoxes(type, status) |
|
counts = databoxes.map { |databox| count_from_databox databox } |
|
|
|
expect(counts).to eq [0, 0] |
|
end |
|
end |
|
|
|
context "and logged in as a coordinator" do |
|
let(:user) { coordinator } |
|
|
|
it "shows the correct counts of logs created by all users in their organisation" do |
|
last_year_in_progress_count = 2 |
|
this_year_in_progress_count = 3 |
|
create_list(:lettings_log, last_year_in_progress_count, :in_progress, :ignore_validation_errors, assigned_to: provider_1, startdate: Time.zone.today - 1.year) |
|
create_list(:lettings_log, this_year_in_progress_count, :in_progress, assigned_to: coordinator, startdate: Time.zone.today) |
|
|
|
get root_path |
|
|
|
type = "lettings" |
|
status = "in_progress" |
|
databoxes = all_databoxes(type, status) |
|
counts = databoxes.map { |databox| count_from_databox databox } |
|
|
|
expect(counts).to eq [last_year_in_progress_count, this_year_in_progress_count] |
|
end |
|
|
|
it "does not include logs created by users from other organisations in the count" do |
|
create(:lettings_log, :in_progress, assigned_to: provider_2, startdate: Time.zone.today) |
|
|
|
get root_path |
|
|
|
type = "lettings" |
|
status = "in_progress" |
|
databoxes = all_databoxes(type, status) |
|
|
|
counts = databoxes.map { |databox| count_from_databox databox } |
|
expect(counts).to eq [0, 0] |
|
end |
|
|
|
it "shows the correct count for schemes" do |
|
completed_schemes_count = 3 |
|
incomplete_schemes_count = 2 |
|
create_list(:scheme, completed_schemes_count, :incomplete, owning_organisation: coordinator.organisation) |
|
create_list(:scheme, incomplete_schemes_count, :incomplete, owning_organisation: coordinator.organisation, discarded_at: Time.zone.yesterday) |
|
|
|
get root_path |
|
|
|
type = "schemes" |
|
status = "incomplete" |
|
databoxes = all_databoxes(type, status) |
|
count = count_from_databox(databoxes.first) |
|
|
|
expect(count).to eq(completed_schemes_count) |
|
end |
|
end |
|
|
|
context "and logged in as a support user" do |
|
let(:user) { support_user } |
|
|
|
it "shows the correct counts of all logs from all orgs" do |
|
provider_1_lettings_last_year_in_progress_count = 2 |
|
coordinator_lettings_this_year_in_progress_count = 3 |
|
provider_2_lettings_last_year_in_progress_count = 2 |
|
provider_2_sales_this_year_in_progress_count = 3 |
|
create_list(:lettings_log, provider_1_lettings_last_year_in_progress_count, :in_progress, :ignore_validation_errors, assigned_to: provider_1, startdate: Time.zone.today - 1.year) |
|
create_list(:lettings_log, coordinator_lettings_this_year_in_progress_count, :in_progress, assigned_to: coordinator, startdate: Time.zone.today) |
|
create_list(:lettings_log, provider_2_lettings_last_year_in_progress_count, :in_progress, :ignore_validation_errors, assigned_to: provider_2, startdate: Time.zone.today - 1.year) |
|
create_list(:sales_log, provider_2_sales_this_year_in_progress_count, :in_progress, assigned_to: provider_2, saledate: Time.zone.today) |
|
|
|
get root_path |
|
|
|
type = "lettings" |
|
status = "in_progress" |
|
lettings_databoxes = all_databoxes(type, status) |
|
lettings_counts = lettings_databoxes.map { |databox| count_from_databox databox } |
|
|
|
expect(lettings_counts).to eq [ |
|
provider_1_lettings_last_year_in_progress_count + provider_2_lettings_last_year_in_progress_count, |
|
coordinator_lettings_this_year_in_progress_count, |
|
] |
|
|
|
type = "sales" |
|
status = "in_progress" |
|
sales_databoxes = all_databoxes(type, status) |
|
sales_counts = sales_databoxes.map { |databox| count_from_databox databox } |
|
|
|
expect(sales_counts).to eq [ |
|
0, |
|
provider_2_sales_this_year_in_progress_count, |
|
] |
|
end |
|
end |
|
end |
|
end |
|
|
|
context "and 2023 collection window is open for editing" do |
|
before do |
|
allow(Time).to receive(:now).and_return(Time.zone.local(2024, 1, 1)) |
|
end |
|
|
|
it "displays correct resources for 2023/24 and 2024/25 collection years" do |
|
get root_path |
|
expect(page).to have_content("Lettings 24/25") |
|
expect(page).to have_content("Lettings 23/24") |
|
expect(page).to have_content("Lettings 2024 to 2025") |
|
expect(page).to have_content("Lettings 2023 to 2024") |
|
expect(page).to have_content("Sales 24/25") |
|
expect(page).to have_content("Sales 23/24") |
|
expect(page).to have_content("Sales 2024 to 2025") |
|
expect(page).to have_content("Sales 2023 to 2024") |
|
end |
|
end |
|
|
|
context "and 2023 collection window is closed for editing" do |
|
before do |
|
allow(Time).to receive(:now).and_return(Time.zone.local(2025, 1, 1)) |
|
end |
|
|
|
it "displays correct resources for 2023/24 and 2024/25 collection years" do |
|
get root_path |
|
expect(page).to have_content("Lettings 24/25") |
|
expect(page).not_to have_content("Lettings 23/24") |
|
expect(page).to have_content("Lettings 2024 to 2025") |
|
expect(page).not_to have_content("Lettings 2023 to 2024") |
|
expect(page).to have_content("Sales 24/25") |
|
expect(page).not_to have_content("Sales 23/24") |
|
expect(page).to have_content("Sales 2024 to 2025") |
|
expect(page).not_to have_content("Sales 2023 to 2024") |
|
end |
|
end |
|
|
|
it "shows guidance link" do |
|
get root_path |
|
expect(page).to have_content("Guidance for submitting social housing lettings and sales data (CORE)") |
|
end |
|
|
|
it "displays About this service section" do |
|
get root_path |
|
expect(page).to have_content("About this service") |
|
end |
|
end |
|
end |
|
|
|
describe "guidance page" do |
|
context "when the user is not signed in" do |
|
it "routes user to the guidance page" do |
|
get guidance_path |
|
expect(page).to have_content("Guidance for submitting social housing lettings and sales data") |
|
end |
|
end |
|
|
|
context "when the user is signed in" do |
|
before do |
|
sign_in user |
|
end |
|
|
|
it "routes user to the guidance page" do |
|
get guidance_path |
|
expect(page).to have_content("Guidance for submitting social housing lettings and sales data") |
|
end |
|
end |
|
end |
|
|
|
private |
|
|
|
def all_databoxes(type, status) |
|
databoxes = page.find_all(".app-data-box__upper") |
|
databoxes.select do |box| |
|
box.text.downcase.include?(type) && |
|
box.text.downcase.include?(status.humanize.downcase) |
|
end |
|
end |
|
|
|
def link_from_databox(databox) |
|
URI.parse(databox.first("a")[:href]) |
|
end |
|
|
|
def count_from_databox(databox) |
|
databox.first("a").text.to_i |
|
end |
|
end
|
|
|