From 654d4ae8e5f37a205b08b70512cb1da1f345181b Mon Sep 17 00:00:00 2001 From: magicmilo Date: Fri, 29 Oct 2021 13:32:51 +0100 Subject: [PATCH 01/29] add select --- app/views/form/_select_question.html.erb | 5 ++ config/forms/2021_2022.json | 78 ++++++++++++++++++++++++ 2 files changed, 83 insertions(+) create mode 100644 app/views/form/_select_question.html.erb diff --git a/app/views/form/_select_question.html.erb b/app/views/form/_select_question.html.erb new file mode 100644 index 000000000..c4d8dccdc --- /dev/null +++ b/app/views/form/_select_question.html.erb @@ -0,0 +1,5 @@ +<%= f.govuk_collection_select question_key, question["answer_options"], +:id, +:name, +label: { text: question["header"].html_safe, size: "l" }, +hint: { text: question["hint_text"] } %> \ No newline at end of file diff --git a/config/forms/2021_2022.json b/config/forms/2021_2022.json index f4cf447c3..257f5fdd7 100644 --- a/config/forms/2021_2022.json +++ b/config/forms/2021_2022.json @@ -3,6 +3,84 @@ "start_year": 2021, "end_year": 2022, "sections": { + "about_this_log": { + "label": "About this log", + "subsections": { + "about_this_log": { + "label": "About this log", + "pages": { + "gdpr_acceptance": { + "header": "About this log", + "description": "About this log", + "questions": { + "gdpr_acceptance": { + "check_answer_label": "", + "header": "Has the tenant or buyer seen the DLUHC privacy notice?", + "hint_text": "", + "type": "select", + "answer_options": { + "0": "Yes", + "1": "No" + } + } + }, + "conditional_route_to": { + "organisation_details": { "gdpr_acceptance": "Yes" } + }, + "default_next_page": "gdpr_declined" + }, + "gdpr_declined": { + "header": "You cannot use this service", + "description": "We cannot accept data about a tenant or buyer unless they’ve seen the DLUHC privacy notice.", + "questions": { + } + }, + "organisation_details": { + "header": "About this log", + "description": "Organisation Details", + "questions": { + "property_owner_organisation": { + "check_answer_label": "", + "header": "Which organisation owns this property?", + "hint_text": "", + "type": "radio", + "answer_options": { + "0": "A", + "1": "B" + } + }, + "property_manager_organisation": { + "check_answer_label": "", + "header": "Which organisation manages this property?", + "hint_text": "", + "type": "radio", + "answer_options": { + "0": "A", + "1": "B" + } + } + } + }, + "sale_or_letting": { + "header": "About this log", + "description": "Is this a sale or a letting?", + "questions": { + "sale_or_letting": { + "check_answer_label": "", + "header": "Is this a sale or a letting?", + "hint_text": "", + "type": "radio", + "answer_options": { + "0": "Sale", + "1": "Letting" + } + } + } + } + } + } + } + }, "household": { "label": "About the household", "subsections": { From ec130db9ac90781a415a398a51cdef43ba1263c4 Mon Sep 17 00:00:00 2001 From: magicmilo Date: Mon, 1 Nov 2021 13:30:48 +0000 Subject: [PATCH 02/29] add select box and pages, waiting for naming convetion meeting --- app/views/form/_select_question.html.erb | 16 +++-- config/forms/2021_2022.json | 90 +++++++++++++++++++++++- 2 files changed, 100 insertions(+), 6 deletions(-) diff --git a/app/views/form/_select_question.html.erb b/app/views/form/_select_question.html.erb index c4d8dccdc..88c1a6058 100644 --- a/app/views/form/_select_question.html.erb +++ b/app/views/form/_select_question.html.erb @@ -1,5 +1,11 @@ -<%= f.govuk_collection_select question_key, question["answer_options"], -:id, -:name, -label: { text: question["header"].html_safe, size: "l" }, -hint: { text: question["hint_text"] } %> \ No newline at end of file + +<%= answers = question["answer_options"].map {|key, value| OpenStruct.new(id:key, name: value)} + f.govuk_collection_select :answer_id, + answers, + :id, + :name, + label: { text: question["header"]}, + hint: { text: question["hint_text"] } + %> + + diff --git a/config/forms/2021_2022.json b/config/forms/2021_2022.json index 257f5fdd7..0808a1c54 100644 --- a/config/forms/2021_2022.json +++ b/config/forms/2021_2022.json @@ -76,7 +76,95 @@ } } } - } + }, + "tenant_same_property_renewal": { + "header": "About this log", + "description": "Is this a renewal to the same tenant in the same property?", + "questions": { + "sale_or_letting": { + "check_answer_label": "", + "header": "Is this a renewal to the same tenant in the same property?", + "hint_text": "", + "type": "radio", + "answer_options": { + "0": "Yes", + "1": "No" + } + } + } + }, + "tenancy_start_date": { + "header": "About this log", + "description": "", + "questions": { + "sale_or_letting": { + "check_answer_label": "When is the tenancy start date?", + "header": "What is the tenancy start date?", + "hint_text": "For example, 27 3 2007", + "type": "date" + } + } + }, + "letting_type": { + "header": "About this log", + "description": "", + "questions": { + "rent_type": { + "check_answer_label": "What is the rent type?", + "header": "What is the rent type?", + "hint_text": "", + "type": "select", + "answer_options": { + "0": "Social Rent", + "1": "Affordable Rent", + "2": "London Affordable Rent", + "3": "Rent To Buy", + "4": "London Living Rent", + "5": "Other Intermediate Rent Product" + }, + "intermediate_rent_product_name": { + "check_answer_label": "Enter the product name", + "header": "What is intermediate rent product name?", + "type": "text", + "conditional_for": { + "rent_type": "Other Intermediate Rent Product" + } + }, + "needs_type": { + "check_answer_label": "What is the needs type?", + "header": "What is the needs type?", + "hint_text": "", + "type": "select", + "answer_options": { + "0": "Supported Housing", + "1": "General Needs" + } + } + }, + "sale_completion_date": { + "header": "About this log", + "description": "", + "questions": { + "sale_completion_date": { + "check_answer_label": "What is the sale completion date?", + "header": "What is the sale completion date?", + "hint_text": "For example, 27 3 2007", + "type": "date" + } + } + }, + "purchaser_code": { + "header": "About this log", + "description": "", + "questions": { + "purchaser_code": { + "check_answer_label": "What is the purchaser code?", + "header": "What is the purchaser code?", + "hint_text": "", + "type": "text" + } + } + } } } } From df90dde03121237680e6d327531d6ee3ee7126f4 Mon Sep 17 00:00:00 2001 From: magicmilo Date: Tue, 2 Nov 2021 14:00:42 +0000 Subject: [PATCH 03/29] add columns to about form --- app/controllers/case_logs_controller.rb | 2 +- app/views/form/_select_question.html.erb | 4 +-- config/forms/2021_2022.json | 26 +++++++++++++------ ...820_add_about_this_log_readable_columns.rb | 17 ++++++++++++ db/schema.rb | 13 +++++++++- 5 files changed, 50 insertions(+), 12 deletions(-) create mode 100644 db/migrate/20211102100820_add_about_this_log_readable_columns.rb diff --git a/app/controllers/case_logs_controller.rb b/app/controllers/case_logs_controller.rb index 48fe5726d..6ac932b56 100644 --- a/app/controllers/case_logs_controller.rb +++ b/app/controllers/case_logs_controller.rb @@ -136,7 +136,7 @@ private content["conditional_route_to"].each do |route, conditions| if conditions.keys.all? { |x| case_log[x].present? } && conditions.all? { |k, v| v.include?(case_log[k]) } return "case_log_#{route}_path" - end + end end end form.next_page_redirect_path(previous_page) diff --git a/app/views/form/_select_question.html.erb b/app/views/form/_select_question.html.erb index 88c1a6058..6f41b6b35 100644 --- a/app/views/form/_select_question.html.erb +++ b/app/views/form/_select_question.html.erb @@ -1,8 +1,8 @@ <%= answers = question["answer_options"].map {|key, value| OpenStruct.new(id:key, name: value)} - f.govuk_collection_select :answer_id, + f.govuk_collection_select question_key, answers, - :id, + :name, :name, label: { text: question["header"]}, hint: { text: question["hint_text"] } diff --git a/config/forms/2021_2022.json b/config/forms/2021_2022.json index 0808a1c54..6efc727f4 100644 --- a/config/forms/2021_2022.json +++ b/config/forms/2021_2022.json @@ -10,14 +10,14 @@ "label": "About this log", "pages": { "gdpr_acceptance": { - "header": "About this log", - "description": "About this log", + "header": "DLUHC Privacy Notice Acceptance", + "description": "", "questions": { "gdpr_acceptance": { - "check_answer_label": "", + "check_answer_label": "GDPR acceptance", "header": "Has the tenant or buyer seen the DLUHC privacy notice?", "hint_text": "", - "type": "select", + "type": "radio", "answer_options": { "0": "Yes", "1": "No" @@ -31,9 +31,12 @@ }, "gdpr_declined": { "header": "You cannot use this service", + "hint_text": "", "description": "We cannot accept data about a tenant or buyer unless they’ve seen the DLUHC privacy notice.", "questions": { - } + + }, + "default_next_page" : "check_answers" }, "organisation_details": { "header": "About this log", @@ -74,14 +77,19 @@ "0": "Sale", "1": "Letting" } - } + }, + "conditional_route_to": { + "sale_completion_date": { "sale_or_letting": "Sale" }, + "tenant_same_property_renewal": { "sale_or_letting": "Letting" } + }, + "default_next_page" : "check_answers" } }, "tenant_same_property_renewal": { "header": "About this log", "description": "Is this a renewal to the same tenant in the same property?", "questions": { - "sale_or_letting": { + "tenant_same_property_renewal": { "check_answer_label": "", "header": "Is this a renewal to the same tenant in the same property?", "hint_text": "", @@ -97,7 +105,7 @@ "header": "About this log", "description": "", "questions": { - "sale_or_letting": { + "tenancy_start_date": { "check_answer_label": "When is the tenancy start date?", "header": "What is the tenancy start date?", "hint_text": "For example, 27 3 2007", @@ -121,6 +129,7 @@ "3": "Rent To Buy", "4": "London Living Rent", "5": "Other Intermediate Rent Product" + } }, "intermediate_rent_product_name": { "check_answer_label": "Enter the product name", @@ -138,6 +147,7 @@ "answer_options": { "0": "Supported Housing", "1": "General Needs" + } } } }, diff --git a/db/migrate/20211102100820_add_about_this_log_readable_columns.rb b/db/migrate/20211102100820_add_about_this_log_readable_columns.rb new file mode 100644 index 000000000..b451af20e --- /dev/null +++ b/db/migrate/20211102100820_add_about_this_log_readable_columns.rb @@ -0,0 +1,17 @@ +class AddAboutThisLogReadableColumns < ActiveRecord::Migration[6.1] + def change + change_table :case_logs, bulk: true do |t| + t.column :gdpr_acceptance, :string + t.column :gdpr_declined, :string + t.column :property_owner_organisation, :string + t.column :property_manager_organisation, :string + t.column :sale_or_letting, :string + t.column :tenant_same_property_renewal, :string + t.column :rent_type, :string + t.column :intermediate_rent_product_name, :string + t.column :needs_type, :string + t.column :sale_completion_date, :string + t.column :purchaser_code, :string + end + end +end diff --git a/db/schema.rb b/db/schema.rb index 346f047c2..c29297c23 100644 --- a/db/schema.rb +++ b/db/schema.rb @@ -10,7 +10,7 @@ # # It's strongly recommended that you check this file into your version control system. -ActiveRecord::Schema.define(version: 2021_10_27_123535) do +ActiveRecord::Schema.define(version: 2021_11_02_100820) do # These are extensions that must be enabled in order to support this database enable_extension "plpgsql" @@ -133,6 +133,17 @@ ActiveRecord::Schema.define(version: 2021_10_27_123535) do t.boolean "reasonable_preference_reason_do_not_know" t.datetime "discarded_at" t.string "other_tenancy_type" + t.string "gdpr_acceptance" + t.string "gdpr_declined" + t.string "property_owner_organisation" + t.string "property_manager_organisation" + t.string "sale_or_letting" + t.string "tenant_same_property_renewal" + t.string "rent_type" + t.string "intermediate_rent_product_name" + t.string "needs_type" + t.string "sale_completion_date" + t.string "purchaser_code" t.index ["discarded_at"], name: "index_case_logs_on_discarded_at" end From 8d3ff3060af546b623eb1c78782c65e9b4af8cb4 Mon Sep 17 00:00:00 2001 From: magicmilo Date: Tue, 2 Nov 2021 14:33:01 +0000 Subject: [PATCH 04/29] conditional fors must be arr --- config/forms/2021_2022.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/config/forms/2021_2022.json b/config/forms/2021_2022.json index 6efc727f4..977a2e89e 100644 --- a/config/forms/2021_2022.json +++ b/config/forms/2021_2022.json @@ -136,7 +136,7 @@ "header": "What is intermediate rent product name?", "type": "text", "conditional_for": { - "rent_type": "Other Intermediate Rent Product" + "rent_type": ["Other Intermediate Rent Product"] } }, "needs_type": { From f14597bbbc78fac51c93482e015a339f420173c3 Mon Sep 17 00:00:00 2001 From: magicmilo Date: Wed, 3 Nov 2021 09:54:47 +0000 Subject: [PATCH 05/29] added aboutthislog test json --- app/helpers/check_answers_helper.rb | 2 + config/forms/2021_2022.json | 5 +- ...00820_add_about_this_log_readable_columns} | 0 db/schema.rb | 13 +- spec/fixtures/forms/test_aboutthislog.json | 181 ++++++++++++++++++ 5 files changed, 185 insertions(+), 16 deletions(-) rename db/migrate/{20211102100820_add_about_this_log_readable_columns.rb => 20211102100820_add_about_this_log_readable_columns} (100%) create mode 100644 spec/fixtures/forms/test_aboutthislog.json diff --git a/app/helpers/check_answers_helper.rb b/app/helpers/check_answers_helper.rb index 3e59de811..ff5312cce 100644 --- a/app/helpers/check_answers_helper.rb +++ b/app/helpers/check_answers_helper.rb @@ -58,6 +58,8 @@ module CheckAnswersHelper case_log[question_key].blank? || !case_log[question_key].send(operator, operand) when "radio" case_log[question_key].blank? || !condition.include?(case_log[question_key]) + when "select" + case_log[question_key].blank? || !condition.include?(case_log[question_key]) else raise "Not implemented yet" end diff --git a/config/forms/2021_2022.json b/config/forms/2021_2022.json index 977a2e89e..662cf9cec 100644 --- a/config/forms/2021_2022.json +++ b/config/forms/2021_2022.json @@ -33,9 +33,6 @@ "header": "You cannot use this service", "hint_text": "", "description": "We cannot accept data about a tenant or buyer unless they’ve seen the DLUHC privacy notice.", - "questions": { - - }, "default_next_page" : "check_answers" }, "organisation_details": { @@ -82,7 +79,7 @@ "sale_completion_date": { "sale_or_letting": "Sale" }, "tenant_same_property_renewal": { "sale_or_letting": "Letting" } }, - "default_next_page" : "check_answers" + "default_next_page" : ["check_answers"] } }, "tenant_same_property_renewal": { diff --git a/db/migrate/20211102100820_add_about_this_log_readable_columns.rb b/db/migrate/20211102100820_add_about_this_log_readable_columns similarity index 100% rename from db/migrate/20211102100820_add_about_this_log_readable_columns.rb rename to db/migrate/20211102100820_add_about_this_log_readable_columns diff --git a/db/schema.rb b/db/schema.rb index c29297c23..346f047c2 100644 --- a/db/schema.rb +++ b/db/schema.rb @@ -10,7 +10,7 @@ # # It's strongly recommended that you check this file into your version control system. -ActiveRecord::Schema.define(version: 2021_11_02_100820) do +ActiveRecord::Schema.define(version: 2021_10_27_123535) do # These are extensions that must be enabled in order to support this database enable_extension "plpgsql" @@ -133,17 +133,6 @@ ActiveRecord::Schema.define(version: 2021_11_02_100820) do t.boolean "reasonable_preference_reason_do_not_know" t.datetime "discarded_at" t.string "other_tenancy_type" - t.string "gdpr_acceptance" - t.string "gdpr_declined" - t.string "property_owner_organisation" - t.string "property_manager_organisation" - t.string "sale_or_letting" - t.string "tenant_same_property_renewal" - t.string "rent_type" - t.string "intermediate_rent_product_name" - t.string "needs_type" - t.string "sale_completion_date" - t.string "purchaser_code" t.index ["discarded_at"], name: "index_case_logs_on_discarded_at" end diff --git a/spec/fixtures/forms/test_aboutthislog.json b/spec/fixtures/forms/test_aboutthislog.json new file mode 100644 index 000000000..5f4313bd0 --- /dev/null +++ b/spec/fixtures/forms/test_aboutthislog.json @@ -0,0 +1,181 @@ +{ + "form_type": "lettings", + "sections": { + "about_this_log": { + "label": "About this log", + "subsections": { + "about_this_log": { + "label": "About this log", + "pages": { + "gdpr_acceptance": { + "header": "DLUHC Privacy Notice Acceptance", + "description": "", + "questions": { + "gdpr_acceptance": { + "check_answer_label": "GDPR acceptance", + "header": "Has the tenant or buyer seen the DLUHC privacy notice?", + "hint_text": "", + "type": "radio", + "answer_options": { + "0": "Yes", + "1": "No" + } + } + }, + "conditional_route_to": { + "organisation_details": { "gdpr_acceptance": "Yes" } + }, + "default_next_page": "gdpr_declined" + }, + "gdpr_declined": { + "header": "You cannot use this service", + "hint_text": "", + "description": "We cannot accept data about a tenant or buyer unless they’ve seen the DLUHC privacy notice.", + "questions": { + + }, + "default_next_page" : "check_answers" + }, + "organisation_details": { + "header": "About this log", + "description": "Organisation Details", + "questions": { + "property_owner_organisation": { + "check_answer_label": "", + "header": "Which organisation owns this property?", + "hint_text": "", + "type": "radio", + "answer_options": { + "0": "A", + "1": "B" + } + }, + "property_manager_organisation": { + "check_answer_label": "", + "header": "Which organisation manages this property?", + "hint_text": "", + "type": "radio", + "answer_options": { + "0": "A", + "1": "B" + } + } + } + }, + "sale_or_letting": { + "header": "About this log", + "description": "Is this a sale or a letting?", + "questions": { + "sale_or_letting": { + "check_answer_label": "", + "header": "Is this a sale or a letting?", + "hint_text": "", + "type": "radio", + "answer_options": { + "0": "Sale", + "1": "Letting" + } + }, + "conditional_route_to": { + "sale_completion_date": { "sale_or_letting": "Sale" }, + "tenant_same_property_renewal": { "sale_or_letting": "Letting" } + }, + "default_next_page" : ["check_answers"] + } + }, + "tenant_same_property_renewal": { + "header": "About this log", + "description": "Is this a renewal to the same tenant in the same property?", + "questions": { + "tenant_same_property_renewal": { + "check_answer_label": "", + "header": "Is this a renewal to the same tenant in the same property?", + "hint_text": "", + "type": "radio", + "answer_options": { + "0": "Yes", + "1": "No" + } + } + } + }, + "tenancy_start_date": { + "header": "About this log", + "description": "", + "questions": { + "tenancy_start_date": { + "check_answer_label": "When is the tenancy start date?", + "header": "What is the tenancy start date?", + "hint_text": "For example, 27 3 2007", + "type": "date" + } + } + }, + "letting_type": { + "header": "About this log", + "description": "", + "questions": { + "rent_type": { + "check_answer_label": "What is the rent type?", + "header": "What is the rent type?", + "hint_text": "", + "type": "select", + "answer_options": { + "0": "Social Rent", + "1": "Affordable Rent", + "2": "London Affordable Rent", + "3": "Rent To Buy", + "4": "London Living Rent", + "5": "Other Intermediate Rent Product" + } + }, + "intermediate_rent_product_name": { + "check_answer_label": "Enter the product name", + "header": "What is intermediate rent product name?", + "type": "text", + "conditional_for": { + "rent_type": ["Other Intermediate Rent Product"] + } + }, + "needs_type": { + "check_answer_label": "What is the needs type?", + "header": "What is the needs type?", + "hint_text": "", + "type": "select", + "answer_options": { + "0": "Supported Housing", + "1": "General Needs" + } + } + } + }, + "sale_completion_date": { + "header": "About this log", + "description": "", + "questions": { + "sale_completion_date": { + "check_answer_label": "What is the sale completion date?", + "header": "What is the sale completion date?", + "hint_text": "For example, 27 3 2007", + "type": "date" + } + } + }, + "purchaser_code": { + "header": "About this log", + "description": "", + "questions": { + "purchaser_code": { + "check_answer_label": "What is the purchaser code?", + "header": "What is the purchaser code?", + "hint_text": "", + "type": "text" + } + } + } + } + } + } + } + } +} From ca367d612dbef16cce8bba2f72fb6d8f25bf2957 Mon Sep 17 00:00:00 2001 From: magicmilo Date: Wed, 3 Nov 2021 14:43:49 +0000 Subject: [PATCH 06/29] switch test form --- app/helpers/check_answers_helper.rb | 18 ++++++++++++-- config/forms/2021_2022.json | 24 ++++++++++--------- ...20_add_about_this_log_readable_columns.rb} | 0 db/schema.rb | 13 +++++++++- spec/fixtures/forms/test_aboutthislog.json | 21 ++++++++-------- 5 files changed, 51 insertions(+), 25 deletions(-) rename db/migrate/{20211102100820_add_about_this_log_readable_columns => 20211102100820_add_about_this_log_readable_columns.rb} (100%) diff --git a/app/helpers/check_answers_helper.rb b/app/helpers/check_answers_helper.rb index ff5312cce..053c19f89 100644 --- a/app/helpers/check_answers_helper.rb +++ b/app/helpers/check_answers_helper.rb @@ -28,12 +28,25 @@ module CheckAnswersHelper def filter_conditional_questions(questions, case_log) applicable_questions = questions + # puts applicable_questions.count questions.each do |k, question| + + # if k == "default_next_page" + # applicable_questions = applicable_questions.reject { |z| z == "default_next_page" } + # else + # question.fetch("conditional_for", []).each do |conditional_question_key, condition| + # if condition_not_met(case_log, k, question, condition) + # applicable_questions = applicable_questions.reject { |z| z == conditional_question_key } + # end + # end + # end + question.fetch("conditional_for", []).each do |conditional_question_key, condition| if condition_not_met(case_log, k, question, condition) applicable_questions = applicable_questions.reject { |z| z == conditional_question_key } end end + end applicable_questions end @@ -56,13 +69,14 @@ module CheckAnswersHelper operator = condition[/[<>=]+/].to_sym operand = condition[/\d+/].to_i case_log[question_key].blank? || !case_log[question_key].send(operator, operand) + when "text" + case_log[question_key].blank? || !condition.include?(case_log[question_key]) when "radio" case_log[question_key].blank? || !condition.include?(case_log[question_key]) when "select" case_log[question_key].blank? || !condition.include?(case_log[question_key]) else - raise "Not implemented yet" - end + raise "Not implemented yet" end end def create_update_answer_link(case_log_answer, case_log_id, page) diff --git a/config/forms/2021_2022.json b/config/forms/2021_2022.json index 662cf9cec..8355b4f93 100644 --- a/config/forms/2021_2022.json +++ b/config/forms/2021_2022.json @@ -33,6 +33,9 @@ "header": "You cannot use this service", "hint_text": "", "description": "We cannot accept data about a tenant or buyer unless they’ve seen the DLUHC privacy notice.", + "questions": { + + }, "default_next_page" : "check_answers" }, "organisation_details": { @@ -74,13 +77,12 @@ "0": "Sale", "1": "Letting" } - }, - "conditional_route_to": { - "sale_completion_date": { "sale_or_letting": "Sale" }, - "tenant_same_property_renewal": { "sale_or_letting": "Letting" } - }, - "default_next_page" : ["check_answers"] - } + } + }, + "conditional_route_to": { + "tenant_same_property_renewal": { "sale_or_letting": "Letting" } + }, + "default_next_page" : "check_answers" }, "tenant_same_property_renewal": { "header": "About this log", @@ -126,15 +128,15 @@ "3": "Rent To Buy", "4": "London Living Rent", "5": "Other Intermediate Rent Product" + }, + "conditional_for": { + "intermediate_rent_product_name": ["Other Intermediate Rent Product"] } }, "intermediate_rent_product_name": { "check_answer_label": "Enter the product name", "header": "What is intermediate rent product name?", - "type": "text", - "conditional_for": { - "rent_type": ["Other Intermediate Rent Product"] - } + "type": "text" }, "needs_type": { "check_answer_label": "What is the needs type?", diff --git a/db/migrate/20211102100820_add_about_this_log_readable_columns b/db/migrate/20211102100820_add_about_this_log_readable_columns.rb similarity index 100% rename from db/migrate/20211102100820_add_about_this_log_readable_columns rename to db/migrate/20211102100820_add_about_this_log_readable_columns.rb diff --git a/db/schema.rb b/db/schema.rb index 346f047c2..c29297c23 100644 --- a/db/schema.rb +++ b/db/schema.rb @@ -10,7 +10,7 @@ # # It's strongly recommended that you check this file into your version control system. -ActiveRecord::Schema.define(version: 2021_10_27_123535) do +ActiveRecord::Schema.define(version: 2021_11_02_100820) do # These are extensions that must be enabled in order to support this database enable_extension "plpgsql" @@ -133,6 +133,17 @@ ActiveRecord::Schema.define(version: 2021_10_27_123535) do t.boolean "reasonable_preference_reason_do_not_know" t.datetime "discarded_at" t.string "other_tenancy_type" + t.string "gdpr_acceptance" + t.string "gdpr_declined" + t.string "property_owner_organisation" + t.string "property_manager_organisation" + t.string "sale_or_letting" + t.string "tenant_same_property_renewal" + t.string "rent_type" + t.string "intermediate_rent_product_name" + t.string "needs_type" + t.string "sale_completion_date" + t.string "purchaser_code" t.index ["discarded_at"], name: "index_case_logs_on_discarded_at" end diff --git a/spec/fixtures/forms/test_aboutthislog.json b/spec/fixtures/forms/test_aboutthislog.json index 5f4313bd0..2cfd8ff26 100644 --- a/spec/fixtures/forms/test_aboutthislog.json +++ b/spec/fixtures/forms/test_aboutthislog.json @@ -75,13 +75,12 @@ "0": "Sale", "1": "Letting" } - }, - "conditional_route_to": { - "sale_completion_date": { "sale_or_letting": "Sale" }, - "tenant_same_property_renewal": { "sale_or_letting": "Letting" } - }, - "default_next_page" : ["check_answers"] - } + } + }, + "conditional_route_to": { + "tenant_same_property_renewal": { "sale_or_letting": "Letting" } + }, + "default_next_page" : "check_answers" }, "tenant_same_property_renewal": { "header": "About this log", @@ -127,15 +126,15 @@ "3": "Rent To Buy", "4": "London Living Rent", "5": "Other Intermediate Rent Product" + }, + "conditional_for": { + "intermediate_rent_product_name": ["Other Intermediate Rent Product"] } }, "intermediate_rent_product_name": { "check_answer_label": "Enter the product name", "header": "What is intermediate rent product name?", - "type": "text", - "conditional_for": { - "rent_type": ["Other Intermediate Rent Product"] - } + "type": "text" }, "needs_type": { "check_answer_label": "What is the needs type?", From de2ebc6aea812884ada1ac91080dff776bc6bd1f Mon Sep 17 00:00:00 2001 From: magicmilo Date: Thu, 4 Nov 2021 11:48:30 +0000 Subject: [PATCH 07/29] commit --- app/helpers/check_answers_helper.rb | 16 ++-------------- spec/helpers/check_answers_helper_spec.rb | 4 +++- 2 files changed, 5 insertions(+), 15 deletions(-) diff --git a/app/helpers/check_answers_helper.rb b/app/helpers/check_answers_helper.rb index 053c19f89..37debfd8c 100644 --- a/app/helpers/check_answers_helper.rb +++ b/app/helpers/check_answers_helper.rb @@ -15,6 +15,7 @@ module CheckAnswersHelper page_name = subsection_keys.first while page_name.to_s != "check_answers" && subsection_keys.include?(page_name) + binding.pry questions = form.questions_for_page(page_name) applicable_questions = filter_conditional_questions(questions, case_log) total_questions = total_questions.merge(applicable_questions) @@ -30,23 +31,11 @@ module CheckAnswersHelper # puts applicable_questions.count questions.each do |k, question| - - # if k == "default_next_page" - # applicable_questions = applicable_questions.reject { |z| z == "default_next_page" } - # else - # question.fetch("conditional_for", []).each do |conditional_question_key, condition| - # if condition_not_met(case_log, k, question, condition) - # applicable_questions = applicable_questions.reject { |z| z == conditional_question_key } - # end - # end - # end - question.fetch("conditional_for", []).each do |conditional_question_key, condition| if condition_not_met(case_log, k, question, condition) applicable_questions = applicable_questions.reject { |z| z == conditional_question_key } end end - end applicable_questions end @@ -64,6 +53,7 @@ module CheckAnswersHelper end def condition_not_met(case_log, question_key, question, condition) + binding.pry case question["type"] when "numeric" operator = condition[/[<>=]+/].to_sym @@ -73,8 +63,6 @@ module CheckAnswersHelper case_log[question_key].blank? || !condition.include?(case_log[question_key]) when "radio" case_log[question_key].blank? || !condition.include?(case_log[question_key]) - when "select" - case_log[question_key].blank? || !condition.include?(case_log[question_key]) else raise "Not implemented yet" end end diff --git a/spec/helpers/check_answers_helper_spec.rb b/spec/helpers/check_answers_helper_spec.rb index 3eae2227c..4d45c164d 100644 --- a/spec/helpers/check_answers_helper_spec.rb +++ b/spec/helpers/check_answers_helper_spec.rb @@ -98,7 +98,9 @@ RSpec.describe CheckAnswersHelper do "hint_text" => "", "type" => "date", "check_answer_label" => "Question Label", - "conditional_for" => { "question_2" => %w[12-12-2021] } } } + "conditional_for" => { "question_2" => %w[12-12-2021] } + } + } end it "raises an error" do From 3b0efa52934456ae6cf52dd3bf5808dd643491f2 Mon Sep 17 00:00:00 2001 From: magicmilo Date: Thu, 4 Nov 2021 12:05:18 +0000 Subject: [PATCH 08/29] fixed broken test --- app/helpers/check_answers_helper.rb | 6 ++++-- spec/fixtures/forms/test_form.json | 2 +- spec/helpers/check_answers_helper_spec.rb | 2 +- 3 files changed, 6 insertions(+), 4 deletions(-) diff --git a/app/helpers/check_answers_helper.rb b/app/helpers/check_answers_helper.rb index 37debfd8c..4cafe3731 100644 --- a/app/helpers/check_answers_helper.rb +++ b/app/helpers/check_answers_helper.rb @@ -14,8 +14,10 @@ module CheckAnswersHelper subsection_keys = form.pages_for_subsection(subsection).keys page_name = subsection_keys.first + # binding.pry + while page_name.to_s != "check_answers" && subsection_keys.include?(page_name) - binding.pry + # binding.pry questions = form.questions_for_page(page_name) applicable_questions = filter_conditional_questions(questions, case_log) total_questions = total_questions.merge(applicable_questions) @@ -53,7 +55,7 @@ module CheckAnswersHelper end def condition_not_met(case_log, question_key, question, condition) - binding.pry + # binding.pry case question["type"] when "numeric" operator = condition[/[<>=]+/].to_sym diff --git a/spec/fixtures/forms/test_form.json b/spec/fixtures/forms/test_form.json index 35590cb3e..ab1b69c76 100644 --- a/spec/fixtures/forms/test_form.json +++ b/spec/fixtures/forms/test_form.json @@ -497,7 +497,7 @@ "check_answer_label": "Postcode of previous accomodation if the household has moved from settled accommodation", "header": "Postcode for the previous accommodation", "hint_text": "If the household has moved from settled accommodation immediately prior to being re-housed", - "type": "text", + "type": "date", "conditional_for": { "faake_key": "fake_condition" } } } diff --git a/spec/helpers/check_answers_helper_spec.rb b/spec/helpers/check_answers_helper_spec.rb index 4d45c164d..38db2ef6b 100644 --- a/spec/helpers/check_answers_helper_spec.rb +++ b/spec/helpers/check_answers_helper_spec.rb @@ -104,7 +104,7 @@ RSpec.describe CheckAnswersHelper do end it "raises an error" do - allow_any_instance_of(Form).to receive(:pages_for_subsection).and_return(unimplemented_conditional) + allow_any_instance_of(Form).to receive(:questions_for_page).and_return(unimplemented_conditional) expect { total_number_of_questions(subsection, case_log, form) }.to raise_error(RuntimeError, "Not implemented yet") end end From dcad47cbe77dd541db04efac3fd2ecd0d092d3fd Mon Sep 17 00:00:00 2001 From: magicmilo Date: Thu, 4 Nov 2021 12:15:45 +0000 Subject: [PATCH 09/29] return test_form data to text --- spec/fixtures/forms/test_form.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/spec/fixtures/forms/test_form.json b/spec/fixtures/forms/test_form.json index ab1b69c76..35590cb3e 100644 --- a/spec/fixtures/forms/test_form.json +++ b/spec/fixtures/forms/test_form.json @@ -497,7 +497,7 @@ "check_answer_label": "Postcode of previous accomodation if the household has moved from settled accommodation", "header": "Postcode for the previous accommodation", "hint_text": "If the household has moved from settled accommodation immediately prior to being re-housed", - "type": "date", + "type": "text", "conditional_for": { "faake_key": "fake_condition" } } } From c383493f5e9b4787baeae3fa8ae3121fd39e7fa6 Mon Sep 17 00:00:00 2001 From: magicmilo Date: Fri, 5 Nov 2021 09:55:35 +0000 Subject: [PATCH 10/29] add new fields to completecaselog --- spec/fixtures/complete_case_log.json | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/spec/fixtures/complete_case_log.json b/spec/fixtures/complete_case_log.json index 9238bba6a..3647c6163 100644 --- a/spec/fixtures/complete_case_log.json +++ b/spec/fixtures/complete_case_log.json @@ -112,6 +112,18 @@ "reasonable_preference_reason_unsatisfactory_housing": false, "reasonable_preference_reason_medical_grounds": false, "reasonable_preference_reason_avoid_hardship": false, - "reasonable_preference_reason_do_not_know": true + "reasonable_preference_reason_do_not_know": true, + "other_tenancy_type": "", + "gdpr_acceptance": "", + "gdpr_declined": "", + "property_owner_organisation": "", + "property_manager_organisation": "", + "sale_or_letting": "", + "tenant_same_property_renewal": "", + "rent_type": "", + "intermediate_rent_product_name": "", + "needs_type": "", + "sale_completion_date" : "", + "purchaser_code": "" } } From acfe2622e01d6fdc10747c87aa05897ebef3ed47 Mon Sep 17 00:00:00 2001 From: magicmilo Date: Fri, 5 Nov 2021 09:57:37 +0000 Subject: [PATCH 11/29] remove debug lines --- app/helpers/check_answers_helper.rb | 4 ---- 1 file changed, 4 deletions(-) diff --git a/app/helpers/check_answers_helper.rb b/app/helpers/check_answers_helper.rb index 4cafe3731..92bedb2a0 100644 --- a/app/helpers/check_answers_helper.rb +++ b/app/helpers/check_answers_helper.rb @@ -14,10 +14,7 @@ module CheckAnswersHelper subsection_keys = form.pages_for_subsection(subsection).keys page_name = subsection_keys.first - # binding.pry - while page_name.to_s != "check_answers" && subsection_keys.include?(page_name) - # binding.pry questions = form.questions_for_page(page_name) applicable_questions = filter_conditional_questions(questions, case_log) total_questions = total_questions.merge(applicable_questions) @@ -55,7 +52,6 @@ module CheckAnswersHelper end def condition_not_met(case_log, question_key, question, condition) - # binding.pry case question["type"] when "numeric" operator = condition[/[<>=]+/].to_sym From 0d82814fee1499d6cf35d6879034f687a1f60293 Mon Sep 17 00:00:00 2001 From: magicmilo Date: Fri, 5 Nov 2021 10:42:02 +0000 Subject: [PATCH 12/29] remove debug line and rubocop --- app/controllers/case_logs_controller.rb | 2 +- app/helpers/check_answers_helper.rb | 3 +-- spec/helpers/check_answers_helper_spec.rb | 4 +--- spec/models/case_log_spec.rb | 5 +++-- 4 files changed, 6 insertions(+), 8 deletions(-) diff --git a/app/controllers/case_logs_controller.rb b/app/controllers/case_logs_controller.rb index 6ac932b56..48fe5726d 100644 --- a/app/controllers/case_logs_controller.rb +++ b/app/controllers/case_logs_controller.rb @@ -136,7 +136,7 @@ private content["conditional_route_to"].each do |route, conditions| if conditions.keys.all? { |x| case_log[x].present? } && conditions.all? { |k, v| v.include?(case_log[k]) } return "case_log_#{route}_path" - end + end end end form.next_page_redirect_path(previous_page) diff --git a/app/helpers/check_answers_helper.rb b/app/helpers/check_answers_helper.rb index 92bedb2a0..5a8369ade 100644 --- a/app/helpers/check_answers_helper.rb +++ b/app/helpers/check_answers_helper.rb @@ -28,7 +28,6 @@ module CheckAnswersHelper def filter_conditional_questions(questions, case_log) applicable_questions = questions - # puts applicable_questions.count questions.each do |k, question| question.fetch("conditional_for", []).each do |conditional_question_key, condition| if condition_not_met(case_log, k, question, condition) @@ -62,7 +61,7 @@ module CheckAnswersHelper when "radio" case_log[question_key].blank? || !condition.include?(case_log[question_key]) else - raise "Not implemented yet" end + raise "Not implemented yet" end end def create_update_answer_link(case_log_answer, case_log_id, page) diff --git a/spec/helpers/check_answers_helper_spec.rb b/spec/helpers/check_answers_helper_spec.rb index 38db2ef6b..5ac16b2bd 100644 --- a/spec/helpers/check_answers_helper_spec.rb +++ b/spec/helpers/check_answers_helper_spec.rb @@ -98,9 +98,7 @@ RSpec.describe CheckAnswersHelper do "hint_text" => "", "type" => "date", "check_answer_label" => "Question Label", - "conditional_for" => { "question_2" => %w[12-12-2021] } - } - } + "conditional_for" => { "question_2" => %w[12-12-2021] } } } end it "raises an error" do diff --git a/spec/models/case_log_spec.rb b/spec/models/case_log_spec.rb index d95f000a7..8ac7d349d 100644 --- a/spec/models/case_log_spec.rb +++ b/spec/models/case_log_spec.rb @@ -198,10 +198,11 @@ RSpec.describe Form, type: :model do # Crossover over tests here as injured must be answered as well for no error it "must be answered if ever served in the forces as a regular" do - expect { + expect do CaseLog.create!(armed_forces: "Yes - a regular", armed_forces_active: "Yes", - armed_forces_injured: "Yes")} + armed_forces_injured: "Yes") + end end end From ebb564052ac0dbd8e6a31b80e739dc39347d23a4 Mon Sep 17 00:00:00 2001 From: magicmilo Date: Fri, 5 Nov 2021 10:46:14 +0000 Subject: [PATCH 13/29] remove end --- app/helpers/check_answers_helper.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/app/helpers/check_answers_helper.rb b/app/helpers/check_answers_helper.rb index 5a8369ade..21b6d4f1a 100644 --- a/app/helpers/check_answers_helper.rb +++ b/app/helpers/check_answers_helper.rb @@ -61,7 +61,7 @@ module CheckAnswersHelper when "radio" case_log[question_key].blank? || !condition.include?(case_log[question_key]) else - raise "Not implemented yet" end + raise "Not implemented yet" end def create_update_answer_link(case_log_answer, case_log_id, page) From cff0083aec0770a69c5b4bf730800f3fd00452db Mon Sep 17 00:00:00 2001 From: magicmilo Date: Fri, 5 Nov 2021 10:47:28 +0000 Subject: [PATCH 14/29] move end --- app/helpers/check_answers_helper.rb | 1 + 1 file changed, 1 insertion(+) diff --git a/app/helpers/check_answers_helper.rb b/app/helpers/check_answers_helper.rb index 21b6d4f1a..1cc1bc65e 100644 --- a/app/helpers/check_answers_helper.rb +++ b/app/helpers/check_answers_helper.rb @@ -62,6 +62,7 @@ module CheckAnswersHelper case_log[question_key].blank? || !condition.include?(case_log[question_key]) else raise "Not implemented yet" + end end def create_update_answer_link(case_log_answer, case_log_id, page) From 8f6ef06bb1d5475747c18051a6efa6e27ffa5655 Mon Sep 17 00:00:00 2001 From: baarkerlounger Date: Fri, 5 Nov 2021 11:35:37 +0000 Subject: [PATCH 15/29] Rubocop --- app/admin/case_logs.rb | 3 +-- config/initializers/active_admin.rb | 4 ++-- 2 files changed, 3 insertions(+), 4 deletions(-) diff --git a/app/admin/case_logs.rb b/app/admin/case_logs.rb index cd303787e..5b5861e1b 100644 --- a/app/admin/case_logs.rb +++ b/app/admin/case_logs.rb @@ -1,9 +1,8 @@ ActiveAdmin.register CaseLog do - # See permitted parameters documentation: # https://github.com/activeadmin/activeadmin/blob/master/docs/2-resource-customization.md#setting-up-strong-parameters permit_params do - permitted = [:status, :tenant_code, :person_1_age, :person_1_gender, :tenant_ethnic_group, :tenant_nationality, :previous_housing_situation, :armed_forces, :person_1_economic_status, :household_number_of_other_members, :person_2_relationship, :person_2_age, :person_2_gender, :person_2_economic_status, :person_3_relationship, :person_3_age, :person_3_gender, :person_3_economic_status, :person_4_relationship, :person_4_age, :person_4_gender, :person_4_economic_status, :person_5_relationship, :person_5_age, :person_5_gender, :person_5_economic_status, :person_6_relationship, :person_6_age, :person_6_gender, :person_6_economic_status, :person_7_relationship, :person_7_age, :person_7_gender, :person_7_economic_status, :person_8_relationship, :person_8_age, :person_8_gender, :person_8_economic_status, :homelessness, :reason_for_leaving_last_settled_home, :benefit_cap_spare_room_subsidy, :armed_forces_active, :armed_forces_injured, :armed_forces_partner, :medical_conditions, :pregnancy, :accessibility_requirements, :condition_effects, :tenancy_code, :tenancy_start_date, :starter_tenancy, :fixed_term_tenancy, :tenancy_type, :letting_type, :letting_provider, :property_location, :previous_postcode, :property_relet, :property_vacancy_reason, :property_reference, :property_unit_type, :property_building_type, :property_number_of_bedrooms, :property_void_date, :property_major_repairs, :property_major_repairs_date, :property_number_of_times_relet, :property_wheelchair_accessible, :net_income, :net_income_frequency, :net_income_uc_proportion, :housing_benefit, :rent_frequency, :basic_rent, :service_charge, :personal_service_charge, :support_charge, :total_charge, :outstanding_amount, :time_lived_in_la, :time_on_la_waiting_list, :previous_la, :property_postcode, :reasonable_preference, :reasonable_preference_reason, :cbl_letting, :chr_letting, :cap_letting, :outstanding_rent_or_charges, :other_reason_for_leaving_last_settled_home, :accessibility_requirements_fully_wheelchair_accessible_housing, :accessibility_requirements_wheelchair_access_to_essential_rooms, :accessibility_requirements_level_access_housing, :accessibility_requirements_other_disability_requirements, :accessibility_requirements_no_disability_requirements, :accessibility_requirements_do_not_know, :accessibility_requirements_prefer_not_to_say, :condition_effects_vision, :condition_effects_hearing, :condition_effects_mobility, :condition_effects_dexterity, :condition_effects_stamina, :condition_effects_learning, :condition_effects_memory, :condition_effects_mental_health, :condition_effects_social_or_behavioral, :condition_effects_other, :condition_effects_prefer_not_to_say, :reasonable_preference_reason_homeless, :reasonable_preference_reason_unsatisfactory_housing, :reasonable_preference_reason_medical_grounds, :reasonable_preference_reason_avoid_hardship, :reasonable_preference_reason_do_not_know, :other_tenancy_type, :override_net_income_validation, :net_income_known] + permitted = %i[status tenant_code person_1_age person_1_gender tenant_ethnic_group tenant_nationality previous_housing_situation armed_forces person_1_economic_status household_number_of_other_members person_2_relationship person_2_age person_2_gender person_2_economic_status person_3_relationship person_3_age person_3_gender person_3_economic_status person_4_relationship person_4_age person_4_gender person_4_economic_status person_5_relationship person_5_age person_5_gender person_5_economic_status person_6_relationship person_6_age person_6_gender person_6_economic_status person_7_relationship person_7_age person_7_gender person_7_economic_status person_8_relationship person_8_age person_8_gender person_8_economic_status homelessness reason_for_leaving_last_settled_home benefit_cap_spare_room_subsidy armed_forces_active armed_forces_injured armed_forces_partner medical_conditions pregnancy accessibility_requirements condition_effects tenancy_code tenancy_start_date starter_tenancy fixed_term_tenancy tenancy_type letting_type letting_provider property_location previous_postcode property_relet property_vacancy_reason property_reference property_unit_type property_building_type property_number_of_bedrooms property_void_date property_major_repairs property_major_repairs_date property_number_of_times_relet property_wheelchair_accessible net_income net_income_frequency net_income_uc_proportion housing_benefit rent_frequency basic_rent service_charge personal_service_charge support_charge total_charge outstanding_amount time_lived_in_la time_on_la_waiting_list previous_la property_postcode reasonable_preference reasonable_preference_reason cbl_letting chr_letting cap_letting outstanding_rent_or_charges other_reason_for_leaving_last_settled_home accessibility_requirements_fully_wheelchair_accessible_housing accessibility_requirements_wheelchair_access_to_essential_rooms accessibility_requirements_level_access_housing accessibility_requirements_other_disability_requirements accessibility_requirements_no_disability_requirements accessibility_requirements_do_not_know accessibility_requirements_prefer_not_to_say condition_effects_vision condition_effects_hearing condition_effects_mobility condition_effects_dexterity condition_effects_stamina condition_effects_learning condition_effects_memory condition_effects_mental_health condition_effects_social_or_behavioral condition_effects_other condition_effects_prefer_not_to_say reasonable_preference_reason_homeless reasonable_preference_reason_unsatisfactory_housing reasonable_preference_reason_medical_grounds reasonable_preference_reason_avoid_hardship reasonable_preference_reason_do_not_know other_tenancy_type override_net_income_validation net_income_known] permitted end diff --git a/config/initializers/active_admin.rb b/config/initializers/active_admin.rb index 4ef658194..5afdcdc12 100644 --- a/config/initializers/active_admin.rb +++ b/config/initializers/active_admin.rb @@ -124,7 +124,7 @@ ActiveAdmin.setup do |config| # This allows your users to comment on any resource registered with Active Admin. # # You can completely disable comments: - config.comments = false + config.comments = false # # You can change the name under which comments are registered: # config.comments_registration_name = 'AdminComment' @@ -157,7 +157,7 @@ ActiveAdmin.setup do |config| # You can exclude possibly sensitive model attributes from being displayed, # added to forms, or exported by default by ActiveAdmin # - config.filter_attributes = [:encrypted_password, :password, :password_confirmation] + config.filter_attributes = %i[encrypted_password password password_confirmation] # == Localize Date/Time Format # From 5ae2f120a86c0f1d63eeccec8aa0deedd5e0bbf2 Mon Sep 17 00:00:00 2001 From: kosiakkatrina <54268893+kosiakkatrina@users.noreply.github.com> Date: Fri, 5 Nov 2021 16:16:36 +0000 Subject: [PATCH 16/29] Db migration (#79) * migration wip * change field names to lowercase and fix the tests * Change national and ethnic field types and map to correct enums * change ecstat column types * Change prevten field type * Change homeless field type * Change benefit cap field type * Put db enums in one folder and add a few new field changes" * change field type for housing needs * Change illness field type * display checkbox answers * cbl, chr, cap * Change tenancy and tenancylength field types * Change landlord and rsnvac field types * Change unittype_gn field type * Reasonble preference displaying on check answers * update more field types * Fix typo in comumn name * Change more types * Test fixes * Add adr * fix some tests * run migration * Fix tests Co-authored-by: Matthew Phelan --- app/admin/case_logs.rb | 2 +- app/constants/db_enums.rb | 252 +++++++ app/controllers/case_logs_controller.rb | 2 +- app/models/case_log.rb | 93 ++- app/models/form.rb | 17 + app/validations/financial_validations.rb | 14 +- app/validations/household_validations.rb | 98 +-- app/validations/property_validations.rb | 4 +- app/validations/soft_validations.rb | 8 +- app/validations/tenancy_validations.rb | 12 +- app/views/form/_check_answers_table.html.erb | 2 +- app/views/form/_checkbox_question.html.erb | 2 +- app/views/form/check_answers.html.erb | 2 +- config/forms/2021_2022.json | 290 ++++---- db/migrate/20211101192151_rename_fields.rb | 106 +++ .../20211103090530_change_field_types.rb | 131 ++++ db/schema.rb | 184 +++--- docs/adr/adr-008-field-names.md | 11 + docs/api/DLUHC-CORE-Data.v1.json | 625 ++++++++---------- spec/controllers/case_logs_controller_spec.rb | 50 +- spec/factories/case_log.rb | 2 +- spec/features/case_log_spec.rb | 153 ++--- spec/fixtures/complete_case_log.json | 256 +++---- spec/fixtures/forms/test_form.json | 122 ++-- spec/helpers/check_answers_helper_spec.rb | 36 +- .../conditional_questions_helper_spec.rb | 4 +- .../helpers/question_attribute_helper_spec.rb | 12 +- spec/helpers/tasklist_helper_spec.rb | 6 +- spec/models/case_log_spec.rb | 162 ++--- spec/models/form_spec.rb | 2 +- spec/requests/case_log_controller_spec.rb | 20 +- 31 files changed, 1606 insertions(+), 1074 deletions(-) create mode 100644 app/constants/db_enums.rb create mode 100644 db/migrate/20211101192151_rename_fields.rb create mode 100644 db/migrate/20211103090530_change_field_types.rb create mode 100644 docs/adr/adr-008-field-names.md diff --git a/app/admin/case_logs.rb b/app/admin/case_logs.rb index 5b5861e1b..f14d33a3a 100644 --- a/app/admin/case_logs.rb +++ b/app/admin/case_logs.rb @@ -2,7 +2,7 @@ ActiveAdmin.register CaseLog do # See permitted parameters documentation: # https://github.com/activeadmin/activeadmin/blob/master/docs/2-resource-customization.md#setting-up-strong-parameters permit_params do - permitted = %i[status tenant_code person_1_age person_1_gender tenant_ethnic_group tenant_nationality previous_housing_situation armed_forces person_1_economic_status household_number_of_other_members person_2_relationship person_2_age person_2_gender person_2_economic_status person_3_relationship person_3_age person_3_gender person_3_economic_status person_4_relationship person_4_age person_4_gender person_4_economic_status person_5_relationship person_5_age person_5_gender person_5_economic_status person_6_relationship person_6_age person_6_gender person_6_economic_status person_7_relationship person_7_age person_7_gender person_7_economic_status person_8_relationship person_8_age person_8_gender person_8_economic_status homelessness reason_for_leaving_last_settled_home benefit_cap_spare_room_subsidy armed_forces_active armed_forces_injured armed_forces_partner medical_conditions pregnancy accessibility_requirements condition_effects tenancy_code tenancy_start_date starter_tenancy fixed_term_tenancy tenancy_type letting_type letting_provider property_location previous_postcode property_relet property_vacancy_reason property_reference property_unit_type property_building_type property_number_of_bedrooms property_void_date property_major_repairs property_major_repairs_date property_number_of_times_relet property_wheelchair_accessible net_income net_income_frequency net_income_uc_proportion housing_benefit rent_frequency basic_rent service_charge personal_service_charge support_charge total_charge outstanding_amount time_lived_in_la time_on_la_waiting_list previous_la property_postcode reasonable_preference reasonable_preference_reason cbl_letting chr_letting cap_letting outstanding_rent_or_charges other_reason_for_leaving_last_settled_home accessibility_requirements_fully_wheelchair_accessible_housing accessibility_requirements_wheelchair_access_to_essential_rooms accessibility_requirements_level_access_housing accessibility_requirements_other_disability_requirements accessibility_requirements_no_disability_requirements accessibility_requirements_do_not_know accessibility_requirements_prefer_not_to_say condition_effects_vision condition_effects_hearing condition_effects_mobility condition_effects_dexterity condition_effects_stamina condition_effects_learning condition_effects_memory condition_effects_mental_health condition_effects_social_or_behavioral condition_effects_other condition_effects_prefer_not_to_say reasonable_preference_reason_homeless reasonable_preference_reason_unsatisfactory_housing reasonable_preference_reason_medical_grounds reasonable_preference_reason_avoid_hardship reasonable_preference_reason_do_not_know other_tenancy_type override_net_income_validation net_income_known] + permitted = %i[status tenant_code age1 sex1 tenant_ethnic_group tenant_nationality previous_housing_situation armed_forces ecstat1 hhmemb relat2 age2 sex2 ecstat2 relat3 age3 sex3 ecstat3 relat4 age4 sex4 ecstat4 relat5 age5 sex5 ecstat5 relat6 age6 sex6 ecstat6 relat7 age7 person_7_gender ecstat7 relat8 age8 sex8 ecstat8 homelessness reason_for_leaving_last_settled_home benefit_cap_spare_room_subsidy armed_forces_active armed_forces_injured armed_forces_partner medical_conditions pregnancy accessibility_requirements condition_effects tenancy_code tenancy_start_date starter_tenancy fixed_term_tenancy tenancy_type letting_type letting_provider property_location previous_postcode property_relet property_vacancy_reason property_reference property_unit_type property_building_type property_number_of_bedrooms property_void_date property_major_repairs property_major_repairs_date property_number_of_times_relet property_wheelchair_accessible net_income net_income_frequency net_income_uc_proportion housing_benefit rent_frequency basic_rent service_charge personal_service_charge support_charge total_charge outstanding_amount time_lived_in_la time_on_la_waiting_list previous_la property_postcode reasonable_preference reasonable_preference_reason cbl_letting chr_letting cap_letting outstanding_rent_or_charges other_reason_for_leaving_last_settled_home accessibility_requirements_fully_wheelchair_accessible_housing accessibility_requirements_wheelchair_access_to_essential_rooms accessibility_requirements_level_access_housing accessibility_requirements_other_disability_requirements accessibility_requirements_no_disability_requirements accessibility_requirements_do_not_know accessibility_requirements_prefer_not_to_say condition_effects_vision condition_effects_hearing condition_effects_mobility condition_effects_dexterity condition_effects_stamina condition_effects_learning condition_effects_memory condition_effects_mental_health condition_effects_social_or_behavioral condition_effects_other condition_effects_prefer_not_to_say reasonable_preference_reason_homeless reasonable_preference_reason_unsatisfactory_housing reasonable_preference_reason_medical_grounds reasonable_preference_reason_avoid_hardship reasonable_preference_reason_do_not_know other_tenancy_type override_net_income_validation net_income_known] permitted end diff --git a/app/constants/db_enums.rb b/app/constants/db_enums.rb new file mode 100644 index 000000000..536620915 --- /dev/null +++ b/app/constants/db_enums.rb @@ -0,0 +1,252 @@ +module DbEnums + def self.benefitcap + { + "Yes - benefit cap" => 5, + "Yes - removal of the spare room subsidy" => 4, + "Yes - both the benefit cap and the removal of the spare room subsidy" => 6, + "No" => 2, + "Do not know" => 3, + "Prefer not to say" => 100, + } + end + + def self.ecstat + { + "Part-time - Less than 30 hours" => 2, + "Full-time - 30 hours or more" => 1, + "In government training into work, such as New Deal" => 3, + "Jobseeker" => 4, + "Retired" => 5, + "Not seeking work" => 6, + "Full-time student" => 7, + "Unable to work because of long term sick or disability" => 8, + "Child under 16" => 100, + "Other" => 0, + "Prefer not to say" => 10, + } + end + + def self.ethnic + { + "White: English/Scottish/Welsh/Northern Irish/British" => 1, + "White: Irish" => 2, + "White: Gypsy/Irish Traveller" => 18, + "White: Other" => 3, + "Mixed: White & Black Caribbean" => 4, + "Mixed: White & Black African" => 5, + "Mixed: White & Asian" => 6, + "Mixed: Other" => 7, + "Asian or Asian British: Indian" => 8, + "Asian or Asian British: Pakistani" => 9, + "Asian or Asian British: Bangladeshi" => 10, + "Asian or Asian British: Chinese" => 15, + "Asian or Asian British: Other" => 11, + "Black: Caribbean" => 12, + "Black: African" => 13, + "Black: Other" => 14, + "Other Ethnic Group: Arab" => 16, + "Other Ethnic Group: Other" => 19, + "Prefer not to say" => 17, + } + end + + def self.homeless + { + "Yes - assessed as homeless by a local authority and owed a homelessness duty. Including if threatened with homelessness within 56 days" => 11, + "Yes - other homelessness" => 7, + "No" => 1, + } + end + + def self.illness + { + "Yes" => 1, + "No" => 2, + "Do not know" => 3, + "Prefer not to say" => 100, + } + end + + def self.leftreg + { + "Yes" => 6, + "No - they left up to 5 years ago" => 4, + "No - they left more than 5 years ago" => 5, + "Prefer not to say" => 3, + } + end + + def self.national + { + "UK national resident in UK" => 1, + "A current or former reserve in the UK Armed Forces (exc. National Service)" => 100, + "UK national returning from residence overseas" => 2, + "Czech Republic" => 3, + "Estonia" => 4, + "Hungary" => 5, + "Latvia" => 6, + "Lithuania" => 7, + "Poland" => 8, + "Slovakia" => 9, + "Bulgaria" => 14, + "Romania" => 15, + "Ireland" => 17, + "Other EU Economic Area (EEA country)" => 11, + "Any other country" => 12, + "Prefer not to say" => 13, + } + end + + def self.pregnancy + { + "Yes" => 1, + "No" => 2, + "Prefer not to say" => 3, + } + end + + def self.previous_tenancy + { + "Owner occupation (private) " => 26, + "Owner occupation (low cost home ownership)" => 27, + "Private sector tenancy" => 3, + "Tied housing or rented with job" => 4, + "Supported housing" => 5, + "Sheltered accomodation" => 8, + "Residential care home" => 9, + "Living with friends or family" => 28, + "Refuge" => 21, + "Hospital" => 10, + "Prison / approved probation hostel" => 29, + "Direct access hostel" => 7, + "Bed & Breakfast" => 14, + "Mobile home / caravan" => 23, + "Any other temporary accommodation" => 18, + "Home Office Asylum Support" => 24, + "Children’s home / foster care" => 13, + "Rough sleeping" => 19, + "Other" => 25, + "Fixed term Local Authority General Needs tenancy" => 30, + "Lifetime Local Authority General Needs tenancy" => 31, + "Fixed term PRP General Needs tenancy" => 32, + "Lifetime PRP General Needs tenancy" => 33, + } + end + + def self.reservist + { + "Yes" => 1, + "No" => 2, + "Prefer not to say" => 3, + } + end + + def self.polar + { + "No" => 0, + "Yes" => 1, + } + end + + def self.polar2 + { + "No" => 2, + "Yes" => 1, + } + end + + def self.tenancy + { + "Fixed term – Secure" => 1, + "Fixed term – Assured Shorthold Tenancy (AST)" => 4, + "Lifetime – Secure" => 100, + "Lifetime – Assured" => 2, + "License agreement" => 5, + "Other" => 3, + } + end + + def self.landlord + { + "This landlord" => 1, + "Another registered provider - includes housing association or local authority" => 2, + } + end + + def self.rsnvac + { + "First let of newbuild property" => 15, + "First let of conversion/rehabilitation/acquired property" => 16, + "First let of leased property" => 17, + "Relet - tenant evicted due to arrears" => 10, + "Relet - tenant evicted due to ASB or other reason" => 11, + "Relet - tenant died (no succession)" => 5, + "Relet - tenant moved to other social housing provider" => 12, + "Relet - tenant abandoned property" => 6, + "Relet - tenant moved to private sector or other accommodation" => 8, + "Relet - to tenant who occupied same property as temporary accommodation" => 9, + "Relet – internal transfer (excluding renewals of a fixed-term tenancy)" => 13, + "Relet – renewal of fixed-term tenancy" => 14, + "Relet – tenant moved to care home" => 18, + "Relet – tenant involved in a succession downsize" => 19, + } + end + + def self.unittype_gn + { + "Flat / maisonette" => 1, + "Bed-sit" => 2, + "House" => 7, + "Bungalow" => 8, + "Shared flat / maisonette" => 4, + "Shared house" => 9, + "Shared bungalow" => 10, + "Other" => 6, + } + end + + def self.incfreq + { + "Weekly" => 1, + "Monthly" => 2, + "Yearly" => 3, + } + end + + def self.benefits + { + "All" => 1, + "Some" => 2, + "None" => 3, + "Do not know" => 4, + } + end + + def self.period + { + "Weekly for 52 weeks" => 1, + "Fortnightly" => 2, + "Four-weekly" => 3, + "Calendar monthly" => 4, + "Weekly for 50 weeks" => 5, + "Weekly for 49 weeks" => 6, + "Weekly for 48 weeks" => 7, + "Weekly for 47 weeks" => 8, + "Weekly for 46 weeks" => 9, + "Weekly for 53 weeks" => 10, + } + end + + def self.latime + { + "Just moved to local authority area" => 1, + "Less than 1 year" => 2, + "1 to 2 years" => 7, + "2 to 3 years" => 8, + "3 to 4 years" => 9, + "4 to 5 years" => 10, + "5 years or more" => 5, + "Do not know" => 6, + } + end +end diff --git a/app/controllers/case_logs_controller.rb b/app/controllers/case_logs_controller.rb index f8bef385a..460dfe71d 100644 --- a/app/controllers/case_logs_controller.rb +++ b/app/controllers/case_logs_controller.rb @@ -107,7 +107,7 @@ private if question_info["type"] == "checkbox" question_info["answer_options"].keys.reject { |x| x.match(/divider/) }.each do |option| - result[option] = question_params.include?(option) + result[option] = question_params.include?(option) ? "Yes" : "No" end else result[question_key] = question_params diff --git a/app/models/case_log.rb b/app/models/case_log.rb index 9c6660052..ac37461da 100644 --- a/app/models/case_log.rb +++ b/app/models/case_log.rb @@ -37,6 +37,7 @@ end class CaseLog < ApplicationRecord include Discard::Model include SoftValidations + include DbEnums default_scope -> { kept } scope :not_completed, -> { where.not(status: "completed") } @@ -47,6 +48,60 @@ class CaseLog < ApplicationRecord enum status: { "not_started" => 0, "in_progress" => 1, "completed" => 2 } + enum ethnic: DbEnums.ethnic + enum national: DbEnums.national, _suffix: true + enum ecstat1: DbEnums.ecstat, _suffix: true + enum ecstat2: DbEnums.ecstat, _suffix: true + enum ecstat3: DbEnums.ecstat, _suffix: true + enum ecstat4: DbEnums.ecstat, _suffix: true + enum ecstat5: DbEnums.ecstat, _suffix: true + enum ecstat6: DbEnums.ecstat, _suffix: true + enum ecstat7: DbEnums.ecstat, _suffix: true + enum ecstat8: DbEnums.ecstat, _suffix: true + enum prevten: DbEnums.previous_tenancy, _suffix: true + enum homeless: DbEnums.homeless, _suffix: true + enum underoccupation_benefitcap: DbEnums.benefitcap, _suffix: true + enum reservist: DbEnums.reservist, _suffix: true + enum leftreg: DbEnums.leftreg, _suffix: true + enum illness: DbEnums.illness, _suffix: true + enum preg_occ: DbEnums.pregnancy, _suffix: true + enum housingneeds_a: DbEnums.polar, _suffix: true + enum housingneeds_b: DbEnums.polar, _suffix: true + enum housingneeds_c: DbEnums.polar, _suffix: true + enum housingneeds_f: DbEnums.polar, _suffix: true + enum housingneeds_g: DbEnums.polar, _suffix: true + enum housingneeds_h: DbEnums.polar, _suffix: true + enum illness_type_1: DbEnums.polar, _suffix: true + enum illness_type_2: DbEnums.polar, _suffix: true + enum illness_type_3: DbEnums.polar, _suffix: true + enum illness_type_4: DbEnums.polar, _suffix: true + enum illness_type_5: DbEnums.polar, _suffix: true + enum illness_type_6: DbEnums.polar, _suffix: true + enum illness_type_7: DbEnums.polar, _suffix: true + enum illness_type_8: DbEnums.polar, _suffix: true + enum illness_type_9: DbEnums.polar, _suffix: true + enum illness_type_10: DbEnums.polar, _suffix: true + enum startertenancy: DbEnums.polar2, _suffix: true + enum tenancy: DbEnums.tenancy, _suffix: true + enum landlord: DbEnums.landlord, _suffix: true + enum rsnvac: DbEnums.rsnvac, _suffix: true + enum unittype_gn: DbEnums.unittype_gn, _suffix: true + enum rp_homeless: DbEnums.polar, _suffix: true + enum rp_insan_unsat: DbEnums.polar, _suffix: true + enum rp_medwel: DbEnums.polar, _suffix: true + enum rp_hardship: DbEnums.polar, _suffix: true + enum rp_dontknow: DbEnums.polar, _suffix: true + enum cbl: DbEnums.polar2, _suffix: true + enum chr: DbEnums.polar2, _suffix: true + enum cap: DbEnums.polar2, _suffix: true + enum wchair: DbEnums.polar2, _suffix: true + enum incfreq: DbEnums.incfreq, _suffix: true + enum benefits: DbEnums.benefits, _suffix: true + enum period: DbEnums.period, _suffix: true + enum layear: DbEnums.latime, _suffix: true + enum lawaitlist: DbEnums.latime, _suffix: true + enum reasonpref: DbEnums.polar2, _suffix: true + AUTOGENERATED_FIELDS = %w[id status created_at updated_at discarded_at].freeze def self.editable_fields @@ -66,20 +121,20 @@ class CaseLog < ApplicationRecord end def weekly_net_income - case net_income_frequency + case incfreq when "Weekly" - net_income + earnings when "Monthly" - ((net_income * 12) / 52.0).round(0) + ((earnings * 12) / 52.0).round(0) when "Yearly" - (net_income / 12.0).round(0) + (earnings / 12.0).round(0) end end def applicable_income_range - return unless person_1_economic_status + return unless ecstat1 - IncomeRange::ALLOWED[person_1_economic_status.to_sym] + IncomeRange::ALLOWED[ecstat1.to_sym] end private @@ -111,33 +166,33 @@ private dynamically_not_required << "other_reason_for_leaving_last_settled_home" end - if net_income.to_i.zero? - dynamically_not_required << "net_income_frequency" + if earnings.to_i.zero? + dynamically_not_required << "incfreq" end - if tenancy_type == "Fixed term – Secure" - dynamically_not_required << "fixed_term_tenancy" + if tenancy == "Fixed term – Secure" + dynamically_not_required << "tenancylength" end unless net_income_in_soft_max_range? || net_income_in_soft_min_range? dynamically_not_required << "override_net_income_validation" end - unless tenancy_type == "Other" - dynamically_not_required << "other_tenancy_type" + unless tenancy == "Other" + dynamically_not_required << "tenancyother" end unless net_income_known == "Yes" - dynamically_not_required << "net_income" - dynamically_not_required << "net_income_frequency" + dynamically_not_required << "earnings" + dynamically_not_required << "incfreq" end - start_range = (household_number_of_other_members || 0) + 2 + start_range = (hhmemb || 0) + 2 (start_range..8).each do |n| - dynamically_not_required << "person_#{n}_age" - dynamically_not_required << "person_#{n}_gender" - dynamically_not_required << "person_#{n}_relationship" - dynamically_not_required << "person_#{n}_economic_status" + dynamically_not_required << "age#{n}" + dynamically_not_required << "sex#{n}" + dynamically_not_required << "relat#{n}" + dynamically_not_required << "ecstat#{n}" end required.delete_if { |key, _value| dynamically_not_required.include?(key) } diff --git a/app/models/form.rb b/app/models/form.rb index ea803e5b6..3eeac8987 100644 --- a/app/models/form.rb +++ b/app/models/form.rb @@ -90,4 +90,21 @@ class Form pages_for_subsection(subsection).keys[current_page_idx - 1] end + + def all_questions + @all_questions ||= all_pages.map { |_page_key, page_value| + page_value["questions"] + }.reduce(:merge) + end + + def get_answer_label(case_log, question_title) + question = all_questions[question_title] + if question["type"] == "checkbox" + answer = [] + question["answer_options"].each { |key, value| case_log[key] == "Yes" ? answer << value : nil } + return answer.join(", ") + end + + case_log[question_title] + end end diff --git a/app/validations/financial_validations.rb b/app/validations/financial_validations.rb index 3567e334d..dd4b58baf 100644 --- a/app/validations/financial_validations.rb +++ b/app/validations/financial_validations.rb @@ -13,25 +13,25 @@ module FinancialValidations EMPLOYED_STATUSES = ["Full-time - 30 hours or more", "Part-time - Less than 30 hours"].freeze def validate_net_income_uc_proportion(record) (1..8).any? do |n| - economic_status = record["person_#{n}_economic_status"] + economic_status = record["ecstat#{n}"] is_employed = EMPLOYED_STATUSES.include?(economic_status) - relationship = record["person_#{n}_relationship"] + relationship = record["relat#{n}"] is_partner_or_main = relationship == "Partner" || (relationship.nil? && economic_status.present?) - if is_employed && is_partner_or_main && record.net_income_uc_proportion == "All" - record.errors.add :net_income_uc_proportion, "income is from Universal Credit, state pensions or benefits cannot be All if the tenant or the partner works part or full time" + if is_employed && is_partner_or_main && record.benefits == "All" + record.errors.add :benefits, "income is from Universal Credit, state pensions or benefits cannot be All if the tenant or the partner works part or full time" end end end def validate_net_income(record) - return unless record.person_1_economic_status && record.weekly_net_income + return unless record.ecstat1 && record.weekly_net_income if record.weekly_net_income > record.applicable_income_range.hard_max - record.errors.add :net_income, "Net income cannot be greater than #{record.applicable_income_range.hard_max} given the tenant's working situation" + record.errors.add :earnings, "Net income cannot be greater than #{record.applicable_income_range.hard_max} given the tenant's working situation" end if record.weekly_net_income < record.applicable_income_range.hard_min - record.errors.add :net_income, "Net income cannot be less than #{record.applicable_income_range.hard_min} given the tenant's working situation" + record.errors.add :earnings, "Net income cannot be less than #{record.applicable_income_range.hard_min} given the tenant's working situation" end end end diff --git a/app/validations/household_validations.rb b/app/validations/household_validations.rb index 0bfa142d5..ca8d887e9 100644 --- a/app/validations/household_validations.rb +++ b/app/validations/household_validations.rb @@ -2,14 +2,14 @@ module HouseholdValidations # Validations methods need to be called 'validate_' to run on model save # or 'validate_' to run on submit as well def validate_reasonable_preference(record) - if record.homelessness == "No" && record.reasonable_preference == "Yes" - record.errors.add :reasonable_preference, "Can not be Yes if Not Homeless immediately prior to this letting has been selected" - elsif record.reasonable_preference == "Yes" - if !record.reasonable_preference_reason_homeless && !record.reasonable_preference_reason_unsatisfactory_housing && !record.reasonable_preference_reason_medical_grounds && !record.reasonable_preference_reason_avoid_hardship && !record.reasonable_preference_reason_do_not_know + if record.homeless == "No" && record.reasonpref == "Yes" + record.errors.add :reasonpref, "Can not be Yes if Not Homeless immediately prior to this letting has been selected" + elsif record.reasonpref == "Yes" + if !record.rp_homeless && !record.rp_insan_unsat && !record.rp_medwel && !record.rp_hardship && !record.rp_dontknow record.errors.add :reasonable_preference_reason, "If reasonable preference is Yes, a reason must be given" end - elsif record.reasonable_preference == "No" - if record.reasonable_preference_reason_homeless || record.reasonable_preference_reason_unsatisfactory_housing || record.reasonable_preference_reason_medical_grounds || record.reasonable_preference_reason_avoid_hardship || record.reasonable_preference_reason_do_not_know + elsif record.reasonpref == "No" + if record.rp_homeless || record.rp_insan_unsat || record.rp_medwel || record.rp_hardship || record.rp_dontknow record.errors.add :reasonable_preference_reason, "If reasonable preference is No, no reasons should be given" end end @@ -20,34 +20,34 @@ module HouseholdValidations end def validate_reason_for_leaving_last_settled_home(record) - if record.reason_for_leaving_last_settled_home == "Do not know" && record.benefit_cap_spare_room_subsidy != "Do not know" - record.errors.add :benefit_cap_spare_room_subsidy, "must be do not know if tenant’s main reason for leaving is do not know" + if record.reason_for_leaving_last_settled_home == "Do not know" && record.underoccupation_benefitcap != "Do not know" + record.errors.add :underoccupation_benefitcap, "must be do not know if tenant’s main reason for leaving is do not know" end end def validate_armed_forces_injured(record) - if (record.armed_forces == "Yes - a regular" || record.armed_forces == "Yes - a reserve") && record.armed_forces_injured.blank? - record.errors.add :armed_forces_injured, "You must answer the armed forces injury question if the tenant has served in the armed forces" + if (record.armed_forces == "Yes - a regular" || record.armed_forces == "Yes - a reserve") && record.reservist.blank? + record.errors.add :reservist, "You must answer the armed forces injury question if the tenant has served in the armed forces" end - if (record.armed_forces == "No" || record.armed_forces == "Prefer not to say") && record.armed_forces_injured.present? - record.errors.add :armed_forces_injured, "You must not answer the armed forces injury question if the tenant has not served in the armed forces or prefer not to say was chosen" + if (record.armed_forces == "No" || record.armed_forces == "Prefer not to say") && record.reservist.present? + record.errors.add :reservist, "You must not answer the armed forces injury question if the tenant has not served in the armed forces or prefer not to say was chosen" end end def validate_armed_forces_active_response(record) - if record.armed_forces == "Yes - a regular" && record.armed_forces_active.blank? - record.errors.add :armed_forces_active, "You must answer the armed forces active question if the tenant has served as a regular in the armed forces" + if record.armed_forces == "Yes - a regular" && record.leftreg.blank? + record.errors.add :leftreg, "You must answer the armed forces active question if the tenant has served as a regular in the armed forces" end - if record.armed_forces != "Yes - a regular" && record.armed_forces_active.present? - record.errors.add :armed_forces_active, "You must not answer the armed forces active question if the tenant has not served as a regular in the armed forces" + if record.armed_forces != "Yes - a regular" && record.leftreg.present? + record.errors.add :leftreg, "You must not answer the armed forces active question if the tenant has not served as a regular in the armed forces" end end def validate_household_pregnancy(record) - if (record.pregnancy == "Yes" || record.pregnancy == "Prefer not to say") && !women_of_child_bearing_age_in_household(record) - record.errors.add :pregnancy, "You must answer no as there are no female tenants aged 16-50 in the property" + if (record.preg_occ == "Yes" || record.preg_occ == "Prefer not to say") && !women_of_child_bearing_age_in_household(record) + record.errors.add :preg_occ, "You must answer no as there are no female tenants aged 16-50 in the property" end end @@ -63,10 +63,10 @@ module HouseholdValidations end def validate_person_1_age(record) - return unless record.person_1_age + return unless record.age1 - if !record.person_1_age.is_a?(Integer) || record.person_1_age < 16 || record.person_1_age > 120 - record.errors.add "person_1_age", "Tenant age must be an integer between 16 and 120" + if !record.age1.is_a?(Integer) || record.age1 < 16 || record.age1 > 120 + record.errors.add "age1", "Tenant age must be an integer between 16 and 120" end end @@ -75,17 +75,17 @@ module HouseholdValidations end def validate_shared_housing_rooms(record) - unless record.property_unit_type.nil? - if record.property_unit_type == "Bed-sit" && record.property_number_of_bedrooms != 1 - record.errors.add :property_unit_type, "A bedsit can only have one bedroom" + unless record.unittype_gn.nil? + if record.unittype_gn == "Bed-sit" && record.beds != 1 + record.errors.add :unittype_gn, "A bedsit can only have one bedroom" end - if !record.household_number_of_other_members.nil? && record.household_number_of_other_members.positive? && (record.property_unit_type.include?("Shared") && !record.property_number_of_bedrooms.to_i.between?(1, 7)) - record.errors.add :property_unit_type, "A shared house must have 1 to 7 bedrooms" + if !record.hhmemb.nil? && record.hhmemb.positive? && (record.unittype_gn.include?("Shared") && !record.beds.to_i.between?(1, 7)) + record.errors.add :unittype_gn, "A shared house must have 1 to 7 bedrooms" end - if record.property_unit_type.include?("Shared") && !record.property_number_of_bedrooms.to_i.between?(1, 3) - record.errors.add :property_unit_type, "A shared house with less than two tenants must have 1 to 3 bedrooms" + if record.unittype_gn.include?("Shared") && !record.beds.to_i.between?(1, 3) + record.errors.add :unittype_gn, "A shared house with less than two tenants must have 1 to 3 bedrooms" end end end @@ -94,72 +94,72 @@ private def women_of_child_bearing_age_in_household(record) (1..8).any? do |n| - next if record["person_#{n}_gender"].nil? || record["person_#{n}_age"].nil? + next if record["sex#{n}"].nil? || record["age#{n}"].nil? - record["person_#{n}_gender"] == "Female" && record["person_#{n}_age"] >= 16 && record["person_#{n}_age"] <= 50 + record["sex#{n}"] == "Female" && record["age#{n}"] >= 16 && record["age#{n}"] <= 50 end end def validate_person_age(record, person_num) - age = record.public_send("person_#{person_num}_age") + age = record.public_send("age#{person_num}") return unless age if !age.is_a?(Integer) || age < 1 || age > 120 - record.errors.add "person_#{person_num}_age".to_sym, "Tenant age must be an integer between 0 and 120" + record.errors.add "age#{person_num}".to_sym, "Tenant age must be an integer between 0 and 120" end end def validate_person_age_matches_economic_status(record, person_num) - age = record.public_send("person_#{person_num}_age") - economic_status = record.public_send("person_#{person_num}_economic_status") + age = record.public_send("age#{person_num}") + economic_status = record.public_send("ecstat#{person_num}") return unless age && economic_status if age > 70 && economic_status != "Retired" - record.errors.add "person_#{person_num}_economic_status", "Tenant #{person_num} must be retired if over 70" + record.errors.add "ecstat#{person_num}", "Tenant #{person_num} must be retired if over 70" end if age < 16 && economic_status != "Child under 16" - record.errors.add "person_#{person_num}_economic_status", "Tenant #{person_num} economic status must be Child under 16 if their age is under 16" + record.errors.add "ecstat#{person_num}", "Tenant #{person_num} economic status must be Child under 16 if their age is under 16" end end def validate_person_age_matches_relationship(record, person_num) - age = record.public_send("person_#{person_num}_age") - relationship = record.public_send("person_#{person_num}_relationship") + age = record.public_send("age#{person_num}") + relationship = record.public_send("relat#{person_num}") return unless age && relationship if age < 16 && relationship != "Child - includes young adult and grown-up" - record.errors.add "person_#{person_num}_relationship", "Tenant #{person_num}'s relationship to tenant 1 must be Child if their age is under 16" + record.errors.add "relat#{person_num}", "Tenant #{person_num}'s relationship to tenant 1 must be Child if their age is under 16" end end def validate_person_age_and_relationship_matches_economic_status(record, person_num) - age = record.public_send("person_#{person_num}_age") - economic_status = record.public_send("person_#{person_num}_economic_status") - relationship = record.public_send("person_#{person_num}_relationship") + age = record.public_send("age#{person_num}") + economic_status = record.public_send("ecstat#{person_num}") + relationship = record.public_send("relat#{person_num}") return unless age && economic_status && relationship if age >= 16 && age <= 19 && relationship == "Child - includes young adult and grown-up" && (economic_status != "Full-time student" || economic_status != "Prefer not to say") - record.errors.add "person_#{person_num}_economic_status", "If age is between 16 and 19 - tenant #{person_num} must be a full time student or prefer not to say." + record.errors.add "ecstat#{person_num}", "If age is between 16 and 19 - tenant #{person_num} must be a full time student or prefer not to say." end end def validate_person_age_and_gender_match_economic_status(record, person_num) - age = record.public_send("person_#{person_num}_age") - gender = record.public_send("person_#{person_num}_gender") - economic_status = record.public_send("person_#{person_num}_economic_status") + age = record.public_send("age#{person_num}") + gender = record.public_send("sex#{person_num}") + economic_status = record.public_send("ecstat#{person_num}") return unless age && economic_status && gender if gender == "Male" && economic_status == "Retired" && age < 65 - record.errors.add "person_#{person_num}_age", "Male tenant who is retired must be 65 or over" + record.errors.add "age#{person_num}", "Male tenant who is retired must be 65 or over" end if gender == "Female" && economic_status == "Retired" && age < 60 - record.errors.add "person_#{person_num}_age", "Female tenant who is retired must be 60 or over" + record.errors.add "age#{person_num}", "Female tenant who is retired must be 60 or over" end end def validate_partner_count(record) # TODO: probably need to keep track of which specific field is wrong so we can highlight it in the UI - partner_count = (2..8).count { |n| record.public_send("person_#{n}_relationship") == "Partner" } + partner_count = (2..8).count { |n| record.public_send("relat#{n}") == "Partner" } if partner_count > 1 record.errors.add :base, "Number of partners cannot be greater than 1" end diff --git a/app/validations/property_validations.rb b/app/validations/property_validations.rb index 65dde4a08..53df3e62b 100644 --- a/app/validations/property_validations.rb +++ b/app/validations/property_validations.rb @@ -2,8 +2,8 @@ module PropertyValidations # Validations methods need to be called 'validate_' to run on model save # or 'validate_' to run on submit as well def validate_property_number_of_times_relet(record) - if record.property_number_of_times_relet && !/^[1-9]$|^0[1-9]$|^1[0-9]$|^20$/.match?(record.property_number_of_times_relet.to_s) - record.errors.add :property_number_of_times_relet, "Property number of times relet must be between 0 and 20" + if record.offered && !/^[1-9]$|^0[1-9]$|^1[0-9]$|^20$/.match?(record.offered.to_s) + record.errors.add :offered, "Property number of times relet must be between 0 and 20" end end end diff --git a/app/validations/soft_validations.rb b/app/validations/soft_validations.rb index b62490130..e9ce6d12b 100644 --- a/app/validations/soft_validations.rb +++ b/app/validations/soft_validations.rb @@ -18,12 +18,12 @@ private if net_income_in_soft_min_range? net_income_errors["override_net_income_validation"] = OpenStruct.new( message: "Net income is lower than expected based on the main tenant's working situation. Are you sure this is correct?", - hint_text: "This is based on the tenant's work situation: #{person_1_economic_status}", + hint_text: "This is based on the tenant's work situation: #{ecstat1}", ) elsif net_income_in_soft_max_range? net_income_errors["override_net_income_validation"] = OpenStruct.new( message: "Net income is higher than expected based on the main tenant's working situation. Are you sure this is correct?", - hint_text: "This is based on the tenant's work situation: #{person_1_economic_status}", + hint_text: "This is based on the tenant's work situation: #{ecstat1}", ) else update_column(:override_net_income_validation, nil) @@ -32,13 +32,13 @@ private end def net_income_in_soft_max_range? - return unless weekly_net_income && person_1_economic_status + return unless weekly_net_income && ecstat1 weekly_net_income.between?(applicable_income_range.soft_max, applicable_income_range.hard_max) end def net_income_in_soft_min_range? - return unless weekly_net_income && person_1_economic_status + return unless weekly_net_income && ecstat1 weekly_net_income.between?(applicable_income_range.soft_min, applicable_income_range.hard_min) end diff --git a/app/validations/tenancy_validations.rb b/app/validations/tenancy_validations.rb index 5738bc2a3..32ff8e2b0 100644 --- a/app/validations/tenancy_validations.rb +++ b/app/validations/tenancy_validations.rb @@ -2,20 +2,20 @@ module TenancyValidations # Validations methods need to be called 'validate_' to run on model save # or 'validate_' to run on submit as well def validate_fixed_term_tenancy(record) - is_present = record.fixed_term_tenancy.present? - is_in_range = record.fixed_term_tenancy.to_i.between?(2, 99) - is_secure = record.tenancy_type == "Fixed term – Secure" - is_ast = record.tenancy_type == "Fixed term – Assured Shorthold Tenancy (AST)" + is_present = record.tenancylength.present? + is_in_range = record.tenancylength.to_i.between?(2, 99) + is_secure = record.tenancy == "Fixed term – Secure" + is_ast = record.tenancy == "Fixed term – Assured Shorthold Tenancy (AST)" conditions = [ { condition: !(is_secure || is_ast) && is_present, error: "You must only answer the fixed term tenancy length question if the tenancy type is fixed term" }, { condition: is_ast && !is_in_range, error: "Fixed term – Assured Shorthold Tenancy (AST) should be between 2 and 99 years" }, { condition: is_secure && (!is_in_range && is_present), error: "Fixed term – Secure should be between 2 and 99 years or not specified" }, ] - conditions.each { |condition| condition[:condition] ? (record.errors.add :fixed_term_tenancy, condition[:error]) : nil } + conditions.each { |condition| condition[:condition] ? (record.errors.add :tenancylength, condition[:error]) : nil } end def validate_other_tenancy_type(record) - validate_other_field(record, "tenancy_type", "other_tenancy_type") + validate_other_field(record, "tenancy", "tenancyother") end end diff --git a/app/views/form/_check_answers_table.html.erb b/app/views/form/_check_answers_table.html.erb index 9025cf42d..eaa54075a 100644 --- a/app/views/form/_check_answers_table.html.erb +++ b/app/views/form/_check_answers_table.html.erb @@ -4,7 +4,7 @@ <%= question_info["check_answer_label"].to_s.present? ? question_info["check_answer_label"].to_s : question_info["header"].to_s%>
- <%= @case_log[question_title] %> + <%= form.get_answer_label(@case_log, question_title) %>
<%= create_update_answer_link(@case_log[question_title], @case_log.id, page)%> diff --git a/app/views/form/_checkbox_question.html.erb b/app/views/form/_checkbox_question.html.erb index 1d9c548e8..edb6ac74c 100644 --- a/app/views/form/_checkbox_question.html.erb +++ b/app/views/form/_checkbox_question.html.erb @@ -8,7 +8,7 @@ <% else %> <%= f.govuk_check_box question_key, key, label: { text: val }, - checked: f.object.send(key), + checked: @case_log[key] == "Yes", **stimulus_html_attributes(question) %> <% end %> diff --git a/app/views/form/check_answers.html.erb b/app/views/form/check_answers.html.erb index f5b0fe93e..49ebeda0f 100644 --- a/app/views/form/check_answers.html.erb +++ b/app/views/form/check_answers.html.erb @@ -6,7 +6,7 @@ <% form.pages_for_subsection(subsection).each do |page, page_info| %> <% page_info["questions"].each do |question_title, question_info| %> <% if total_questions(subsection, @case_log, form).include?(question_title) %> - <%= render partial: 'form/check_answers_table', locals: { question_title: question_title, question_info: question_info, case_log: @case_log, page: page } %> + <%= render partial: 'form/check_answers_table', locals: { question_title: question_title, question_info: question_info, case_log: @case_log, page: page, form: form } %> <%end %> <%end %> <% end %> diff --git a/config/forms/2021_2022.json b/config/forms/2021_2022.json index 406f5a69f..498e064b2 100644 --- a/config/forms/2021_2022.json +++ b/config/forms/2021_2022.json @@ -196,11 +196,11 @@ } } }, - "person_1_age": { + "age1": { "header": "", "description": "", "questions": { - "person_1_age": { + "age1": { "check_answer_label": "Tenant's age", "header": "What is the tenant's age?", "hint_text": "", @@ -211,11 +211,11 @@ } } }, - "person_1_gender": { + "sex1": { "header": "", "description": "", "questions": { - "person_1_gender": { + "sex1": { "check_answer_label": "Tenant's gender", "header": "Which of these best describes the tenant's gender identity?", "hint_text": "", @@ -233,7 +233,7 @@ "header": "", "description": "", "questions": { - "tenant_ethnic_group": { + "ethnic": { "check_answer_label": "Ethnicity", "header": "What is the tenant's ethnic group?", "hint_text": "", @@ -266,7 +266,7 @@ "header": "", "description": "", "questions": { - "tenant_nationality": { + "national": { "check_answer_label": "Nationality", "header": "What is the tenant's nationality?", "hint_text": "", @@ -296,7 +296,7 @@ "header": "", "description": "", "questions": { - "person_1_economic_status": { + "ecstat1": { "check_answer_label": "Work", "header": "Which of these best describes the tenant's working situation?", "hint_text": "", @@ -321,7 +321,7 @@ "header": "", "description": "", "questions": { - "household_number_of_other_members": { + "hhmemb": { "check_answer_label": "Number of Other Household Members", "header": "How many other people are there in the household?", "hint_text": "The maximum number of others is 7", @@ -330,37 +330,37 @@ "max": 7, "step": 1, "conditional_for": { - "person_2_relationship": ">0", - "person_2_age": ">0", - "person_2_gender": ">0", - "person_2_economic_status": ">0", - "person_3_relationship": ">1", - "person_3_age": ">1", - "person_3_gender": ">1", - "person_3_economic_status": ">1", - "person_4_relationship": ">2", - "person_4_age": ">2", - "person_4_gender": ">2", - "person_4_economic_status": ">2", - "person_5_relationship": ">3", - "person_5_age": ">3", - "person_5_gender": ">3", - "person_5_economic_status": ">3", - "person_6_relationship": ">4", - "person_6_age": ">4", - "person_6_gender": ">4", - "person_6_economic_status": ">4", - "person_7_relationship": ">5", - "person_7_age": ">5", - "person_7_gender": ">5", - "person_7_economic_status": ">5", - "person_8_relationship": ">6", - "person_8_age": ">6", - "person_8_gender": ">6", - "person_8_economic_status": ">6" + "relat2": ">0", + "age2": ">0", + "sex2": ">0", + "ecstat2": ">0", + "relat3": ">1", + "age3": ">1", + "sex3": ">1", + "ecstat3": ">1", + "relat4": ">2", + "age4": ">2", + "sex4": ">2", + "ecstat4": ">2", + "relat5": ">3", + "age5": ">3", + "sex5": ">3", + "ecstat5": ">3", + "relat6": ">4", + "age6": ">4", + "sex6": ">4", + "ecstat6": ">4", + "relat7": ">5", + "age7": ">5", + "sex7": ">5", + "ecstat7": ">5", + "relat8": ">6", + "age8": ">6", + "sex8": ">6", + "ecstat8": ">6" } }, - "person_2_relationship": { + "relat2": { "check_answer_label": "Person 2's relationship to lead tenant", "header": "What's person 2's relationship to lead tenant", "hint_text": "", @@ -372,7 +372,7 @@ "3": "Prefer not to say" } }, - "person_2_age": { + "age2": { "check_answer_label": "Person 2's age", "header": "What's person 2's age", "hint_text": "", @@ -381,7 +381,7 @@ "max": 150, "step": 1 }, - "person_2_gender": { + "sex2": { "check_answer_label": "Person 2's gender", "header": "Which of these best describes person 2's gender identity?", "hint_text": "", @@ -393,7 +393,7 @@ "3": "Prefer not to say" } }, - "person_2_economic_status": { + "ecstat2": { "check_answer_label": "Person 2's Work", "header": "Which of these best describes person 2's working situation?", "hint_text": "", @@ -412,7 +412,7 @@ "10": "Prefer not to say" } }, - "person_3_relationship": { + "relat3": { "check_answer_label": "Person 3's relationship to lead tenant", "header": "What's person 3's relationship to lead tenant", "hint_text": "", @@ -424,7 +424,7 @@ "3": "Prefer not to say" } }, - "person_3_age": { + "age3": { "check_answer_label": "Person 3's age", "header": "What's person 3's age", "hint_text": "", @@ -433,7 +433,7 @@ "max": 150, "step": 1 }, - "person_3_gender": { + "sex3": { "check_answer_label": "Person 3's gender", "header": "Which of these best describes person 3's gender identity?", "hint_text": "", @@ -445,7 +445,7 @@ "3": "Prefer not to say" } }, - "person_3_economic_status": { + "ecstat3": { "check_answer_label": "Person 3's Work", "header": "Which of these best describes person 3's working situation?", "hint_text": "", @@ -464,7 +464,7 @@ "10": "Prefer not to say" } }, - "person_4_relationship": { + "relat4": { "check_answer_label": "Person 4's relationship to lead tenant", "header": "What's person 4's relationship to lead tenant", "hint_text": "", @@ -476,7 +476,7 @@ "3": "Prefer not to say" } }, - "person_4_age": { + "age4": { "check_answer_label": "Person 4's age", "header": "What's person 4's age", "hint_text": "", @@ -485,7 +485,7 @@ "max": 150, "step": 1 }, - "person_4_gender": { + "sex4": { "check_answer_label": "Person 4's gender", "header": "Which of these best describes person 4's gender identity?", "hint_text": "", @@ -497,7 +497,7 @@ "3": "Prefer not to say" } }, - "person_4_economic_status": { + "ecstat4": { "check_answer_label": "Person 4's Work", "header": "Which of these best describes person 4's working situation?", "hint_text": "", @@ -516,7 +516,7 @@ "10": "Prefer not to say" } }, - "person_5_relationship": { + "relat5": { "check_answer_label": "Person 5's relationship to lead tenant", "header": "What's person 5's relationship to lead tenant", "hint_text": "", @@ -528,7 +528,7 @@ "3": "Prefer not to say" } }, - "person_5_age": { + "age5": { "check_answer_label": "Person 5's age", "header": "What's person 5's age", "hint_text": "", @@ -537,7 +537,7 @@ "max": 150, "step": 1 }, - "person_5_gender": { + "sex5": { "check_answer_label": "Person 5's gender", "header": "Which of these best describes person 5's gender identity?", "hint_text": "", @@ -549,7 +549,7 @@ "3": "Prefer not to say" } }, - "person_5_economic_status": { + "ecstat5": { "check_answer_label": "Person 5's Work", "header": "Which of these best describes person 5's working situation?", "hint_text": "", @@ -568,7 +568,7 @@ "10": "Prefer not to say" } }, - "person_6_relationship": { + "relat6": { "check_answer_label": "Person 6's relationship to lead tenant", "header": "What's person 6's relationship to lead tenant", "hint_text": "", @@ -580,7 +580,7 @@ "3": "Prefer not to say" } }, - "person_6_age": { + "age6": { "check_answer_label": "Person 6's age", "header": "What's person 6's age", "hint_text": "", @@ -589,7 +589,7 @@ "max": 150, "step": 1 }, - "person_6_gender": { + "sex6": { "check_answer_label": "Person 6's gender", "header": "Which of these best describes person 6's gender identity?", "hint_text": "", @@ -601,7 +601,7 @@ "3": "Prefer not to say" } }, - "person_6_economic_status": { + "ecstat6": { "check_answer_label": "Person 6's Work", "header": "Which of these best describes person 6's working situation?", "hint_text": "", @@ -620,7 +620,7 @@ "10": "Prefer not to say" } }, - "person_7_relationship": { + "relat7": { "check_answer_label": "Person 7's relationship to lead tenant", "header": "What's person 7's relationship to lead tenant", "hint_text": "", @@ -632,7 +632,7 @@ "3": "Prefer not to say" } }, - "person_7_age": { + "age7": { "check_answer_label": "Person 7's age", "header": "What's person 7's age", "hint_text": "", @@ -641,7 +641,7 @@ "max": 150, "step": 1 }, - "person_7_gender": { + "sex7": { "check_answer_label": "Person 7's gender", "header": "Which of these best describes person 7's gender identity?", "hint_text": "", @@ -653,7 +653,7 @@ "3": "Prefer not to say" } }, - "person_7_economic_status": { + "ecstat7": { "check_answer_label": "Person 7's Work", "header": "Which of these best describes person 7's working situation?", "hint_text": "", @@ -672,7 +672,7 @@ "10": "Prefer not to say" } }, - "person_8_relationship": { + "relat8": { "check_answer_label": "Person 8's relationship to lead tenant", "header": "What's person 8's relationship to lead tenant", "hint_text": "", @@ -684,7 +684,7 @@ "3": "Prefer not to say" } }, - "person_8_age": { + "age8": { "check_answer_label": "Person 8's age", "header": "What's person 8's age", "hint_text": "", @@ -693,7 +693,7 @@ "max": 150, "step": 1 }, - "person_8_gender": { + "sex8": { "check_answer_label": "Person 8's gender", "header": "Which of these best describes person 8's gender identity?", "hint_text": "", @@ -705,7 +705,7 @@ "3": "Prefer not to say" } }, - "person_8_economic_status": { + "ecstat8": { "check_answer_label": "Person 8's Work", "header": "Which of these best describes person 8's working situation?", "hint_text": "", @@ -735,7 +735,7 @@ "header": "", "description": "", "questions": { - "previous_housing_situation": { + "prevten": { "header": "What was the tenant’s housing situation immediately before this letting?", "hint_text": "", "type": "radio", @@ -771,7 +771,7 @@ "header": "", "description": "", "questions": { - "homelessness": { + "homeless": { "header": "Did the tenant experience homelessness immediately before this letting?", "hint_text": "", "type": "radio", @@ -836,7 +836,7 @@ "hint_text": "", "type": "text" }, - "benefit_cap_spare_room_subsidy": { + "underoccupation_benefitcap": { "header": "Was the reason for leaving because of the benefit cap or removal of the spare room subsidy?", "hint_text": "", "type": "radio", @@ -872,11 +872,11 @@ "3": "Prefer not to say" }, "conditional_for": { - "armed_forces_active": ["Yes - a regular", "Yes - a reserve"], - "armed_forces_injured": ["Yes - a regular", "Yes - a reserve"] + "leftreg": ["Yes - a regular", "Yes - a reserve"], + "reservist": ["Yes - a regular", "Yes - a reserve"] } }, - "armed_forces_active": { + "leftreg": { "header": "Are they still serving?", "hint_text": "", "type": "radio", @@ -888,7 +888,7 @@ "3": "Prefer not to say" } }, - "armed_forces_injured": { + "reservist": { "header": "Were they seriously injured or ill as a result of their service?", "hint_text": "", "type": "radio", @@ -917,7 +917,7 @@ "header": "", "description": "", "questions": { - "medical_conditions": { + "illness": { "header": "Does anyone in the household have any of the following that they expect to last for 12 months or more:
  • Physical Condition
  • Mental Health Condition
  • Other Illness
", "hint_text": "", "type": "radio", @@ -935,7 +935,7 @@ "header": "", "description": "", "questions": { - "pregnancy": { + "preg_occ": { "header": "Is anyone in the household pregnant?", "hint_text": "", "type": "radio", @@ -958,13 +958,13 @@ "type": "checkbox", "check_answer_label": "Disability requirements", "answer_options": { - "accessibility_requirements_fully_wheelchair_accessible_housing": "Fully wheelchair accessible housing", - "accessibility_requirements_wheelchair_access_to_essential_rooms": "Wheelchair access to essential rooms", - "accessibility_requirements_level_access_housing": "Level access housing", - "accessibility_requirements_other_disability_requirements": "Other disability requirements", - "accessibility_requirements_no_disability_requirements": "No disability requirements", + "housingneeds_a": "Fully wheelchair accessible housing", + "housingneeds_b": "Wheelchair access to essential rooms", + "housingneeds_c": "Level access housing", + "housingneeds_f": "Other disability requirements", + "housingneeds_g": "No disability requirements", "divider_a": true, - "accessibility_requirements_do_not_know": "Do not know", + "housingneeds_h": "Do not know", "divider_b": true, "accessibility_requirements_prefer_not_to_say": "Prefer not to say" } @@ -981,16 +981,16 @@ "type": "checkbox", "check_answer_label": "Conditions or illnesses", "answer_options": { - "condition_effects_vision": "Vision - such as blindness or partial sight", - "condition_effects_hearing": "Hearing - such as deafness or partial hearing", - "condition_effects_mobility": "Mobility - such as walking short distances or climbing stairs", - "condition_effects_dexterity": "Dexterity - such as lifting and carrying objects or using a keyboard", - "condition_effects_stamina": "Stamina or breathing or fatigue", - "condition_effects_learning": "Learning or understanding or concentrating", - "condition_effects_memory": "Memory", - "condition_effects_mental_health": "Mental health - such as depression, anxiety, schizophrenia or bipolar", - "condition_effects_social_or_behavioral": "Socially or behaviourally - such as those associated with autism spectral disorder (ASD) including Aspergers’ or attention deficit hyperactivity disorder (ADHD))", - "condition_effects_other": "Other", + "illness_type_1": "Vision - such as blindness or partial sight", + "illness_type_2": "Hearing - such as deafness or partial hearing", + "illness_type_3": "Mobility - such as walking short distances or climbing stairs", + "illness_type_4": "Dexterity - such as lifting and carrying objects or using a keyboard", + "illness_type_8": "Stamina or breathing or fatigue", + "illness_type_5": "Learning or understanding or concentrating", + "illness_type_6": "Memory", + "illness_type_7": "Mental health - such as depression, anxiety, schizophrenia or bipolar", + "illness_type_9": "Socially or behaviourally - such as those associated with autism spectral disorder (ASD) including Aspergers’ or attention deficit hyperactivity disorder (ADHD))", + "illness_type_10": "Other", "divider": true, "condition_effects_prefer_not_to_say": "Prefer not to say" } @@ -1023,7 +1023,7 @@ "header": "", "description": "", "questions": { - "tenancy_start_date": { + "startdate": { "check_answer_label": "When is the tenancy start date?", "header": "What is the tenancy start date?", "hint_text": "For example, 27 3 2007", @@ -1035,7 +1035,7 @@ "header": "", "description": "", "questions": { - "starter_tenancy": { + "startertenancy": { "check_answer_label": "Is this a starter or introductory tenancy?", "header": "Is this a starter tenancy?", "hint_text": "", @@ -1051,7 +1051,7 @@ "header": "", "description": "", "questions": { - "fixed_term_tenancy": { + "tenancylength": { "check_answer_label": "If the main tenancy is a fixed term tenancy, please provide the length of the fixed term (to the nearest year) excluding any starter/introductory period", "header": "If fixed-term, what is the length of the fixed-term tenancy after any starter period?", "hint_text": "To the nearest year", @@ -1066,7 +1066,7 @@ "header": "", "description": "", "questions": { - "tenancy_type": { + "tenancy": { "check_answer_label": "Type of main tenancy (after any starter/introductory period)", "header": "What is the type of tenancy after the starter period has ended?", "hint_text": "", @@ -1083,7 +1083,7 @@ "other_tenancy_type": ["Other"] } }, - "other_tenancy_type": { + "tenancyother": { "header": "Please state the tenancy type", "hint_text": "", "type": "text" @@ -1094,7 +1094,7 @@ "header": "", "description": "", "questions": { - "letting_type": { + "lettype": { "check_answer_label": "Type of letting", "header": "Which type of letting is this?", "hint_text": "", @@ -1114,7 +1114,7 @@ "header": "", "description": "", "questions": { - "letting_provider": { + "landlord": { "check_answer_label": "Provider", "header": "Who is the letting provider?", "hint_text": "", @@ -1490,7 +1490,7 @@ "header": "", "description": "", "questions": { - "property_vacancy_reason": { + "rsnvac": { "check_answer_label": "What is the reason for the property vacancy?", "header": "What is the reason for the property vacancy?", "hint_text": "", @@ -1530,7 +1530,7 @@ "header": "", "description": "", "questions": { - "property_unit_type": { + "unittype_gn": { "check_answer_label": "Which type of unit is the property?", "header": "Which type of unit is the property?", "hint_text": "", @@ -1552,7 +1552,7 @@ "header": "", "description": "", "questions": { - "property_number_of_bedrooms": { + "beds": { "check_answer_label": "How many bedrooms are there in the property?", "header": "How many bedrooms are there in the property?", "hint_text": "If shared accommodation, enter number of bedrooms occupied by this household; a bed-sit has 1 bedroom", @@ -1592,7 +1592,7 @@ "header": "", "description": "", "questions": { - "property_number_of_times_relet": { + "offered": { "check_answer_label": "How many times has this unit been previously offered since becoming available for relet since the last tenancy ended or as a first let?", "header": "How many times has this unit been previously offered since becoming available for relet since the last tenancy ended or as a first let? ", "hint_text": "For an Affordable Rent or Intermediate Rent Letting, only include number of offers as that type. For a property let at the first attempt enter '0' ", @@ -1607,7 +1607,7 @@ "header": "", "description": "", "questions": { - "property_wheelchair_accessible": { + "wchair": { "check_answer_label": "Is property built or adapted to wheelchair user standards?", "header": "Is property built or adapted to wheelchair user standards?", "hint_text": "", @@ -1644,11 +1644,11 @@ "2": "Tenant prefers not to say" }, "conditional_for": { - "net_income": ["Yes"], - "net_income_frequency": ["Yes"] + "earnings": ["Yes"], + "incfreq": ["Yes"] } }, - "net_income": { + "earnings": { "check_answer_label": "Income", "header": "What is the tenant’s /and partner’s combined income after tax?", "hint_text": "", @@ -1656,7 +1656,7 @@ "min": 0, "step": "1" }, - "net_income_frequency": { + "incfreq": { "check_answer_label": "Income Frequency", "header": "How often do they receive this income?", "hint_text": "", @@ -1682,7 +1682,7 @@ "header": "", "description": "", "questions": { - "net_income_uc_proportion": { + "benefits": { "check_answer_label": "Benefits as a proportion of income", "header": "How much of the tenant’s income is from Universal Credit, state pensions or benefits?", "hint_text": "", @@ -1701,7 +1701,7 @@ "description": "", "questions": { "housing_benefit": { - "check_answer_label": "Universal Credit & Housing Benefit\t", + "check_answer_label": "Universal Credit & Housing Benefit", "header": "Is the tenant likely to be in receipt of any of these housing-related benefits?", "hint_text": "", "type": "radio", @@ -1726,7 +1726,7 @@ "header": "", "description": "", "questions": { - "rent_frequency": { + "period": { "check_answer_label": "Rent Period", "header": "Which period are rent and other charges due?", "hint_text": "", @@ -1744,47 +1744,67 @@ "9": "Weekly for 53 weeks" } }, - "basic_rent": { + "brent": { "check_answer_label": "Basic Rent", "header": "What is the basic rent?", "hint_text": "Eligible for housing benefit or Universal Credit", "type": "numeric", "min": 0, "step": 1, - "fields-to-add": ["basic_rent", "service_charge", "personal_service_charge", "support_charge"], - "result-field": "total_charge" + "fields-to-add": [ + "brent", + "scharge", + "pscharge", + "supcharg" + ], + "result-field": "tcharge" }, - "service_charge": { + "scharge": { "check_answer_label": "Service Charge", "header": "What is the service charge?", "hint_text": "Eligible for housing benefit or Universal Credit", "type": "numeric", "min": 0, "step": 1, - "fields-to-add": ["basic_rent", "service_charge", "personal_service_charge", "support_charge"], - "result-field": "total_charge" + "fields-to-add": [ + "brent", + "scharge", + "pscharge", + "supcharg" + ], + "result-field": "tcharge" }, - "personal_service_charge": { + "pscharge": { "check_answer_label": "Personal Service Charge", "header": "What is the personal service charge?", "hint_text": "Not eligible for housing benefit or Universal Credit. For example, hot water excluding water rates.", "type": "numeric", "min": 0, "step": 1, - "fields-to-add": ["basic_rent", "service_charge", "personal_service_charge", "support_charge"], - "result-field": "total_charge" + "fields-to-add": [ + "brent", + "scharge", + "pscharge", + "supcharg" + ], + "result-field": "tcharge" }, - "support_charge": { + "supcharg": { "check_answer_label": "Support Charge", "header": "What is the support charge?", "hint_text": "This is to fund housing-related support services included in the tenancy agreement", "type": "numeric", "min": 0, "step": 1, - "fields-to-add": ["basic_rent", "service_charge", "personal_service_charge", "support_charge"], - "result-field": "total_charge" + "fields-to-add": [ + "brent", + "scharge", + "pscharge", + "supcharg" + ], + "result-field": "tcharge" }, - "total_charge": { + "tcharge": { "check_answer_label": "Total Charge", "header": "Total charge?", "hint_text": "This is the total of rent and all charges", @@ -1830,7 +1850,7 @@ "header": "", "description": "", "questions": { - "time_lived_in_la": { + "layear": { "check_answer_label": "How long has the household continuously lived in the local authority area where the new letting is located?", "header": "How long has the household continuously lived in the local authority area where the new letting is located?", "hint_text": "", @@ -1852,7 +1872,7 @@ "header": "", "description": "", "questions": { - "time_on_la_waiting_list": { + "lawaitlist": { "check_answer_label": "How long has the household been on the local authority waiting list where the new letting is located?", "header": "How long has the household been on the local authority waiting list where the new letting is located?", "hint_text": "", @@ -2213,7 +2233,7 @@ "header": "", "description": "", "questions": { - "reasonable_preference": { + "reasonpref": { "check_answer_label": "Was the household given Reasonable Preference (i.e. priority) for housing by the Local Authority?", "header": "Was the household given reasonable preference by the local authority?", "hint_text": "", @@ -2232,12 +2252,12 @@ "hint_text": "Select all that apply", "type": "checkbox", "answer_options": { - "reasonable_preference_reason_homeless": "Homeless or about to lose their home (within 56 days)", - "reasonable_preference_reason_unsatisfactory_housing": "Living in insanitary or overcrowded or unsatisfactory housing", - "reasonable_preference_reason_medical_grounds": "A need to move on medical and welfare grounds (including a disability)", - "reasonable_preference_reason_avoid_hardship": "A need to move to avoid hardship to themselves or others", + "rp_homeless": "Homeless or about to lose their home (within 56 days)", + "rp_insan_unsat": "Living in insanitary or overcrowded or unsatisfactory housing", + "rp_medwel": "A need to move on medical and welfare grounds (including a disability)", + "rp_hardship": "A need to move to avoid hardship to themselves or others", "divider": true, - "reasonable_preference_reason_do_not_know": "Do not know" + "rp_dontknow": "Do not know" } } } @@ -2246,9 +2266,9 @@ "header": "", "description": "", "questions": { - "cbl_letting": { + "cbl": { "check_answer_label": "Choice-based letting?", - "header": "Was the letting made under choice-based lettings (CBL)? ", + "header": "Was the letting made under choice-based lettings (cbl)? ", "hint_text": "", "type": "radio", "answer_options": { @@ -2256,9 +2276,9 @@ "1": "No" } }, - "chr_letting": { + "chr": { "check_answer_label": "Common housing register letting?", - "header": "Was the letting made under common housing register (CHR)? ", + "header": "Was the letting made under common housing register (chr)? ", "hint_text": "", "type": "radio", "answer_options": { @@ -2266,9 +2286,9 @@ "1": "No" } }, - "cap_letting": { + "cap": { "check_answer_label": "Common allocation policy letting?", - "header": "Was the letting made under common allocation policy (CAP)? ", + "header": "Was the letting made under common allocation policy (cap)? ", "hint_text": "", "type": "radio", "answer_options": { diff --git a/db/migrate/20211101192151_rename_fields.rb b/db/migrate/20211101192151_rename_fields.rb new file mode 100644 index 000000000..5333a48cd --- /dev/null +++ b/db/migrate/20211101192151_rename_fields.rb @@ -0,0 +1,106 @@ +class RenameFields < ActiveRecord::Migration[6.1] + def change + rename_column :case_logs, :person_1_age, :age1 + rename_column :case_logs, :person_1_gender, :sex1 + rename_column :case_logs, :tenant_ethnic_group, :ethnic + rename_column :case_logs, :tenant_nationality, :national + rename_column :case_logs, :person_1_economic_status, :ecstat1 + rename_column :case_logs, :household_number_of_other_members, :hhmemb + + rename_column :case_logs, :person_2_relationship, :relat2 + rename_column :case_logs, :person_2_age, :age2 + rename_column :case_logs, :person_2_gender, :sex2 + rename_column :case_logs, :person_2_economic_status, :ecstat2 + + rename_column :case_logs, :person_3_relationship, :relat3 + rename_column :case_logs, :person_3_age, :age3 + rename_column :case_logs, :person_3_gender, :sex3 + rename_column :case_logs, :person_3_economic_status, :ecstat3 + + rename_column :case_logs, :person_4_relationship, :relat4 + rename_column :case_logs, :person_4_age, :age4 + rename_column :case_logs, :person_4_gender, :sex4 + rename_column :case_logs, :person_4_economic_status, :ecstat4 + + rename_column :case_logs, :person_5_relationship, :relat5 + rename_column :case_logs, :person_5_age, :age5 + rename_column :case_logs, :person_5_gender, :sex5 + rename_column :case_logs, :person_5_economic_status, :ecstat5 + + rename_column :case_logs, :person_6_relationship, :relat6 + rename_column :case_logs, :person_6_age, :age6 + rename_column :case_logs, :person_6_gender, :sex6 + rename_column :case_logs, :person_6_economic_status, :ecstat6 + + rename_column :case_logs, :person_7_relationship, :relat7 + rename_column :case_logs, :person_7_age, :age7 + rename_column :case_logs, :person_7_gender, :sex7 + rename_column :case_logs, :person_7_economic_status, :ecstat7 + + rename_column :case_logs, :person_8_relationship, :relat8 + rename_column :case_logs, :person_8_age, :age8 + rename_column :case_logs, :person_8_gender, :sex8 + rename_column :case_logs, :person_8_economic_status, :ecstat8 + + rename_column :case_logs, :previous_housing_situation, :prevten + rename_column :case_logs, :homelessness, :homeless + rename_column :case_logs, :benefit_cap_spare_room_subsidy, :underoccupation_benefitcap + rename_column :case_logs, :armed_forces_injured, :reservist + rename_column :case_logs, :armed_forces_active, :leftreg + rename_column :case_logs, :medical_conditions, :illness + rename_column :case_logs, :pregnancy, :preg_occ + + rename_column :case_logs, :accessibility_requirements_fully_wheelchair_accessible_housing, :housingneeds_a + rename_column :case_logs, :accessibility_requirements_wheelchair_access_to_essential_rooms, :housingneeds_b + rename_column :case_logs, :accessibility_requirements_level_access_housing, :housingneeds_c + rename_column :case_logs, :accessibility_requirements_other_disability_requirements, :housingneeds_f + rename_column :case_logs, :accessibility_requirements_no_disability_requirements, :housingneeds_g + rename_column :case_logs, :accessibility_requirements_do_not_know, :housingneeds_h + + rename_column :case_logs, :condition_effects_vision, :illness_type_1 + rename_column :case_logs, :condition_effects_hearing, :illness_type_2 + rename_column :case_logs, :condition_effects_mobility, :illness_type_3 + rename_column :case_logs, :condition_effects_dexterity, :illness_type_4 + rename_column :case_logs, :condition_effects_stamina, :illness_type_8 + rename_column :case_logs, :condition_effects_learning, :illness_type_5 + rename_column :case_logs, :condition_effects_memory, :illness_type_6 + rename_column :case_logs, :condition_effects_mental_health, :illness_type_7 + rename_column :case_logs, :condition_effects_social_or_behavioral, :illness_type_9 + rename_column :case_logs, :condition_effects_other, :illness_type_10 + + rename_column :case_logs, :tenancy_start_date, :startdate + rename_column :case_logs, :starter_tenancy, :startertenancy + rename_column :case_logs, :fixed_term_tenancy, :tenancylength + rename_column :case_logs, :tenancy_type, :tenancy + rename_column :case_logs, :other_tenancy_type, :tenancyother + rename_column :case_logs, :letting_type, :lettype + rename_column :case_logs, :letting_provider, :landlord + rename_column :case_logs, :property_vacancy_reason, :rsnvac + rename_column :case_logs, :property_unit_type, :unittype_gn + rename_column :case_logs, :property_number_of_bedrooms, :beds + rename_column :case_logs, :property_number_of_times_relet, :offered + rename_column :case_logs, :property_wheelchair_accessible, :wchair + rename_column :case_logs, :net_income, :earnings + rename_column :case_logs, :net_income_frequency, :incfreq + rename_column :case_logs, :net_income_uc_proportion, :benefits + rename_column :case_logs, :rent_frequency, :period + rename_column :case_logs, :basic_rent, :brent + rename_column :case_logs, :service_charge, :scharge + rename_column :case_logs, :personal_service_charge, :pscharge + rename_column :case_logs, :support_charge, :supcharg + rename_column :case_logs, :total_charge, :tcharge + rename_column :case_logs, :time_lived_in_la, :layear + rename_column :case_logs, :time_on_la_waiting_list, :lawaitlist + rename_column :case_logs, :reasonable_preference, :reasonpref + + rename_column :case_logs, :reasonable_preference_reason_homeless, :rp_homeless + rename_column :case_logs, :reasonable_preference_reason_unsatisfactory_housing, :rp_insan_unsat + rename_column :case_logs, :reasonable_preference_reason_medical_grounds, :rp_medwel + rename_column :case_logs, :reasonable_preference_reason_avoid_hardship, :rp_hardship + rename_column :case_logs, :reasonable_preference_reason_do_not_know, :rp_dontknow + + rename_column :case_logs, :cbl_letting, :cbl + rename_column :case_logs, :chr_letting, :chr + rename_column :case_logs, :cap_letting, :cap + end +end diff --git a/db/migrate/20211103090530_change_field_types.rb b/db/migrate/20211103090530_change_field_types.rb new file mode 100644 index 000000000..63968535e --- /dev/null +++ b/db/migrate/20211103090530_change_field_types.rb @@ -0,0 +1,131 @@ +class ChangeFieldTypes < ActiveRecord::Migration[6.1] + def up + change_table :case_logs, bulk: true do |t| + t.change :ethnic, "integer USING ethnic::integer" + t.change :national, "integer USING national::integer" + t.change :ecstat1, "integer USING ecstat1::integer" + t.change :ecstat2, "integer USING ecstat2::integer" + t.change :ecstat3, "integer USING ecstat3::integer" + t.change :ecstat4, "integer USING ecstat4::integer" + t.change :ecstat5, "integer USING ecstat5::integer" + t.change :ecstat6, "integer USING ecstat6::integer" + t.change :ecstat7, "integer USING ecstat7::integer" + t.change :ecstat8, "integer USING ecstat8::integer" + t.change :prevten, "integer USING prevten::integer" + t.change :homeless, "integer USING homeless::integer" + t.change :underoccupation_benefitcap, "integer USING underoccupation_benefitcap::integer" + t.change :reservist, "integer USING reservist::integer" + t.change :leftreg, "integer USING leftreg::integer" + t.change :illness, "integer USING illness::integer" + t.change :preg_occ, "integer USING preg_occ::integer" + t.change :housingneeds_a, "integer USING housingneeds_a::integer" + t.change :housingneeds_b, "integer USING housingneeds_b::integer" + t.change :housingneeds_c, "integer USING housingneeds_c::integer" + t.change :housingneeds_f, "integer USING housingneeds_f::integer" + t.change :housingneeds_g, "integer USING housingneeds_g::integer" + t.change :housingneeds_h, "integer USING housingneeds_h::integer" + t.change :illness_type_1, "integer USING illness_type_1::integer" + t.change :illness_type_2, "integer USING illness_type_2::integer" + t.change :illness_type_3, "integer USING illness_type_3::integer" + t.change :illness_type_4, "integer USING illness_type_4::integer" + t.change :illness_type_5, "integer USING illness_type_5::integer" + t.change :illness_type_6, "integer USING illness_type_6::integer" + t.change :illness_type_7, "integer USING illness_type_7::integer" + t.change :illness_type_8, "integer USING illness_type_8::integer" + t.change :illness_type_9, "integer USING illness_type_9::integer" + t.change :illness_type_10, "integer USING illness_type_10::integer" + t.change :rp_homeless, "integer USING rp_homeless::integer" + t.change :rp_insan_unsat, "integer USING rp_insan_unsat::integer" + t.change :rp_medwel, "integer USING rp_medwel::integer" + t.change :rp_hardship, "integer USING rp_hardship::integer" + t.change :rp_dontknow, "integer USING rp_dontknow::integer" + t.change :cbl, "integer USING cbl::integer" + t.change :chr, "integer USING chr::integer" + t.change :cap, "integer USING cap::integer" + t.change :startertenancy, "integer USING startertenancy::integer" + t.change :tenancylength, "integer USING tenancylength::integer" + t.change :tenancy, "integer USING tenancy::integer" + t.change :landlord, "integer USING landlord::integer" + t.change :rsnvac, "integer USING rsnvac::integer" + t.change :unittype_gn, "integer USING unittype_gn::integer" + t.change :beds, "integer USING beds::integer" + t.change :wchair, "integer USING wchair::integer" + t.change :incfreq, "integer USING incfreq::integer" + t.change :benefits, "integer USING benefits::integer" + t.change :period, "integer USING period::integer" + t.change :brent, "integer USING brent::integer" + t.change :scharge, "integer USING scharge::integer" + t.change :pscharge, "integer USING pscharge::integer" + t.change :supcharg, "integer USING supcharg::integer" + t.change :tcharge, "integer USING tcharge::integer" + t.change :layear, "integer USING layear::integer" + t.change :lawaitlist, "integer USING lawaitlist::integer" + t.change :reasonpref, "integer USING reasonpref::integer" + end + end + + def down + change_table :case_logs, bulk: true do |t| + t.change :ethnic, :string + t.change :national, :string + t.change :ecstat1, :string + t.change :ecstat2, :string + t.change :ecstat3, :string + t.change :ecstat4, :string + t.change :ecstat5, :string + t.change :ecstat6, :string + t.change :ecstat7, :string + t.change :ecstat8, :string + t.change :prevten, :string + t.change :homeless, :string + t.change :underoccupation_benefitcap, :string + t.change :reservist, :string + t.change :leftreg, :string + t.change :illness, :string + t.change :preg_occ, :string + t.change :housingneeds_a, "boolean USING housingneeds_a::boolean" + t.change :housingneeds_b, "boolean USING housingneeds_b::boolean" + t.change :housingneeds_c, "boolean USING housingneeds_c::boolean" + t.change :housingneeds_f, "boolean USING housingneeds_f::boolean" + t.change :housingneeds_g, "boolean USING housingneeds_g::boolean" + t.change :housingneeds_h, "boolean USING housingneeds_h::boolean" + t.change :illness_type_1, "boolean USING illness_type_1::boolean" + t.change :illness_type_2, "boolean USING illness_type_2::boolean" + t.change :illness_type_3, "boolean USING illness_type_3::boolean" + t.change :illness_type_4, "boolean USING illness_type_4::boolean" + t.change :illness_type_5, "boolean USING illness_type_5::boolean" + t.change :illness_type_6, "boolean USING illness_type_6::boolean" + t.change :illness_type_7, "boolean USING illness_type_7::boolean" + t.change :illness_type_8, "boolean USING illness_type_8::boolean" + t.change :illness_type_9, "boolean USING illness_type_9::boolean" + t.change :illness_type_10, "boolean USING illness_type_10::boolean" + t.change :rp_homeless, :boolean + t.change :rp_insan_unsat, :boolean + t.change :rp_medwel, :boolean + t.change :rp_hardship, :boolean + t.change :rp_dontknow, :boolean + t.change :cbl_letting, :string + t.change :chr_letting, :string + t.change :cap_letting, :string + t.change :startertenancy, :string + t.change :tenancylength, :string + t.change :tenancy, :string + t.change :landlord, :string + t.change :rsnvac, :string + t.change :unittype_gn, :string + t.change :beds, :string + t.change :wchair, :string + t.change :incfreq, :string + t.change :benefits, :string + t.change :period, :string + t.change :brent, :string + t.change :scharge, :string + t.change :pscharge, :string + t.change :supcharg, :string + t.change :tcharge, :string + t.change :layear, :string + t.change :lawaitlist, :string + t.change :reasonpref, :string + end + end +end diff --git a/db/schema.rb b/db/schema.rb index ddd456c43..22eb3c9b2 100644 --- a/db/schema.rb +++ b/db/schema.rb @@ -10,7 +10,7 @@ # # It's strongly recommended that you check this file into your version control system. -ActiveRecord::Schema.define(version: 2021_11_02_100820) do +ActiveRecord::Schema.define(version: 2021_11_03_090530) do # These are extensions that must be enabled in order to support this database enable_extension "plpgsql" @@ -20,119 +20,121 @@ ActiveRecord::Schema.define(version: 2021_11_02_100820) do t.datetime "created_at", precision: 6, null: false t.datetime "updated_at", precision: 6, null: false t.string "tenant_code" - t.integer "person_1_age" - t.string "person_1_gender" - t.string "tenant_ethnic_group" - t.string "tenant_nationality" - t.string "previous_housing_situation" + t.integer "age1" + t.string "sex1" + t.integer "ethnic" + t.integer "national" + t.integer "prevten" t.string "armed_forces" - t.string "person_1_economic_status" - t.integer "household_number_of_other_members" - t.string "person_2_relationship" - t.integer "person_2_age" - t.string "person_2_gender" - t.string "person_2_economic_status" - t.string "person_3_relationship" - t.integer "person_3_age" - t.string "person_3_gender" - t.string "person_3_economic_status" - t.string "person_4_relationship" - t.integer "person_4_age" - t.string "person_4_gender" - t.string "person_4_economic_status" - t.string "person_5_relationship" - t.integer "person_5_age" - t.string "person_5_gender" - t.string "person_5_economic_status" - t.string "person_6_relationship" - t.integer "person_6_age" - t.string "person_6_gender" - t.string "person_6_economic_status" - t.string "person_7_relationship" - t.integer "person_7_age" - t.string "person_7_gender" - t.string "person_7_economic_status" - t.string "person_8_relationship" - t.integer "person_8_age" - t.string "person_8_gender" - t.string "person_8_economic_status" - t.string "homelessness" + t.integer "ecstat1" + t.integer "hhmemb" + t.string "relat2" + t.integer "age2" + t.string "sex2" + t.integer "ecstat2" + t.string "relat3" + t.integer "age3" + t.string "sex3" + t.integer "ecstat3" + t.string "relat4" + t.integer "age4" + t.string "sex4" + t.integer "ecstat4" + t.string "relat5" + t.integer "age5" + t.string "sex5" + t.integer "ecstat5" + t.string "relat6" + t.integer "age6" + t.string "sex6" + t.integer "ecstat6" + t.string "relat7" + t.integer "age7" + t.string "sex7" + t.integer "ecstat7" + t.string "relat8" + t.integer "age8" + t.string "sex8" + t.integer "ecstat8" + t.integer "homeless" t.string "reason_for_leaving_last_settled_home" - t.string "benefit_cap_spare_room_subsidy" - t.string "armed_forces_active" - t.string "armed_forces_injured" + t.integer "underoccupation_benefitcap" + t.integer "leftreg" + t.integer "reservist" t.string "armed_forces_partner" - t.string "medical_conditions" - t.string "pregnancy" + t.integer "illness" + t.integer "preg_occ" t.string "accessibility_requirements" t.string "condition_effects" t.string "tenancy_code" - t.string "tenancy_start_date" - t.string "starter_tenancy" - t.string "fixed_term_tenancy" - t.string "tenancy_type" - t.string "letting_type" - t.string "letting_provider" + t.string "startdate" + t.integer "startertenancy" + t.integer "tenancylength" + t.integer "tenancy" + t.string "lettype" + t.integer "landlord" t.string "property_location" t.string "previous_postcode" t.string "property_relet" - t.string "property_vacancy_reason" + t.integer "rsnvac" t.string "property_reference" - t.string "property_unit_type" + t.integer "unittype_gn" t.string "property_building_type" - t.string "property_number_of_bedrooms" + t.integer "beds" t.string "property_void_date" t.string "property_major_repairs" t.string "property_major_repairs_date" - t.integer "property_number_of_times_relet" - t.string "property_wheelchair_accessible" - t.integer "net_income" - t.string "net_income_frequency" - t.string "net_income_uc_proportion" + t.integer "offered" + t.integer "wchair" + t.integer "earnings" + t.integer "incfreq" + t.integer "benefits" t.string "housing_benefit" - t.string "rent_frequency" - t.string "basic_rent" - t.string "service_charge" - t.string "personal_service_charge" - t.string "support_charge" - t.string "total_charge" + t.integer "period" + t.integer "brent" + t.integer "scharge" + t.integer "pscharge" + t.integer "supcharg" + t.integer "tcharge" t.string "outstanding_amount" - t.string "time_lived_in_la" - t.string "time_on_la_waiting_list" + t.integer "layear" + t.integer "lawaitlist" t.string "previous_la" t.string "property_postcode" - t.string "reasonable_preference" + t.integer "reasonpref" t.string "reasonable_preference_reason" - t.string "cbl_letting" - t.string "chr_letting" - t.string "cap_letting" + t.integer "cbl" + t.integer "chr" + t.integer "cap" t.string "outstanding_rent_or_charges" t.string "other_reason_for_leaving_last_settled_home" - t.boolean "accessibility_requirements_fully_wheelchair_accessible_housing" - t.boolean "accessibility_requirements_wheelchair_access_to_essential_rooms" - t.boolean "accessibility_requirements_level_access_housing" - t.boolean "accessibility_requirements_other_disability_requirements" - t.boolean "accessibility_requirements_no_disability_requirements" - t.boolean "accessibility_requirements_do_not_know" + t.integer "housingneeds_a" + t.integer "housingneeds_b" + t.integer "housingneeds_c" + t.integer "housingneeds_f" + t.integer "housingneeds_g" + t.integer "housingneeds_h" t.boolean "accessibility_requirements_prefer_not_to_say" - t.boolean "condition_effects_vision" - t.boolean "condition_effects_hearing" - t.boolean "condition_effects_mobility" - t.boolean "condition_effects_dexterity" - t.boolean "condition_effects_stamina" - t.boolean "condition_effects_learning" - t.boolean "condition_effects_memory" - t.boolean "condition_effects_mental_health" - t.boolean "condition_effects_social_or_behavioral" - t.boolean "condition_effects_other" + t.integer "illness_type_1" + t.integer "illness_type_2" + t.integer "illness_type_3" + t.integer "illness_type_4" + t.integer "illness_type_8" + t.integer "illness_type_5" + t.integer "illness_type_6" + t.integer "illness_type_7" + t.integer "illness_type_9" + t.integer "illness_type_10" t.boolean "condition_effects_prefer_not_to_say" - t.boolean "reasonable_preference_reason_homeless" - t.boolean "reasonable_preference_reason_unsatisfactory_housing" - t.boolean "reasonable_preference_reason_medical_grounds" - t.boolean "reasonable_preference_reason_avoid_hardship" - t.boolean "reasonable_preference_reason_do_not_know" + t.integer "rp_homeless" + t.integer "rp_insan_unsat" + t.integer "rp_medwel" + t.integer "rp_hardship" + t.integer "rp_dontknow" t.datetime "discarded_at" - t.string "other_tenancy_type" + t.string "tenancyother" + t.boolean "override_net_income_validation" + t.string "net_income_known" t.string "gdpr_acceptance" t.string "gdpr_declined" t.string "property_owner_organisation" @@ -144,8 +146,6 @@ ActiveRecord::Schema.define(version: 2021_11_02_100820) do t.string "needs_type" t.string "sale_completion_date" t.string "purchaser_code" - t.boolean "override_net_income_validation" - t.string "net_income_known" t.index ["discarded_at"], name: "index_case_logs_on_discarded_at" end diff --git a/docs/adr/adr-008-field-names.md b/docs/adr/adr-008-field-names.md new file mode 100644 index 000000000..d4668bd04 --- /dev/null +++ b/docs/adr/adr-008-field-names.md @@ -0,0 +1,11 @@ +### ADR - 008: Field Names + +We are changing the schema to reflect the way the data is stored in CORE. +This is due to the SPSS queries that are being performed by ADD and the complexity that would come with changing them. + +The field names are saved lowercase as opposed to the uppercase versions we see in CORE. +This is due to Ruby expecting the uppercase parameters to be constants and database fields are expected to be lower case. +These fields could be mapped to their uppercase versions during the replication if needed. + +A lot of the values are now also being stored as enums. +This gives as some validation by default as the values not defined in the enums will fail to save. diff --git a/docs/api/DLUHC-CORE-Data.v1.json b/docs/api/DLUHC-CORE-Data.v1.json index e4e08d15f..47c068472 100644 --- a/docs/api/DLUHC-CORE-Data.v1.json +++ b/docs/api/DLUHC-CORE-Data.v1.json @@ -54,9 +54,7 @@ { "schema": { "type": "string", - "enum": [ - "application/json" - ] + "enum": ["application/json"] }, "in": "header", "name": "Accept", @@ -109,9 +107,7 @@ "Invalid Age": { "value": { "errors": { - "person_1_age": [ - "Tenant age must be an integer between 16 and 120" - ] + "age1": ["Tenant age must be between 16 and 120"] } } } @@ -136,9 +132,7 @@ { "schema": { "type": "string", - "enum": [ - "application/json" - ] + "enum": ["application/json"] }, "in": "header", "name": "Accept", @@ -177,9 +171,7 @@ { "schema": { "type": "string", - "enum": [ - "application/json" - ] + "enum": ["application/json"] }, "in": "header", "name": "Accept", @@ -219,9 +211,7 @@ "reasonable_preference_reason": [ "If reasonable preference is Yes, a reason must be given" ], - "person_1_age": [ - "Tenant age must be an integer between 16 and 120" - ] + "age1": ["Tenant age must be between 16 and 120"] } } } @@ -247,9 +237,7 @@ "schema": { "type": "string", "pattern": "application/json", - "enum": [ - "application/json" - ] + "enum": ["application/json"] }, "in": "header", "name": "Accept", @@ -268,117 +256,117 @@ "x-examples": { "example-1": { "tenant_code": "T657", - "person_1_age": 35, - "person_1_gender": "Female", - "tenant_ethnic_group": "White: English/Scottish/Welsh/Northern Irish/British", - "tenant_nationality": "UK national resident in UK", - "previous_housing_situation": "Private sector tenancy", + "age1": 35, + "sex1": "Female", + "ethnic": "White: English/Scottish/Welsh/Northern Irish/British", + "national": "UK national resident in UK", + "prevten": "Private sector tenancy", "armed_forces": "Yes - a regular", - "person_1_economic_status": "Full-time - 30 hours or more", - "household_number_of_other_members": 7, - "person_2_relationship": "Partner", - "person_2_age": 32, - "person_2_gender": "Male", - "person_2_economic_status": "Not seeking work", - "person_3_relationship": "Child - includes young adult and grown-up", - "person_3_age": 12, - "person_3_gender": "Male", - "person_3_economic_status": "Child under 16", - "person_4_relationship": "Child - includes young adult and grown-up", - "person_4_age": 12, - "person_4_gender": "Female", - "person_4_economic_status": "Child under 16", - "person_5_relationship": "Child - includes young adult and grown-up", - "person_5_age": 10, - "person_5_gender": "Non-binary", - "person_5_economic_status": "Child under 16", - "person_6_relationship": "Child - includes young adult and grown-up", - "person_6_age": 5, - "person_6_gender": "Prefer not to say", - "person_6_economic_status": "Child under 16", - "person_7_relationship": "Child - includes young adult and grown-up", - "person_7_age": 5, - "person_7_gender": "Prefer not to say", - "person_7_economic_status": "Child under 16", - "person_8_relationship": "Child - includes young adult and grown-up", - "person_8_age": 2, - "person_8_gender": "Prefer not to say", - "person_8_economic_status": "Child under 16", - "homelessness": "No", + "ecstat1": "Full-time - 30 hours or more", + "hhmemb": 7, + "relat2": "Partner", + "age2": 32, + "sex2": "Male", + "ecstat2": "Not seeking work", + "relat3": "Child - includes young adult and grown-up", + "age3": 12, + "sex3": "Male", + "ecstat3": "Child under 16", + "relat4": "Child - includes young adult and grown-up", + "age4": 12, + "sex4": "Female", + "ecstat4": "Child under 16", + "relat5": "Child - includes young adult and grown-up", + "age5": 10, + "sex5": "Non-binary", + "ecstat5": "Child under 16", + "relat6": "Child - includes young adult and grown-up", + "age6": 5, + "sex6": "Prefer not to say", + "ecstat6": "Child under 16", + "relat7": "Child - includes young adult and grown-up", + "age7": 5, + "sex7": "Prefer not to say", + "ecstat7": "Child under 16", + "relat8": "Child - includes young adult and grown-up", + "age8": 2, + "sex8": "Prefer not to say", + "ecstat8": "Child under 16", + "homeless": "No", "reason_for_leaving_last_settled_home": "Other problems with neighbours", - "benefit_cap_spare_room_subsidy": "No", - "armed_forces_active": "No", - "armed_forces_injured": "No", + "underoccupation_benefitcap": "No", + "leftreg": "No", + "reservist": "No", "armed_forces_partner": "No", - "medical_conditions": "Yes", - "pregnancy": "No", + "illness": "Yes", + "preg_occ": "No", "accessibility_requirements": "No", "condition_effects": "dummy", "tenancy_code": "BZ757", - "tenancy_start_date": "12/03/2019", - "starter_tenancy": "No", - "fixed_term_tenancy": "No", - "tenancy_type": "Fixed term – Secure", - "letting_type": "Affordable Rent - General Needs", - "letting_provider": "This landlord", + "startdate": "12/03/2019", + "startertenancy": "No", + "tenancylength": "No", + "tenancy": "Fixed term – Secure", + "lettype": "Affordable Rent - General Needs", + "landlord": "This landlord", "property_location": "Barnet", "previous_postcode": "NW1 5TY", "property_relet": "No", - "property_vacancy_reason": "Relet - tenant abandoned property", + "rsnvac": "Relet - tenant abandoned property", "property_reference": "P9876", - "property_unit_type": "House", + "unittype_gn": "House", "property_building_type": "dummy", - "property_number_of_bedrooms": 3, + "beds": 3, "property_void_date": "03/11/2019", "property_major_repairs": "Yes", "property_major_repairs_date": "05/05/2020", - "property_number_of_times_relet": 2, - "property_wheelchair_accessible": true, - "net_income": 1000, - "net_income_frequency": "Monthly", - "net_income_uc_proportion": "Some", + "offered": 2, + "wchair": true, + "earnings": 1000, + "incfreq": "Monthly", + "benefits": "Some", "housing_benefit": "Universal Credit with housing element, but not Housing Benefit", - "rent_frequency": "Weekly", - "basic_rent": 200, - "service_charge": 50, - "personal_service_charge": 40, - "support_charge": 35, - "total_charge": 325, + "period": "Weekly", + "brent": 200, + "scharge": 50, + "pscharge": 40, + "supcharg": 35, + "tcharge": 325, "outstanding_amount": "Yes", - "time_lived_in_la": "1 to 2 years", - "time_on_la_waiting_list": "Less than 1 year", + "layear": "1 to 2 years", + "lawaitlist": "Less than 1 year", "previous_la": "Ashford", "property_postcode": "SE2 6RT", - "reasonable_preference": "Yes", + "reasonpref": "Yes", "reasonable_preference_reason": "dummy", - "cbl_letting": true, - "chr_letting": false, - "cap_letting": false, + "cbl": true, + "chr": false, + "cap": false, "outstanding_rent_or_charges": 25, "other_reason_for_leaving_last_settled_home": "Other reason", - "accessibility_requirements_fully_wheelchair_accessible_housing": true, - "accessibility_requirements_wheelchair_access_to_essential_rooms": false, - "accessibility_requirements_level_access_housing": false, - "accessibility_requirements_other_disability_requirements": false, - "accessibility_requirements_no_disability_requirements": false, - "accessibility_requirements_do_not_know": false, + "housingneeds_a": true, + "housingneeds_b": false, + "housingneeds_c": false, + "housingneeds_f": false, + "housingneeds_g": false, + "housingneeds_h": false, "accessibility_requirements_prefer_not_to_say": false, - "condition_effects_vision": false, - "condition_effects_hearing": true, - "condition_effects_mobility": false, - "condition_effects_dexterity": false, - "condition_effects_stamina": false, - "condition_effects_learning": false, - "condition_effects_memory": false, - "condition_effects_mental_health": false, - "condition_effects_social_or_behavioral": false, - "condition_effects_other": false, + "illness_type_1": false, + "illness_type_2": true, + "illness_type_3": false, + "illness_type_4": false, + "illness_type_8": false, + "illness_type_5": false, + "illness_type_6": false, + "illness_type_7": false, + "illness_type_9": false, + "illness_type_10": false, "condition_effects_prefer_not_to_say": false, - "reasonable_preference_reason_homeless": false, - "reasonable_preference_reason_unsatisfactory_housing": false, - "reasonable_preference_reason_medical_grounds": false, - "reasonable_preference_reason_avoid_hardship": false, - "reasonable_preference_reason_do_not_know": true + "rp_homeless": false, + "rp_insan_unsat": false, + "rp_medwel": false, + "rp_hardship": false, + "rp_dontknow": true } }, "title": "Case Log", @@ -388,23 +376,18 @@ "type": "string", "minLength": 1 }, - "person_1_age": { + "age1": { "type": "number", "description": "The age of the lead tenant", "maximum": 120, "minimum": 0 }, - "person_1_gender": { + "sex1": { "type": "string", "minLength": 1, - "enum": [ - "Female", - "Male", - "Non-binary", - "Prefer not to say" - ] + "enum": ["Female", "Male", "Non-binary", "Prefer not to say"] }, - "tenant_ethnic_group": { + "ethnic": { "type": "string", "minLength": 1, "enum": [ @@ -429,7 +412,7 @@ "Prefer not to say" ] }, - "tenant_nationality": { + "national": { "type": "string", "minLength": 1, "enum": [ @@ -451,7 +434,7 @@ "Prefer not to say" ] }, - "previous_housing_situation": { + "prevten": { "type": "string", "minLength": 1 }, @@ -459,7 +442,7 @@ "type": "string", "minLength": 1 }, - "person_1_economic_status": { + "ecstat1": { "type": "string", "minLength": 1, "enum": [ @@ -476,12 +459,12 @@ "Prefer not to say" ] }, - "household_number_of_other_members": { + "hhmemb": { "type": "number", "minimum": 0, "maximum": 7 }, - "person_2_relationship": { + "relat2": { "type": "string", "minLength": 1, "enum": [ @@ -491,22 +474,17 @@ "Prefer not to say" ] }, - "person_2_age": { + "age2": { "type": "number", "maximum": 120, "minimum": 0 }, - "person_2_gender": { + "sex2": { "type": "string", "minLength": 1, - "enum": [ - "Female", - "Male", - "Non-binary", - "Prefer not to say" - ] + "enum": ["Female", "Male", "Non-binary", "Prefer not to say"] }, - "person_2_economic_status": { + "ecstat2": { "type": "string", "minLength": 1, "enum": [ @@ -523,7 +501,7 @@ "Prefer not to say" ] }, - "person_3_relationship": { + "relat3": { "type": "string", "minLength": 1, "enum": [ @@ -533,22 +511,17 @@ "Prefer not to say" ] }, - "person_3_age": { + "age3": { "type": "number", "maximum": 120, "minimum": 0 }, - "person_3_gender": { + "sex3": { "type": "string", "minLength": 1, - "enum": [ - "Female", - "Male", - "Non-binary", - "Prefer not to say" - ] + "enum": ["Female", "Male", "Non-binary", "Prefer not to say"] }, - "person_3_economic_status": { + "ecstat3": { "type": "string", "minLength": 1, "enum": [ @@ -565,7 +538,7 @@ "Prefer not to say" ] }, - "person_4_relationship": { + "relat4": { "type": "string", "minLength": 1, "enum": [ @@ -575,22 +548,17 @@ "Prefer not to say" ] }, - "person_4_age": { + "age4": { "type": "number", "maximum": 120, "minimum": 0 }, - "person_4_gender": { + "sex4": { "type": "string", "minLength": 1, - "enum": [ - "Female", - "Male", - "Non-binary", - "Prefer not to say" - ] + "enum": ["Female", "Male", "Non-binary", "Prefer not to say"] }, - "person_4_economic_status": { + "ecstat4": { "type": "string", "minLength": 1, "enum": [ @@ -607,7 +575,7 @@ "Prefer not to say" ] }, - "person_5_relationship": { + "relat5": { "type": "string", "minLength": 1, "enum": [ @@ -617,22 +585,17 @@ "Prefer not to say" ] }, - "person_5_age": { + "age5": { "type": "number", "maximum": 120, "minimum": 0 }, - "person_5_gender": { + "sex5": { "type": "string", "minLength": 1, - "enum": [ - "Female", - "Male", - "Non-binary", - "Prefer not to say" - ] + "enum": ["Female", "Male", "Non-binary", "Prefer not to say"] }, - "person_5_economic_status": { + "ecstat5": { "type": "string", "minLength": 1, "enum": [ @@ -649,7 +612,7 @@ "Prefer not to say" ] }, - "person_6_relationship": { + "relat6": { "type": "string", "minLength": 1, "enum": [ @@ -659,22 +622,17 @@ "Prefer not to say" ] }, - "person_6_age": { + "age6": { "type": "number", "maximum": 120, "minimum": 0 }, - "person_6_gender": { + "sex6": { "type": "string", "minLength": 1, - "enum": [ - "Female", - "Male", - "Non-binary", - "Prefer not to say" - ] + "enum": ["Female", "Male", "Non-binary", "Prefer not to say"] }, - "person_6_economic_status": { + "ecstat6": { "type": "string", "minLength": 1, "enum": [ @@ -691,7 +649,7 @@ "Prefer not to say" ] }, - "person_7_relationship": { + "relat7": { "type": "string", "minLength": 1, "enum": [ @@ -701,22 +659,17 @@ "Prefer not to say" ] }, - "person_7_age": { + "age7": { "type": "number", "maximum": 120, "minimum": 0 }, - "person_7_gender": { + "sex7": { "type": "string", "minLength": 1, - "enum": [ - "Female", - "Male", - "Non-binary", - "Prefer not to say" - ] + "enum": ["Female", "Male", "Non-binary", "Prefer not to say"] }, - "person_7_economic_status": { + "ecstat7": { "type": "string", "minLength": 1, "enum": [ @@ -733,7 +686,7 @@ "Prefer not to say" ] }, - "person_8_relationship": { + "relat8": { "type": "string", "minLength": 1, "enum": [ @@ -743,22 +696,17 @@ "Prefer not to say" ] }, - "person_8_age": { + "age8": { "type": "number", "maximum": 120, "minimum": 0 }, - "person_8_gender": { + "sex8": { "type": "string", "minLength": 1, - "enum": [ - "Female", - "Male", - "Non-binary", - "Prefer not to say" - ] + "enum": ["Female", "Male", "Non-binary", "Prefer not to say"] }, - "person_8_economic_status": { + "ecstat8": { "type": "string", "minLength": 1, "enum": [ @@ -775,7 +723,7 @@ "Prefer not to say" ] }, - "homelessness": { + "homeless": { "type": "string", "minLength": 1 }, @@ -819,7 +767,7 @@ "Prefer not to say" ] }, - "benefit_cap_spare_room_subsidy": { + "underoccupation_benefitcap": { "type": "string", "minLength": 1, "enum": [ @@ -831,11 +779,11 @@ "Prefer not to say" ] }, - "armed_forces_active": { + "leftreg": { "type": "string", "minLength": 1 }, - "armed_forces_injured": { + "reservist": { "type": "string", "minLength": 1 }, @@ -843,11 +791,11 @@ "type": "string", "minLength": 1 }, - "medical_conditions": { + "illness": { "type": "string", "minLength": 1 }, - "pregnancy": { + "preg_occ": { "type": "string", "minLength": 1 }, @@ -863,28 +811,28 @@ "type": "string", "minLength": 1 }, - "tenancy_start_date": { + "startdate": { "type": "string", "minLength": 1 }, - "starter_tenancy": { + "startertenancy": { "type": "string", "minLength": 1 }, - "fixed_term_tenancy": { + "tenancylength": { "type": "string", "minLength": 1, "pattern": "((?!1|0)([0-9][0-9]))+" }, - "tenancy_type": { + "tenancy": { "type": "string", "minLength": 1 }, - "letting_type": { + "lettype": { "type": "string", "minLength": 1 }, - "letting_provider": { + "landlord": { "type": "string", "minLength": 1 }, @@ -900,7 +848,7 @@ "type": "string", "minLength": 1 }, - "property_vacancy_reason": { + "rsnvac": { "type": "string", "minLength": 1 }, @@ -908,7 +856,7 @@ "type": "string", "minLength": 1 }, - "property_unit_type": { + "unittype_gn": { "type": "string", "minLength": 1 }, @@ -916,7 +864,7 @@ "type": "string", "minLength": 1 }, - "property_number_of_bedrooms": { + "beds": { "type": "number" }, "property_void_date": { @@ -931,70 +879,61 @@ "type": "string", "minLength": 1 }, - "property_number_of_times_relet": { + "offered": { "type": "number" }, - "property_wheelchair_accessible": { + "wchair": { "type": "boolean" }, - "net_income_known": { + "earnings_known": { "type": "string", "minLength": 1, - "enum": [ - "Yes", - "No", - "Tenant prefers not to say" - ] + "enum": ["Yes", "No", "Tenant prefers not to say"] }, - "net_income": { + "earnings": { "type": "number" }, - "net_income_frequency": { + "incfreq": { "type": "string", "minLength": 1 }, - "net_income_uc_proportion": { + "benefits": { "type": "string", "minLength": 1, - "enum": [ - "All", - "Some", - "None", - "Do not know" - ] + "enum": ["All", "Some", "None", "Do not know"] }, "housing_benefit": { "type": "string", "minLength": 1 }, - "rent_frequency": { + "period": { "type": "string", "minLength": 1 }, - "basic_rent": { + "brent": { "type": "number" }, - "service_charge": { + "scharge": { "type": "number" }, - "personal_service_charge": { + "pscharge": { "type": "number" }, - "support_charge": { + "supcharg": { "type": "number" }, - "total_charge": { + "tcharge": { "type": "number" }, "outstanding_amount": { "type": "string", "minLength": 1 }, - "time_lived_in_la": { + "layear": { "type": "string", "minLength": 1 }, - "time_on_la_waiting_list": { + "lawaitlist": { "type": "string", "minLength": 1 }, @@ -1006,7 +945,7 @@ "type": "string", "minLength": 1 }, - "reasonable_preference": { + "reasonpref": { "type": "string", "minLength": 1 }, @@ -1014,13 +953,13 @@ "type": "string", "minLength": 1 }, - "cbl_letting": { + "cbl": { "type": "boolean" }, - "chr_letting": { + "chr": { "type": "boolean" }, - "cap_letting": { + "cap": { "type": "boolean" }, "outstanding_rent_or_charges": { @@ -1030,73 +969,73 @@ "type": "string", "minLength": 1 }, - "accessibility_requirements_fully_wheelchair_accessible_housing": { + "housingneeds_a": { "type": "boolean" }, - "accessibility_requirements_wheelchair_access_to_essential_rooms": { + "housingneeds_b": { "type": "boolean" }, - "accessibility_requirements_level_access_housing": { + "housingneeds_c": { "type": "boolean" }, - "accessibility_requirements_other_disability_requirements": { + "housingneeds_f": { "type": "boolean" }, - "accessibility_requirements_no_disability_requirements": { + "housingneeds_g": { "type": "boolean" }, - "accessibility_requirements_do_not_know": { + "housingneeds_h": { "type": "boolean" }, "accessibility_requirements_prefer_not_to_say": { "type": "boolean" }, - "condition_effects_vision": { + "illness_type_1": { "type": "boolean" }, - "condition_effects_hearing": { + "illness_type_2": { "type": "boolean" }, - "condition_effects_mobility": { + "illness_type_3": { "type": "boolean" }, - "condition_effects_dexterity": { + "illness_type_4": { "type": "boolean" }, - "condition_effects_stamina": { + "illness_type_8": { "type": "boolean" }, - "condition_effects_learning": { + "illness_type_5": { "type": "boolean" }, - "condition_effects_memory": { + "illness_type_6": { "type": "boolean" }, - "condition_effects_mental_health": { + "illness_type_7": { "type": "boolean" }, - "condition_effects_social_or_behavioral": { + "illness_type_9": { "type": "boolean" }, - "condition_effects_other": { + "illness_type_10": { "type": "boolean" }, "condition_effects_prefer_not_to_say": { "type": "boolean" }, - "reasonable_preference_reason_homeless": { + "rp_homeless": { "type": "boolean" }, - "reasonable_preference_reason_unsatisfactory_housing": { + "rp_insan_unsat": { "type": "boolean" }, - "reasonable_preference_reason_medical_grounds": { + "rp_medwel": { "type": "boolean" }, - "reasonable_preference_reason_avoid_hardship": { + "rp_hardship": { "type": "boolean" }, - "reasonable_preference_reason_do_not_know": { + "rp_dontknow": { "type": "boolean" }, "other_tenancy-type": { @@ -1106,119 +1045,119 @@ }, "required": [ "tenant_code", - "person_1_age", - "person_1_gender", - "tenant_ethnic_group", - "tenant_nationality", - "previous_housing_situation", + "age1", + "sex1", + "ethnic", + "national", + "prevten", "armed_forces", - "person_1_economic_status", - "household_number_of_other_members", - "person_2_relationship", - "person_2_age", - "person_2_gender", - "person_2_economic_status", - "person_3_relationship", - "person_3_age", - "person_3_gender", - "person_3_economic_status", - "person_4_relationship", - "person_4_age", - "person_4_gender", - "person_4_economic_status", - "person_5_relationship", - "person_5_age", - "person_5_gender", - "person_5_economic_status", - "person_6_relationship", - "person_6_age", - "person_6_gender", - "person_6_economic_status", - "person_7_relationship", - "person_7_age", - "person_7_gender", - "person_7_economic_status", - "person_8_relationship", - "person_8_age", - "person_8_gender", - "person_8_economic_status", - "homelessness", + "ecstat1", + "hhmemb", + "relat2", + "age2", + "sex2", + "ecstat2", + "relat3", + "age3", + "sex3", + "ecstat3", + "relat4", + "age4", + "sex4", + "ecstat4", + "relat5", + "age5", + "sex5", + "ecstat5", + "relat6", + "age6", + "sex6", + "ecstat6", + "relat7", + "age7", + "sex7", + "ecstat7", + "relat8", + "age8", + "sex8", + "ecstat8", + "homeless", "reason_for_leaving_last_settled_home", - "benefit_cap_spare_room_subsidy", - "armed_forces_active", - "armed_forces_injured", + "underoccupation_benefitcap", + "leftreg", + "reservist", "armed_forces_partner", - "medical_conditions", - "pregnancy", + "illness", + "preg_occ", "accessibility_requirements", "condition_effects", "tenancy_code", - "tenancy_start_date", - "starter_tenancy", - "fixed_term_tenancy", - "tenancy_type", - "letting_type", - "letting_provider", + "startdate", + "startertenancy", + "tenancylength", + "tenancy", + "lettype", + "landlord", "property_location", "previous_postcode", "property_relet", - "property_vacancy_reason", + "rsnvac", "property_reference", - "property_unit_type", + "unittype_gn", "property_building_type", - "property_number_of_bedrooms", + "beds", "property_void_date", "property_major_repairs", "property_major_repairs_date", - "property_number_of_times_relet", - "property_wheelchair_accessible", - "net_income", - "net_income_frequency", - "net_income_uc_proportion", + "offered", + "wchair", + "earnings", + "incfreq", + "benefits", "housing_benefit", - "rent_frequency", - "basic_rent", - "service_charge", - "personal_service_charge", - "support_charge", - "total_charge", + "period", + "brent", + "scharge", + "pscharge", + "supcharg", + "tcharge", "outstanding_amount", - "time_lived_in_la", - "time_on_la_waiting_list", + "layear", + "lawaitlist", "previous_la", "property_postcode", - "reasonable_preference", + "reasonpref", "reasonable_preference_reason", - "cbl_letting", - "chr_letting", - "cap_letting", + "cbl", + "chr", + "cap", "outstanding_rent_or_charges", "other_reason_for_leaving_last_settled_home", - "accessibility_requirements_fully_wheelchair_accessible_housing", - "accessibility_requirements_wheelchair_access_to_essential_rooms", - "accessibility_requirements_level_access_housing", - "accessibility_requirements_other_disability_requirements", - "accessibility_requirements_no_disability_requirements", - "accessibility_requirements_do_not_know", + "housingneeds_a", + "housingneeds_b", + "housingneeds_c", + "housingneeds_f", + "housingneeds_g", + "housingneeds_h", "accessibility_requirements_prefer_not_to_say", - "condition_effects_vision", - "condition_effects_hearing", - "condition_effects_mobility", - "condition_effects_dexterity", - "condition_effects_stamina", - "condition_effects_learning", - "condition_effects_memory", - "condition_effects_mental_health", - "condition_effects_social_or_behavioral", - "condition_effects_other", + "illness_type_1", + "illness_type_2", + "illness_type_3", + "illness_type_4", + "illness_type_8", + "illness_type_5", + "illness_type_6", + "illness_type_7", + "illness_type_9", + "illness_type_10", "condition_effects_prefer_not_to_say", - "reasonable_preference_reason_homeless", - "reasonable_preference_reason_unsatisfactory_housing", - "reasonable_preference_reason_medical_grounds", - "reasonable_preference_reason_avoid_hardship", - "reasonable_preference_reason_do_not_know", + "rp_homeless", + "rp_insan_unsat", + "rp_medwel", + "rp_hardship", + "rp_dontknow", "other_tenancy-type", - "net_income_known" + "earnings_known" ] } }, diff --git a/spec/controllers/case_logs_controller_spec.rb b/spec/controllers/case_logs_controller_spec.rb index 3adcf8335..2eecfdfe2 100644 --- a/spec/controllers/case_logs_controller_spec.rb +++ b/spec/controllers/case_logs_controller_spec.rb @@ -49,15 +49,15 @@ RSpec.describe CaseLogsController, type: :controller do let(:id) { case_log.id } let(:case_log_form_params) do { accessibility_requirements: - %w[ accessibility_requirements_fully_wheelchair_accessible_housing - accessibility_requirements_wheelchair_access_to_essential_rooms - accessibility_requirements_level_access_housing], + %w[ housingneeds_a + housingneeds_b + housingneeds_c], page: "accessibility_requirements" } end let(:new_case_log_form_params) do { - accessibility_requirements: %w[accessibility_requirements_level_access_housing], + accessibility_requirements: %w[housingneeds_c], page: "accessibility_requirements", } end @@ -66,27 +66,27 @@ RSpec.describe CaseLogsController, type: :controller do post :submit_form, params: { id: id, case_log: case_log_form_params } case_log.reload - expect(case_log.accessibility_requirements_fully_wheelchair_accessible_housing).to eq(true) - expect(case_log.accessibility_requirements_wheelchair_access_to_essential_rooms).to eq(true) - expect(case_log.accessibility_requirements_level_access_housing).to eq(true) + expect(case_log.housingneeds_a).to eq("Yes") + expect(case_log.housingneeds_b).to eq("Yes") + expect(case_log.housingneeds_c).to eq("Yes") end it "sets previously submitted items to false when resubmitted with new values" do post :submit_form, params: { id: id, case_log: new_case_log_form_params } case_log.reload - expect(case_log.accessibility_requirements_fully_wheelchair_accessible_housing).to eq(false) - expect(case_log.accessibility_requirements_wheelchair_access_to_essential_rooms).to eq(false) - expect(case_log.accessibility_requirements_level_access_housing).to eq(true) + expect(case_log.housingneeds_a).to eq("No") + expect(case_log.housingneeds_b).to eq("No") + expect(case_log.housingneeds_c).to eq("Yes") end context "given a page with checkbox and non-checkbox questions" do let(:tenant_code) { "BZ355" } let(:case_log_form_params) do { accessibility_requirements: - %w[ accessibility_requirements_fully_wheelchair_accessible_housing - accessibility_requirements_wheelchair_access_to_essential_rooms - accessibility_requirements_level_access_housing], + %w[ housingneeds_a + housingneeds_b + housingneeds_c], tenant_code: tenant_code, page: "accessibility_requirements" } end @@ -95,13 +95,13 @@ RSpec.describe CaseLogsController, type: :controller do { "type" => "checkbox", "answer_options" => - { "accessibility_requirements_fully_wheelchair_accessible_housing" => "Fully wheelchair accessible housing", - "accessibility_requirements_wheelchair_access_to_essential_rooms" => "Wheelchair access to essential rooms", - "accessibility_requirements_level_access_housing" => "Level access housing", - "accessibility_requirements_other_disability_requirements" => "Other disability requirements", - "accessibility_requirements_no_disability_requirements" => "No disability requirements", + { "housingneeds_a" => "Fully wheelchair accessible housing", + "housingneeds_b" => "Wheelchair access to essential rooms", + "housingneeds_c" => "Level access housing", + "housingneeds_f" => "Other disability requirements", + "housingneeds_g" => "No disability requirements", "divider_a" => true, - "accessibility_requirements_do_not_know" => "Do not know", + "housingneeds_h" => "Do not know", "divider_b" => true, "accessibility_requirements_prefer_not_to_say" => "Prefer not to say" }, }, @@ -116,9 +116,9 @@ RSpec.describe CaseLogsController, type: :controller do post :submit_form, params: { id: id, case_log: case_log_form_params } case_log.reload - expect(case_log.accessibility_requirements_fully_wheelchair_accessible_housing).to eq(true) - expect(case_log.accessibility_requirements_wheelchair_access_to_essential_rooms).to eq(true) - expect(case_log.accessibility_requirements_level_access_housing).to eq(true) + expect(case_log.housingneeds_a).to eq("Yes") + expect(case_log.housingneeds_b).to eq("Yes") + expect(case_log.housingneeds_c).to eq("Yes") expect(case_log.tenant_code).to eq(tenant_code) end end @@ -130,14 +130,14 @@ RSpec.describe CaseLogsController, type: :controller do let(:case_log_form_conditional_question_yes_params) do { - pregnancy: "Yes", + preg_occ: "Yes", page: "conditional_question", } end let(:case_log_form_conditional_question_no_params) do { - pregnancy: "No", + preg_occ: "No", page: "conditional_question", } end @@ -170,7 +170,7 @@ RSpec.describe CaseLogsController, type: :controller do it "returns a correct page path if there is conditional routing" do responses_for_page = {} - responses_for_page["pregnancy"] = "No" + responses_for_page["preg_occ"] = "No" expect(case_log_controller.send(:get_next_page_path, form, previous_conditional_page, responses_for_page)).to eq("case_log_conditional_question_no_page_path") end end diff --git a/spec/factories/case_log.rb b/spec/factories/case_log.rb index bed593844..5504800fa 100644 --- a/spec/factories/case_log.rb +++ b/spec/factories/case_log.rb @@ -6,7 +6,7 @@ FactoryBot.define do tenant_code { "TH356" } property_postcode { "SW2 6HI" } previous_postcode { "P0 5ST" } - person_1_age { "18" } + age1 { "17" } end trait :completed do status { 2 } diff --git a/spec/features/case_log_spec.rb b/spec/features/case_log_spec.rb index f46a64a3e..be20f6b81 100644 --- a/spec/features/case_log_spec.rb +++ b/spec/features/case_log_spec.rb @@ -6,24 +6,24 @@ RSpec.describe "Test Features" do let(:status) { case_log.status } question_answers = { - tenant_code: { type: "text", answer: "BZ737" }, - person_1_age: { type: "numeric", answer: 25 }, - person_1_gender: { type: "radio", answer: "Female" }, - household_number_of_other_members: { type: "numeric", answer: 2 }, + tenant_code: { type: "text", answer: "BZ737", path: "tenant_code" }, + age1: { type: "numeric", answer: 25, path: "person_1_age" }, + sex1: { type: "radio", answer: "Female", path: "person_1_gender" }, + hhmemb: { type: "numeric", answer: 2, path: "household_number_of_other_members" }, } - def fill_in_number_question(case_log_id, question, value) - visit("/case_logs/#{case_log_id}/#{question}") + def fill_in_number_question(case_log_id, question, value, path) + visit("/case_logs/#{case_log_id}/#{path}") fill_in("case-log-#{question.to_s.dasherize}-field", with: value) click_button("Save and continue") end def answer_all_questions_in_income_subsection visit("/case_logs/#{empty_case_log.id}/net_income") - fill_in("case-log-net-income-field", with: 18_000) - choose("case-log-net-income-frequency-yearly-field") + fill_in("case-log-earnings-field", with: 18_000) + choose("case-log-incfreq-yearly-field") click_button("Save and continue") - choose("case-log-net-income-uc-proportion-all-field") + choose("case-log-benefits-all-field") click_button("Save and continue") choose("case-log-housing-benefit-housing-benefit-but-not-universal-credit-field") click_button("Save and continue") @@ -84,65 +84,66 @@ RSpec.describe "Test Features" do let(:case_log_with_checkbox_questions_answered) do FactoryBot.create( :case_log, :in_progress, - accessibility_requirements_fully_wheelchair_accessible_housing: true, - accessibility_requirements_level_access_housing: true + housingneeds_a: "Yes", + housingneeds_c: "Yes" ) end context "Validate pregnancy questions" do it "Cannot answer yes if no female tenants" do expect { - CaseLog.create!(pregnancy: "Yes", - person_1_gender: "Male", - person_1_age: 20) + CaseLog.create!(preg_occ: "Yes", + sex1: "Male", + age1: 20) }.to raise_error(ActiveRecord::RecordInvalid) end it "Cannot answer yes if no female tenants within age range" do expect { - CaseLog.create!(pregnancy: "Yes", - person_1_gender: "Female", - person_1_age: 51) + CaseLog.create!(preg_occ: "Yes", + sex1: "Female", + age1: 51) }.to raise_error(ActiveRecord::RecordInvalid) end it "Cannot answer prefer not to say if no valid tenants" do expect { - CaseLog.create!(pregnancy: "Prefer not to say", - person_1_gender: "Male", - person_1_age: 20) + CaseLog.create!(preg_occ: "Prefer not to say", + sex1: "Male", + age1: 20) }.to raise_error(ActiveRecord::RecordInvalid) end it "Can answer yes if valid tenants" do expect { - CaseLog.create!(pregnancy: "Yes", - person_1_gender: "Female", - person_1_age: 20) + CaseLog.create!(preg_occ: "Yes", + sex1: "Female", + age1: 20) }.not_to raise_error end it "Can answer yes if valid second tenant" do expect { - CaseLog.create!(pregnancy: "Yes", - person_1_gender: "Male", person_1_age: 99, - person_2_gender: "Female", - person_2_age: 20) + CaseLog.create!(preg_occ: "Yes", + sex1: "Male", age1: 99, + sex2: "Female", + age2: 20) }.not_to raise_error end end it "can be accessed by url" do visit("/case_logs/#{id}/person_1_age") - expect(page).to have_field("case-log-person-1-age-field") + expect(page).to have_field("case-log-age1-field") end it "updates model attributes correctly for each question" do question_answers.each do |question, hsh| type = hsh[:type] answer = hsh[:answer] + path = hsh[:path] original_value = case_log.send(question) - visit("/case_logs/#{id}/#{question}") + visit("/case_logs/#{id}/#{path}") case type when "text" fill_in("case-log-#{question.to_s.dasherize}-field", with: answer) @@ -160,17 +161,17 @@ RSpec.describe "Test Features" do it "updates total value of the rent", js: true do visit("/case_logs/#{id}/rent") - fill_in("case-log-basic-rent-field", with: 3) - expect(page).to have_field("case-log-total-charge-field", with: "3") + fill_in("case-log-brent-field", with: 3) + expect(page).to have_field("case-log-tcharge-field", with: "3") - fill_in("case-log-service-charge-field", with: 2) - expect(page).to have_field("case-log-total-charge-field", with: "5") + fill_in("case-log-scharge-field", with: 2) + expect(page).to have_field("case-log-tcharge-field", with: "5") - fill_in("case-log-personal-service-charge-field", with: 1) - expect(page).to have_field("case-log-total-charge-field", with: "6") + fill_in("case-log-pscharge-field", with: 1) + expect(page).to have_field("case-log-tcharge-field", with: "6") - fill_in("case-log-support-charge-field", with: 4) - expect(page).to have_field("case-log-total-charge-field", with: "10") + fill_in("case-log-supcharg-field", with: 4) + expect(page).to have_field("case-log-tcharge-field", with: "10") end it "displays number answers in inputs if they are already saved" do @@ -180,22 +181,22 @@ RSpec.describe "Test Features" do it "displays text answers in inputs if they are already saved" do visit("/case_logs/#{id}/person_1_age") - expect(page).to have_field("case-log-person-1-age-field", with: "18") + expect(page).to have_field("case-log-age1-field", with: "17") end it "displays checkbox answers in inputs if they are already saved" do visit("/case_logs/#{case_log_with_checkbox_questions_answered.id}/accessibility_requirements") # Something about our styling makes the selenium webdriver think the actual radio buttons are not visible so we pass false here expect(page).to have_checked_field( - "case-log-accessibility-requirements-accessibility-requirements-fully-wheelchair-accessible-housing-field", + "case-log-accessibility-requirements-housingneeds-a-field", visible: false, ) expect(page).to have_unchecked_field( - "case-log-accessibility-requirements-accessibility-requirements-wheelchair-access-to-essential-rooms-field", + "case-log-accessibility-requirements-housingneeds-b-field", visible: false, ) expect(page).to have_checked_field( - "case-log-accessibility-requirements-accessibility-requirements-level-access-housing-field", + "case-log-accessibility-requirements-housingneeds-c-field", visible: false, ) end @@ -222,7 +223,7 @@ RSpec.describe "Test Features" do describe "Form flow is correct" do context "given an ordered list of pages" do it "leads to the next one in the correct order" do - pages = question_answers.keys + pages = question_answers.map { |_key, val| val[:path] } pages[0..-2].each_with_index do |val, index| visit("/case_logs/#{id}/#{val}") click_button("Save and continue") @@ -253,7 +254,7 @@ RSpec.describe "Test Features" do let(:last_question_for_subsection) { "household_number_of_other_members" } it "redirects to the check answers page when answering the last question and clicking save and continue" do - fill_in_number_question(id, last_question_for_subsection, 0) + fill_in_number_question(id, "hhmemb", 0, last_question_for_subsection) expect(page).to have_current_path("/case_logs/#{id}/#{subsection}/check_answers") end @@ -266,8 +267,8 @@ RSpec.describe "Test Features" do end it "should display answers given by the user for the question in the subsection" do - fill_in_number_question(empty_case_log.id, "person_1_age", 28) - choose("case-log-person-1-gender-non-binary-field") + fill_in_number_question(empty_case_log.id, "age1", 28, "person_1_age") + choose("case-log-sex1-non-binary-field") click_button("Save and continue") visit("/case_logs/#{empty_case_log.id}/#{subsection}/check_answers") expect(page).to have_content("28") @@ -282,7 +283,7 @@ RSpec.describe "Test Features" do end it "should have a change link for answered questions" do - fill_in_number_question(empty_case_log.id, "person_1_age", 28) + fill_in_number_question(empty_case_log.id, "age1", 28, "person_1_age") visit("/case_logs/#{empty_case_log.id}/#{subsection}/check_answers") assert_selector "a", text: /Answer\z/, count: 3 assert_selector "a", text: "Change", count: 1 @@ -296,7 +297,7 @@ RSpec.describe "Test Features" do end it "should have a link pointing to the next empty question if some questions are answered" do - fill_in_number_question(empty_case_log.id, "net_income", 18_000) + fill_in_number_question(empty_case_log.id, "earnings", 18_000, "net_income") visit("/case_logs/#{empty_case_log.id}/income_and_benefits/check_answers") expect(page).to have_content("You answered 1 of 4 questions") @@ -324,7 +325,7 @@ RSpec.describe "Test Features" do it "displays conditional question that were visited" do visit("/case_logs/#{id}/conditional_question") - choose("case-log-pregnancy-no-field") + choose("case-log-preg-occ-no-field") click_button("Save and continue") visit("/case_logs/#{id}/#{conditional_subsection}/check_answers") question_labels = ["Has the condition been met?", "Has the condition not been met?"] @@ -351,13 +352,13 @@ RSpec.describe "Test Features" do visit("/case_logs/#{id}/armed_forces") # Something about our styling makes the selenium webdriver think the actual radio buttons are not visible so we allow label click here choose("case-log-armed-forces-yes-a-regular-field", allow_label_click: true) - expect(page).to have_selector("#armed_forces_injured_div") - choose("case-log-armed-forces-injured-no-field", allow_label_click: true) - expect(page).to have_checked_field("case-log-armed-forces-injured-no-field", visible: false) + expect(page).to have_selector("#reservist_div") + choose("case-log-reservist-no-field", allow_label_click: true) + expect(page).to have_checked_field("case-log-reservist-no-field", visible: false) choose("case-log-armed-forces-no-field", allow_label_click: true) - expect(page).not_to have_selector("#armed_forces_injured_div") + expect(page).not_to have_selector("#reservist_div") choose("case-log-armed-forces-yes-a-regular-field", allow_label_click: true) - expect(page).to have_unchecked_field("case-log-armed-forces-injured-no-field", visible: false) + expect(page).to have_unchecked_field("case-log-reservist-no-field", visible: false) end end end @@ -366,32 +367,32 @@ RSpec.describe "Test Features" do context "given an invalid tenant age" do it " of less than 0 it shows validation" do visit("/case_logs/#{id}/person_1_age") - fill_in_number_question(empty_case_log.id, "person_1_age", -5) + fill_in_number_question(empty_case_log.id, "age1", -5, "person_1_age") expect(page).to have_selector("#error-summary-title") - expect(page).to have_selector("#case-log-person-1-age-error") - expect(page).to have_selector("#case-log-person-1-age-field-error") + expect(page).to have_selector("#case-log-age1-error") + expect(page).to have_selector("#case-log-age1-field-error") end it " of greater than 120 it shows validation" do visit("/case_logs/#{id}/person_1_age") - fill_in_number_question(empty_case_log.id, "person_1_age", 121) + fill_in_number_question(empty_case_log.id, "age1", 121, "person_1_age") expect(page).to have_selector("#error-summary-title") - expect(page).to have_selector("#case-log-person-1-age-error") - expect(page).to have_selector("#case-log-person-1-age-field-error") + expect(page).to have_selector("#case-log-age1-error") + expect(page).to have_selector("#case-log-age1-field-error") end end end describe "Soft Validation" do context "given a weekly net income that is above the expected amount for the given economic status but below the hard max" do - let!(:case_log) { FactoryBot.create(:case_log, :in_progress, person_1_economic_status: "Full-time - 30 hours or more") } + let!(:case_log) { FactoryBot.create(:case_log, :in_progress, ecstat1: "Full-time - 30 hours or more") } let(:income_over_soft_limit) { 750 } let(:income_under_soft_limit) { 700 } it "prompts the user to confirm the value is correct" do visit("/case_logs/#{case_log.id}/net_income") - fill_in("case-log-net-income-field", with: income_over_soft_limit) - choose("case-log-net-income-frequency-weekly-field", allow_label_click: true) + fill_in("case-log-earnings-field", with: income_over_soft_limit) + choose("case-log-incfreq-weekly-field", allow_label_click: true) click_button("Save and continue") expect(page).to have_content("Are you sure this is correct?") check("case-log-override-net-income-validation-override-net-income-validation-field", allow_label_click: true) @@ -401,10 +402,10 @@ RSpec.describe "Test Features" do it "does not require confirming the value if the value is amended" do visit("/case_logs/#{case_log.id}/net_income") - fill_in("case-log-net-income-field", with: income_over_soft_limit) - choose("case-log-net-income-frequency-weekly-field", allow_label_click: true) + fill_in("case-log-earnings-field", with: income_over_soft_limit) + choose("case-log-incfreq-weekly-field", allow_label_click: true) click_button("Save and continue") - fill_in("case-log-net-income-field", with: income_under_soft_limit) + fill_in("case-log-earnings-field", with: income_under_soft_limit) click_button("Save and continue") expect(page).to have_current_path("/case_logs/#{case_log.id}/net_income_uc_proportion") case_log.reload @@ -413,10 +414,10 @@ RSpec.describe "Test Features" do it "clears the confirmation question if the amount was amended and the page is returned to using the back button", js: true do visit("/case_logs/#{case_log.id}/net_income") - fill_in("case-log-net-income-field", with: income_over_soft_limit) - choose("case-log-net-income-frequency-weekly-field", allow_label_click: true) + fill_in("case-log-earnings-field", with: income_over_soft_limit) + choose("case-log-incfreq-weekly-field", allow_label_click: true) click_button("Save and continue") - fill_in("case-log-net-income-field", with: income_under_soft_limit) + fill_in("case-log-earnings-field", with: income_under_soft_limit) click_button("Save and continue") click_link(text: "Back") expect(page).not_to have_content("Are you sure this is correct?") @@ -424,8 +425,8 @@ RSpec.describe "Test Features" do it "does not clear the confirmation question if the page is returned to using the back button and the amount is still over the soft limit", js: true do visit("/case_logs/#{case_log.id}/net_income") - fill_in("case-log-net-income-field", with: income_over_soft_limit) - choose("case-log-net-income-frequency-weekly-field", allow_label_click: true) + fill_in("case-log-earnings-field", with: income_over_soft_limit) + choose("case-log-incfreq-weekly-field", allow_label_click: true) click_button("Save and continue") check("case-log-override-net-income-validation-override-net-income-validation-field", allow_label_click: true) click_button("Save and continue") @@ -442,19 +443,21 @@ RSpec.describe "Test Features" do it "can route the user to a different page based on their answer on the current page" do visit("case_logs/#{id}/conditional_question") - choose("case-log-pregnancy-yes-field", allow_label_click: true) + # using a question name that is already in the db to avoid + # having to add a new column to the db for this test + choose("case-log-preg-occ-yes-field", allow_label_click: true) click_button("Save and continue") expect(page).to have_current_path("/case_logs/#{id}/conditional_question_yes_page") click_link(text: "Back") expect(page).to have_current_path("/case_logs/#{id}/conditional_question") - choose("case-log-pregnancy-no-field", allow_label_click: true) + choose("case-log-preg-occ-no-field", allow_label_click: true) click_button("Save and continue") expect(page).to have_current_path("/case_logs/#{id}/conditional_question_no_page") end it "can route based on page inclusion rules" do visit("/case_logs/#{id}/conditional_question_yes_page") - choose("case-log-cbl-letting-yes-field", allow_label_click: true) + choose("case-log-cbl-yes-field", allow_label_click: true) click_button("Save and continue") expect(page).to have_current_path("/case_logs/#{id}/conditional_question/check_answers") end @@ -467,10 +470,10 @@ RSpec.describe "Test Features" do it "can route based on multiple conditions" do visit("/case_logs/#{id}/person_1_gender") - choose("case-log-person-1-gender-female-field", allow_label_click: true) + choose("case-log-sex1-female-field", allow_label_click: true) click_button("Save and continue") visit("/case_logs/#{id}/conditional_question") - choose("case-log-pregnancy-yes-field", allow_label_click: true) + choose("case-log-preg-occ-yes-field", allow_label_click: true) click_button("Save and continue") expect(page).to have_current_path("/case_logs/#{id}/rent") end diff --git a/spec/fixtures/complete_case_log.json b/spec/fixtures/complete_case_log.json index 9c84a7993..3d466170b 100644 --- a/spec/fixtures/complete_case_log.json +++ b/spec/fixtures/complete_case_log.json @@ -1,130 +1,130 @@ { - "case_log": - { - "tenant_code": "T657", - "person_1_age": 35, - "person_1_gender": "Female", - "tenant_ethnic_group": "White: English/Scottish/Welsh/Northern Irish/British", - "tenant_nationality": "UK national resident in UK", - "previous_housing_situation": "Private sector tenancy", - "armed_forces": "Yes - a regular", - "person_1_economic_status": "Full-time - 30 hours or more", - "household_number_of_other_members": 7, - "person_2_relationship": "Partner", - "person_2_age": 32, - "person_2_gender": "Male", - "person_2_economic_status": "Not seeking work", - "person_3_relationship": "Child - includes young adult and grown-up", - "person_3_age": 12, - "person_3_gender": "Male", - "person_3_economic_status": "Child under 16", - "person_4_relationship": "Child - includes young adult and grown-up", - "person_4_age": 12, - "person_4_gender": "Female", - "person_4_economic_status": "Child under 16", - "person_5_relationship": "Child - includes young adult and grown-up", - "person_5_age": 10, - "person_5_gender": "Non-binary", - "person_5_economic_status": "Child under 16", - "person_6_relationship": "Child - includes young adult and grown-up", - "person_6_age": 5, - "person_6_gender": "Prefer not to say", - "person_6_economic_status": "Child under 16", - "person_7_relationship": "Child - includes young adult and grown-up", - "person_7_age": 5, - "person_7_gender": "Prefer not to say", - "person_7_economic_status": "Child under 16", - "person_8_relationship": "Child - includes young adult and grown-up", - "person_8_age": 2, - "person_8_gender": "Prefer not to say", - "person_8_economic_status": "Child under 16", - "homelessness": "Yes - other homelessness", - "reason_for_leaving_last_settled_home": "Other problems with neighbours", - "benefit_cap_spare_room_subsidy": "No", - "armed_forces_active": "No", - "armed_forces_injured": "No", - "armed_forces_partner": "No", - "medical_conditions": "Yes", - "pregnancy": "No", - "accessibility_requirements": "No", - "condition_effects": "dummy", - "tenancy_code": "BZ757", - "tenancy_start_date": "12/03/2019", - "starter_tenancy": "No", - "fixed_term_tenancy": "5", - "tenancy_type": "Fixed term – Secure", - "letting_type": "Affordable Rent - General Needs", - "letting_provider": "This landlord", - "property_location": "Barnet", - "previous_postcode": "NW1 5TY", - "property_relet": "No", - "property_vacancy_reason": "Relet - tenant abandoned property", - "property_reference": "P9876", - "property_unit_type": "House", - "property_building_type": "dummy", - "property_number_of_bedrooms": 3, - "property_void_date": "03/11/2019", - "property_major_repairs": "Yes", - "property_major_repairs_date": "05/05/2020", - "property_number_of_times_relet": 2, - "property_wheelchair_accessible": true, - "net_income_known": "Yes", - "net_income": 0, - "net_income_frequency": null, - "net_income_uc_proportion": "Some", - "housing_benefit": "Universal Credit with housing element, but not Housing Benefit", - "rent_frequency": "Weekly", - "basic_rent": 200, - "service_charge": 50, - "personal_service_charge": 40, - "support_charge": 35, - "total_charge": 325, - "outstanding_amount": "Yes", - "time_lived_in_la": "1 to 2 years", - "time_on_la_waiting_list": "Less than 1 year", - "previous_la": "Ashford", - "property_postcode": "SE2 6RT", - "reasonable_preference": "Yes", - "reasonable_preference_reason": "dummy", - "cbl_letting": true, - "chr_letting": false, - "cap_letting": false, - "outstanding_rent_or_charges": 25, - "other_reason_for_leaving_last_settled_home": null, - "accessibility_requirements_fully_wheelchair_accessible_housing": true, - "accessibility_requirements_wheelchair_access_to_essential_rooms": false, - "accessibility_requirements_level_access_housing": false, - "accessibility_requirements_other_disability_requirements": false, - "accessibility_requirements_no_disability_requirements": false, - "accessibility_requirements_do_not_know": false, - "accessibility_requirements_prefer_not_to_say": false, - "condition_effects_vision": false, - "condition_effects_hearing": true, - "condition_effects_mobility": false, - "condition_effects_dexterity": false, - "condition_effects_stamina": false, - "condition_effects_learning": false, - "condition_effects_memory": false, - "condition_effects_mental_health": false, - "condition_effects_social_or_behavioral": false, - "condition_effects_other": false, - "condition_effects_prefer_not_to_say": true, - "reasonable_preference_reason_homeless": false, - "reasonable_preference_reason_unsatisfactory_housing": false, - "reasonable_preference_reason_medical_grounds": false, - "reasonable_preference_reason_avoid_hardship": false, - "reasonable_preference_reason_do_not_know": true, - "other_tenancy_type": "", - "gdpr_acceptance": "", - "gdpr_declined": "", - "property_owner_organisation": "", - "property_manager_organisation": "", - "sale_or_letting": "", - "tenant_same_property_renewal": "", - "rent_type": "", - "intermediate_rent_product_name": "", - "needs_type": "", - "sale_completion_date" : "", - "purchaser_code": "" - } + "case_log": { + "tenant_code": "T657", + "age1": 35, + "sex1": "Female", + "ethnic": "White: English/Scottish/Welsh/Northern Irish/British", + "national": "UK national resident in UK", + "prevten": "Private sector tenancy", + "armed_forces": "Yes - a regular", + "ecstat1": "Full-time - 30 hours or more", + "hhmemb": 7, + "relat2": "Partner", + "age2": 32, + "sex2": "Male", + "ecstat2": "Not seeking work", + "relat3": "Child - includes young adult and grown-up", + "age3": 12, + "sex3": "Male", + "ecstat3": "Child under 16", + "relat4": "Child - includes young adult and grown-up", + "age4": 12, + "sex4": "Female", + "ecstat4": "Child under 16", + "relat5": "Child - includes young adult and grown-up", + "age5": 10, + "sex5": "Non-binary", + "ecstat5": "Child under 16", + "relat6": "Child - includes young adult and grown-up", + "age6": 5, + "sex6": "Prefer not to say", + "ecstat6": "Child under 16", + "relat7": "Child - includes young adult and grown-up", + "age7": 5, + "sex7": "Prefer not to say", + "ecstat7": "Child under 16", + "relat8": "Child - includes young adult and grown-up", + "age8": 2, + "sex8": "Prefer not to say", + "ecstat8": "Child under 16", + "homeless": "Yes - other homelessness", + "reason_for_leaving_last_settled_home": "Other problems with neighbours", + "underoccupation_benefitcap": "No", + "leftreg": "No - they left up to 5 years ago", + "reservist": "No", + "armed_forces_partner": "No", + "illness": "Yes", + "preg_occ": "No", + "accessibility_requirements": "No", + "condition_effects": "dummy", + "tenancy_code": "BZ757", + "startdate": "12/03/2019", + "startertenancy": "No", + "tenancylength": "5", + "tenancy": "Fixed term – Secure", + "lettype": "Affordable Rent - General Needs", + "landlord": "This landlord", + "property_location": "Barnet", + "previous_postcode": "NW1 5TY", + "property_relet": "No", + "rsnvac": "Relet - tenant abandoned property", + "property_reference": "P9876", + "unittype_gn": "House", + "property_building_type": "dummy", + "beds": 3, + "property_void_date": "03/11/2019", + "property_major_repairs": "Yes", + "property_major_repairs_date": "05/05/2020", + "offered": 2, + "wchair": "Yes", + "net_income_known": "Yes", + "earnings": 0, + "incfreq": null, + "benefits": "Some", + "housing_benefit": "Universal Credit with housing element, but not Housing Benefit", + "period": "Fortnightly", + "brent": 200, + "scharge": 50, + "pscharge": 40, + "supcharg": 35, + "tcharge": 325, + "outstanding_amount": "Yes", + "layear": "1 to 2 years", + "lawaitlist": "Less than 1 year", + "previous_la": "Ashford", + "property_postcode": "SE2 6RT", + "reasonpref": "Yes", + "reasonable_preference_reason": "dummy", + "cbl": "Yes", + "chr": "Yes", + "cap": "No", + "outstanding_rent_or_charges": 25, + "other_reason_for_leaving_last_settled_home": null, + "housingneeds_a": "Yes", + "housingneeds_b": "No", + "housingneeds_c": "No", + "housingneeds_f": "No", + "housingneeds_g": "No", + "housingneeds_h": "No", + "accessibility_requirements_prefer_not_to_say": "No", + "illness_type_1": "No", + "illness_type_2": "Yes", + "illness_type_3": "No", + "illness_type_4": "No", + "illness_type_8": "No", + "illness_type_5": "No", + "illness_type_6": "No", + "illness_type_7": "No", + "illness_type_9": "No", + "illness_type_10": "No", + "condition_effects_prefer_not_to_say": "Yes", + "rp_homeless": "Yes", + "rp_insan_unsat": "No", + "rp_medwel": "No", + "rp_hardship": "No", + "rp_dontknow": "No", + "discarded_at": "05/05/2020", + "override_net_income_validation": "", + "gdpr_acceptance": "", + "gdpr_declined": "", + "property_owner_organisation": "", + "property_manager_organisation": "", + "sale_or_letting": "", + "tenant_same_property_renewal": "", + "rent_type": "", + "intermediate_rent_product_name": "", + "needs_type": "", + "sale_completion_date": "", + "purchaser_code": "" } +} diff --git a/spec/fixtures/forms/test_form.json b/spec/fixtures/forms/test_form.json index 2bcd34aaa..a52768299 100644 --- a/spec/fixtures/forms/test_form.json +++ b/spec/fixtures/forms/test_form.json @@ -18,7 +18,7 @@ }, "person_1_age": { "questions": { - "person_1_age": { + "age1": { "check_answer_label": "Tenant's age", "header": "What is the tenant's age?", "type": "numeric", @@ -30,7 +30,7 @@ }, "person_1_gender": { "questions": { - "person_1_gender": { + "sex1": { "check_answer_label": "Tenant's gender", "header": "Which of these best describes the tenant's gender identity?", "type": "radio", @@ -45,7 +45,7 @@ }, "household_number_of_other_members": { "questions": { - "household_number_of_other_members": { + "hhmemb": { "check_answer_label": "Number of Other Household Members", "header": "How many other people are there in the household?", "hint_text": "The maximum number of others is 1", @@ -54,13 +54,13 @@ "max": 1, "step": 1, "conditional_for": { - "person_2_relationship": ">0", - "person_2_age": ">0", - "person_2_gender": ">0", - "person_2_economic_status": ">0" + "relat2": ">0", + "age2": ">0", + "sex2": ">0", + "ecstat2": ">0" } }, - "person_2_relationship": { + "relat2": { "check_answer_label": "Person 2's relationship to lead tenant", "header": "What's person 2's relationship to lead tenant", "type": "radio", @@ -69,7 +69,7 @@ "1": "Prefer not to say" } }, - "person_2_age": { + "age2": { "check_answer_label": "Person 2's age", "header": "What's person 2's age", "type": "numeric", @@ -77,7 +77,7 @@ "max": 150, "step": 1 }, - "person_2_gender": { + "sex2": { "check_answer_label": "Person 2's gender", "header": "Which of these best describes person 2's gender identity?", "type": "radio", @@ -88,7 +88,7 @@ "3": "Prefer not to say" } }, - "person_2_economic_status": { + "ecstat2": { "check_answer_label": "Person 2's Work", "header": "Which of these best describes person 2's working situation?", "type": "radio", @@ -118,17 +118,11 @@ "3": "Prefer not to say" }, "conditional_for": { - "armed_forces_active": [ - "Yes - a regular", - "Yes - a reserve" - ], - "armed_forces_injured": [ - "Yes - a regular", - "Yes - a reserve" - ] + "leftreg": ["Yes - a regular", "Yes - a reserve"], + "reservist": ["Yes - a regular", "Yes - a reserve"] } }, - "armed_forces_active": { + "leftreg": { "header": "Are they still serving?", "type": "radio", "check_answer_label": "When did they leave the Armed Forces?", @@ -139,7 +133,7 @@ "3": "Prefer not to say" } }, - "armed_forces_injured": { + "reservist": { "header": "Were they seriously injured or ill as a result of their service?", "type": "radio", "check_answer_label": "Has anyone in the household been seriously injured or ill as a result of their service in the armed forces?", @@ -153,7 +147,7 @@ }, "medical_conditions": { "questions": { - "medical_conditions": { + "illness": { "header": "Does anyone in the household have any of the following that they expect to last for 12 months or more:
  • Physical Condition
  • Mental Health Condition
  • Other Illness
", "type": "radio", "check_answer_label": "Physical, mental health or illness in the household", @@ -174,11 +168,11 @@ "type": "checkbox", "check_answer_label": "Disability requirements", "answer_options": { - "accessibility_requirements_fully_wheelchair_accessible_housing": "Fully wheelchair accessible housing", - "accessibility_requirements_wheelchair_access_to_essential_rooms": "Wheelchair access to essential rooms", - "accessibility_requirements_level_access_housing": "Level access housing", + "housingneeds_a": "Fully wheelchair accessible housing", + "housingneeds_b": "Wheelchair access to essential rooms", + "housingneeds_c": "Level access housing", "divider_a": true, - "accessibility_requirements_do_not_know": "Do not know" + "housingneeds_h": "Do not know" } } } @@ -191,8 +185,8 @@ "type": "checkbox", "check_answer_label": "Conditions or illnesses", "answer_options": { - "condition_effects_vision": "Vision - such as blindness or partial sight", - "condition_effects_hearing": "Hearing - such as deafness or partial hearing" + "illness_type_1": "Vision - such as blindness or partial sight", + "illness_type_2": "Hearing - such as deafness or partial hearing" } } } @@ -223,7 +217,7 @@ "pages": { "property_wheelchair_accessible": { "questions": { - "property_wheelchair_accessible": { + "wchair": { "check_answer_label": "Is property built or adapted to wheelchair user standards?", "header": "Is property built or adapted to wheelchair user standards?", "type": "radio", @@ -241,7 +235,7 @@ "pages": { "conditional_question": { "questions": { - "pregnancy": { + "preg_occ": { "check_answer_label": "Has the condition been met?", "header": "Has the condition been met?", "type": "radio", @@ -252,15 +246,15 @@ } }, "conditional_route_to": { - "rent": { "pregnancy": "Yes", "person_1_gender": "Female" }, - "conditional_question_yes_page": { "pregnancy": "Yes" }, - "conditional_question_no_page": { "pregnancy": "No" } + "rent": { "preg_occ": "Yes", "sex1": "Female" }, + "conditional_question_yes_page": { "preg_occ": "Yes" }, + "conditional_question_no_page": { "preg_occ": "No" } }, "default_next_page": "check_answers" }, "conditional_question_yes_page": { "questions": { - "cbl_letting": { + "cbl": { "check_answer_label": "Has the next condition been met?", "header": "Has the next condition been met?", "type": "radio", @@ -311,14 +305,14 @@ "pages": { "net_income": { "questions": { - "net_income": { + "earnings": { "check_answer_label": "Income", "header": "What is the tenant’s /and partner’s combined income after tax?", "type": "numeric", "min": 0, "step": "1" }, - "net_income_frequency": { + "incfreq": { "check_answer_label": "Income Frequency", "header": "How often do they receive this income?", "type": "radio", @@ -341,7 +335,7 @@ }, "net_income_uc_proportion": { "questions": { - "net_income_uc_proportion": { + "benefits": { "check_answer_label": "Benefits as a proportion of income", "header": "How much of the tenant’s income is from Universal Credit, state pensions or benefits?", "type": "radio", @@ -381,7 +375,7 @@ "1": "Fortnightly" } }, - "basic_rent": { + "brent": { "check_answer_label": "Basic Rent", "header": "What is the basic rent?", "hint_text": "Eligible for housing benefit or Universal Credit", @@ -389,14 +383,14 @@ "min": 0, "step": 1, "fields-to-add": [ - "basic_rent", - "service_charge", - "personal_service_charge", - "support_charge" + "brent", + "scharge", + "pscharge", + "supcharg" ], - "result-field": "total_charge" + "result-field": "tcharge" }, - "service_charge": { + "scharge": { "check_answer_label": "Service Charge", "header": "What is the service charge?", "hint_text": "Eligible for housing benefit or Universal Credit", @@ -404,14 +398,14 @@ "min": 0, "step": 1, "fields-to-add": [ - "basic_rent", - "service_charge", - "personal_service_charge", - "support_charge" + "brent", + "scharge", + "pscharge", + "supcharg" ], - "result-field": "total_charge" + "result-field": "tcharge" }, - "personal_service_charge": { + "pscharge": { "check_answer_label": "Personal Service Charge", "header": "What is the personal service charge?", "hint_text": "Not eligible for housing benefit or Universal Credit. For example, hot water excluding water rates.", @@ -419,14 +413,14 @@ "min": 0, "step": 1, "fields-to-add": [ - "basic_rent", - "service_charge", - "personal_service_charge", - "support_charge" + "brent", + "scharge", + "pscharge", + "supcharg" ], - "result-field": "total_charge" + "result-field": "tcharge" }, - "support_charge": { + "supcharg": { "check_answer_label": "Support Charge", "header": "What is the support charge?", "hint_text": "This is to fund housing-related support services included in the tenancy agreement", @@ -434,14 +428,14 @@ "min": 0, "step": 1, "fields-to-add": [ - "basic_rent", - "service_charge", - "personal_service_charge", - "support_charge" + "brent", + "scharge", + "pscharge", + "supcharg" ], - "result-field": "total_charge" + "result-field": "tcharge" }, - "total_charge": { + "tcharge": { "check_answer_label": "Total Charge", "header": "Total charge?", "hint_text": "This is the total of rent and all charges", @@ -464,7 +458,7 @@ "pages": { "time_lived_in_la": { "questions": { - "time_lived_in_la": { + "layear": { "check_answer_label": "How long has the household continuously lived in the local authority area where the new letting is located?", "header": "How long has the household continuously lived in the local authority area where the new letting is located?", "type": "radio", @@ -483,7 +477,7 @@ }, "time_on_la_waiting_list": { "questions": { - "time_on_la_waiting_list": { + "lawaitlist": { "check_answer_label": "How long has the household been on the local authority waiting list where the new letting is located?", "header": "How long has the household been on the local authority waiting list where the new letting is located?", "type": "radio", diff --git a/spec/helpers/check_answers_helper_spec.rb b/spec/helpers/check_answers_helper_spec.rb index 5ac16b2bd..fb8deec77 100644 --- a/spec/helpers/check_answers_helper_spec.rb +++ b/spec/helpers/check_answers_helper_spec.rb @@ -6,14 +6,14 @@ RSpec.describe CheckAnswersHelper do FactoryBot.create( :case_log, :in_progress, - household_number_of_other_members: 1, - person_2_relationship: "Partner", + hhmemb: 1, + relat2: "Partner", ) end let(:case_log_with_met_radio_condition) do FactoryBot.create(:case_log, armed_forces: "Yes - a regular", - armed_forces_injured: "No", - armed_forces_active: "Yes") + reservist: "No", + leftreg: "Yes") end let(:subsection) { "income_and_benefits" } let(:subsection_with_numeric_conditionals) { "household_characteristics" } @@ -29,7 +29,7 @@ RSpec.describe CheckAnswersHelper do end it "returns 1 if 1 question gets answered" do - case_log["net_income"] = "123" + case_log["earnings"] = "123" expect(total_answered_questions(subsection, case_log, form)).to equal(1) end @@ -52,8 +52,8 @@ RSpec.describe CheckAnswersHelper do end it "includes conditional questions with met radio conditions" do - case_log_with_met_radio_condition["armed_forces_injured"] = "No" - case_log_with_met_radio_condition["medical_conditions"] = "No" + case_log_with_met_radio_condition["reservist"] = "No" + case_log_with_met_radio_condition["illness"] = "No" expect(total_answered_questions( subsection_with_radio_conditionals, case_log_with_met_radio_condition, @@ -113,12 +113,12 @@ RSpec.describe CheckAnswersHelper do end it "counts correct questions when the conditional question is answered" do - case_log["pregnancy"] = "Yes" + case_log["preg_occ"] = "Yes" expect(total_number_of_questions(conditional_routing_subsection, case_log, form)).to eq(2) end it "counts correct questions when the conditional question is answered" do - case_log["pregnancy"] = "No" + case_log["preg_occ"] = "No" expect(total_number_of_questions(conditional_routing_subsection, case_log, form)).to eq(3) end end @@ -127,21 +127,21 @@ RSpec.describe CheckAnswersHelper do it "returns total questions" do result = total_questions(subsection, case_log, form) expect(result.class).to eq(Hash) - expected_keys = %w[net_income net_income_frequency net_income_uc_proportion housing_benefit] + expected_keys = %w[earnings incfreq benefits housing_benefit] expect(result.keys).to eq(expected_keys) end context "conditional questions on the same page" do it "it filters out conditional questions that were not displayed" do result = total_questions(conditional_page_subsection, case_log, form) - expected_keys = %w[armed_forces medical_conditions accessibility_requirements condition_effects] + expected_keys = %w[armed_forces illness accessibility_requirements condition_effects] expect(result.keys).to eq(expected_keys) end it "it includes conditional questions that were displayed" do case_log["armed_forces"] = "Yes - a regular" result = total_questions(conditional_page_subsection, case_log, form) - expected_keys = %w[armed_forces armed_forces_active armed_forces_injured medical_conditions accessibility_requirements condition_effects] + expected_keys = %w[armed_forces leftreg reservist illness accessibility_requirements condition_effects] expect(result.keys).to eq(expected_keys) end end @@ -149,22 +149,22 @@ RSpec.describe CheckAnswersHelper do context "conditional routing" do it "it ignores skipped pages and the questions therein when conditional routing" do result = total_questions(conditional_routing_subsection, case_log, form) - expected_keys = %w[pregnancy] + expected_keys = %w[preg_occ] expect(result.keys).to match_array(expected_keys) end it "it includes conditional pages and questions that were displayed" do - case_log["pregnancy"] = "Yes" - case_log["person_1_gender"] = "Female" + case_log["preg_occ"] = "Yes" + case_log["sex1"] = "Female" result = total_questions(conditional_routing_subsection, case_log, form) - expected_keys = %w[pregnancy] + expected_keys = %w[preg_occ] expect(result.keys).to match_array(expected_keys) end it "it includes conditional pages and questions that were displayed" do - case_log["pregnancy"] = "No" + case_log["preg_occ"] = "No" result = total_questions(conditional_routing_subsection, case_log, form) - expected_keys = %w[pregnancy conditional_question_no_question conditional_question_no_second_question] + expected_keys = %w[preg_occ conditional_question_no_question conditional_question_no_second_question] expect(result.keys).to match_array(expected_keys) end end diff --git a/spec/helpers/conditional_questions_helper_spec.rb b/spec/helpers/conditional_questions_helper_spec.rb index 0c611f635..b02f79a56 100644 --- a/spec/helpers/conditional_questions_helper_spec.rb +++ b/spec/helpers/conditional_questions_helper_spec.rb @@ -7,7 +7,7 @@ RSpec.describe ConditionalQuestionsHelper do let(:page) { form.all_pages[page_key] } describe "conditional questions for page" do - let(:conditional_pages) { %w[armed_forces_active armed_forces_injured] } + let(:conditional_pages) { %w[leftreg reservist] } it "returns the question keys of all conditional questions on the given page" do expect(conditional_questions_for_page(page)).to eq(conditional_pages) @@ -16,7 +16,7 @@ RSpec.describe ConditionalQuestionsHelper do describe "display question key div" do let(:question_key) { "armed_forces" } - let(:conditional_question_key) { "armed_forces_injured" } + let(:conditional_question_key) { "reservist" } it "returns a non visible div for conditional questions" do expect(display_question_key_div(page, conditional_question_key)).to match("style='display:none;'") diff --git a/spec/helpers/question_attribute_helper_spec.rb b/spec/helpers/question_attribute_helper_spec.rb index 5dce09cd6..9ec3248d0 100644 --- a/spec/helpers/question_attribute_helper_spec.rb +++ b/spec/helpers/question_attribute_helper_spec.rb @@ -7,15 +7,15 @@ RSpec.describe QuestionAttributeHelper do describe "html attributes" do it "returns empty hash if fields-to-add or result-field are empty " do - expect(stimulus_html_attributes(questions["total_charge"])).to eq({}) + expect(stimulus_html_attributes(questions["tcharge"])).to eq({}) end it "returns html attributes if fields-to-add or result-field are not empty " do - expect(stimulus_html_attributes(questions["basic_rent"])).to eq({ + expect(stimulus_html_attributes(questions["brent"])).to eq({ "data-controller": "numeric-question", "data-action": "numeric-question#calculateFields", - "data-target": "case-log-#{questions['basic_rent']['result-field'].to_s.dasherize}-field", - "data-calculated": questions["basic_rent"]["fields-to-add"].to_json, + "data-target": "case-log-#{questions['brent']['result-field'].to_s.dasherize}-field", + "data-calculated": questions["brent"]["fields-to-add"].to_json, }) end @@ -28,8 +28,8 @@ RSpec.describe QuestionAttributeHelper do "type" => "numeric", "min" => 0, "step" => 1, - "fields-to-add" => %w[basic_rent service_charge personal_service_charge support_charge], - "result-field" => "total_charge", + "fields-to-add" => %w[brent scharge pscharge supcharg], + "result-field" => "tcharge", "conditional_for" => { "next_question": ">1", }, diff --git a/spec/helpers/tasklist_helper_spec.rb b/spec/helpers/tasklist_helper_spec.rb index 2d821e3f3..db9ac3cae 100644 --- a/spec/helpers/tasklist_helper_spec.rb +++ b/spec/helpers/tasklist_helper_spec.rb @@ -30,7 +30,11 @@ RSpec.describe TasklistHelper do end it "returns completed if all the questions in the subsection have been answered" do - %w[net_income net_income_frequency net_income_uc_proportion housing_benefit].each { |x| case_log[x] = "value" } + case_log["earnings"] = "value" + case_log["incfreq"] = "Weekly" + case_log["benefits"] = "All" + case_log["housing_benefit"] = "Do not know" + status = get_subsection_status("income_and_benefits", case_log, income_and_benefits_questions) expect(status).to eq(:completed) end diff --git a/spec/models/case_log_spec.rb b/spec/models/case_log_spec.rb index 684488a96..75bc1f1a6 100644 --- a/spec/models/case_log_spec.rb +++ b/spec/models/case_log_spec.rb @@ -3,46 +3,46 @@ require "rails_helper" RSpec.describe Form, type: :model do describe "#new" do it "validates age is a number" do - expect { CaseLog.create!(person_1_age: "random") }.to raise_error(ActiveRecord::RecordInvalid) + expect { CaseLog.create!(age1: "random") }.to raise_error(ActiveRecord::RecordInvalid) end it "validates age is under 120" do - expect { CaseLog.create!(person_1_age: 121) }.to raise_error(ActiveRecord::RecordInvalid) + expect { CaseLog.create!(age1: 121) }.to raise_error(ActiveRecord::RecordInvalid) end it "validates age is over 0" do - expect { CaseLog.create!(person_1_age: 0) }.to raise_error(ActiveRecord::RecordInvalid) + expect { CaseLog.create!(age1: 0) }.to raise_error(ActiveRecord::RecordInvalid) end it "validates number of relets is a number" do - expect { CaseLog.create!(property_number_of_times_relet: "random") }.to raise_error(ActiveRecord::RecordInvalid) + expect { CaseLog.create!(offered: "random") }.to raise_error(ActiveRecord::RecordInvalid) end it "validates number of relets is under 20" do - expect { CaseLog.create!(property_number_of_times_relet: 21) }.to raise_error(ActiveRecord::RecordInvalid) + expect { CaseLog.create!(offered: 21) }.to raise_error(ActiveRecord::RecordInvalid) end it "validates number of relets is over 0" do - expect { CaseLog.create!(property_number_of_times_relet: 0) }.to raise_error(ActiveRecord::RecordInvalid) + expect { CaseLog.create!(offered: 0) }.to raise_error(ActiveRecord::RecordInvalid) end context "reasonable preference validation" do it "if given reasonable preference is yes a reason must be selected" do expect { - CaseLog.create!(reasonable_preference: "Yes", - reasonable_preference_reason_homeless: nil, - reasonable_preference_reason_unsatisfactory_housing: nil, - reasonable_preference_reason_medical_grounds: nil, - reasonable_preference_reason_avoid_hardship: nil, - reasonable_preference_reason_do_not_know: nil) + CaseLog.create!(reasonpref: "Yes", + rp_homeless: nil, + rp_insan_unsat: nil, + rp_medwel: nil, + rp_hardship: nil, + rp_dontknow: nil) }.to raise_error(ActiveRecord::RecordInvalid) end it "if not previously homeless reasonable preference should not be selected" do expect { CaseLog.create!( - homelessness: "No", - reasonable_preference: "Yes", + homeless: "No", + reasonpref: "Yes", ) }.to raise_error(ActiveRecord::RecordInvalid) end @@ -50,9 +50,9 @@ RSpec.describe Form, type: :model do it "if not given reasonable preference a reason should not be selected" do expect { CaseLog.create!( - homelessness: "Yes", - reasonable_preference: "No", - reasonable_preference_reason_homeless: true, + homeless: "Yes - other homelessness", + reasonpref: "No", + rp_homeless: "Yes", ) }.to raise_error(ActiveRecord::RecordInvalid) end @@ -61,7 +61,7 @@ RSpec.describe Form, type: :model do it "Reason for leaving must be don't know if reason for leaving settled home (Q9a) is don't know." do expect { CaseLog.create!(reason_for_leaving_last_settled_home: "Do not know", - benefit_cap_spare_room_subsidy: "Yes - benefit cap") + underoccupation_benefitcap: "Yes - benefit cap") }.to raise_error(ActiveRecord::RecordInvalid) end end @@ -85,14 +85,14 @@ RSpec.describe Form, type: :model do it "must be answered if tenant was a regular or reserve in armed forces" do expect { CaseLog.create!(armed_forces: "Yes - a regular", - armed_forces_injured: nil) + reservist: nil) }.to raise_error(ActiveRecord::RecordInvalid) end it "must be answered if tenant was not a regular or reserve in armed forces" do expect { CaseLog.create!(armed_forces: "No", - armed_forces_injured: "Yes") + reservist: "Yes") }.to raise_error(ActiveRecord::RecordInvalid) end end @@ -100,38 +100,38 @@ RSpec.describe Form, type: :model do context "Shared accomodation bedrooms validation" do it "you must have more than zero bedrooms" do expect { - CaseLog.create!(property_unit_type: "Shared house", - property_number_of_bedrooms: 0) + CaseLog.create!(unittype_gn: "Shared house", + beds: 0) }.to raise_error(ActiveRecord::RecordInvalid) end it "you must answer less than 8 bedrooms" do expect { - CaseLog.create!(property_unit_type: "Shared bungalow", - property_number_of_bedrooms: 8, - household_number_of_other_members: 1) + CaseLog.create!(unittype_gn: "Shared bungalow", + beds: 8, + hhmemb: 1) }.to raise_error(ActiveRecord::RecordInvalid) end it "you must answer less than 8 bedrooms" do expect { - CaseLog.create!(property_unit_type: "Shared bungalow", - property_number_of_bedrooms: 4, - household_number_of_other_members: 0) + CaseLog.create!(unittype_gn: "Shared bungalow", + beds: 4, + hhmemb: 0) }.to raise_error(ActiveRecord::RecordInvalid) end it "A bedsit must only have one room" do expect { - CaseLog.create!(property_unit_type: "Bed-sit", - property_number_of_bedrooms: 2) + CaseLog.create!(unittype_gn: "Bed-sit", + beds: 2) }.to raise_error(ActiveRecord::RecordInvalid) end it "A bedsit must only have one room" do expect { - CaseLog.create!(property_unit_type: "Bed-sit", - property_number_of_bedrooms: 0) + CaseLog.create!(unittype_gn: "Bed-sit", + beds: 0) }.to raise_error(ActiveRecord::RecordInvalid) end end @@ -155,19 +155,19 @@ RSpec.describe Form, type: :model do context "tenant’s income is from Universal Credit, state pensions or benefits" do it "Cannot be All if person 1 works full time" do expect { - CaseLog.create!(net_income_uc_proportion: "All", person_1_economic_status: "Full-time - 30 hours or more") + CaseLog.create!(benefits: "All", ecstat1: "Full-time - 30 hours or more") }.to raise_error(ActiveRecord::RecordInvalid) end it "Cannot be All if person 1 works part time" do expect { - CaseLog.create!(net_income_uc_proportion: "All", person_1_economic_status: "Part-time - Less than 30 hours") + CaseLog.create!(benefits: "All", ecstat1: "Part-time - Less than 30 hours") }.to raise_error(ActiveRecord::RecordInvalid) end it "Cannot be 1 All if any of persons 2-4 are person 1's partner and work part or full time" do expect { - CaseLog.create!(net_income_uc_proportion: "All", person_2_relationship: "Partner", person_2_economic_status: "Part-time - Less than 30 hours") + CaseLog.create!(benefits: "All", relat2: "Partner", ecstat2: "Part-time - Less than 30 hours") }.to raise_error(ActiveRecord::RecordInvalid) end end @@ -175,47 +175,47 @@ RSpec.describe Form, type: :model do context "fixed term tenancy length" do it "Must not be completed if Type of main tenancy is not responded with either Secure or Assured shorthold " do expect { - CaseLog.create!(tenancy_type: "Other", - fixed_term_tenancy: 10) + CaseLog.create!(tenancy: "Other", + tenancylength: 10) }.to raise_error(ActiveRecord::RecordInvalid) end it "Must be completed and between 2 and 99 if type of tenancy is Assured shorthold" do expect { - CaseLog.create!(tenancy_type: "Fixed term – Assured Shorthold Tenancy (AST)", - fixed_term_tenancy: 1) + CaseLog.create!(tenancy: "Fixed term – Assured Shorthold Tenancy (AST)", + tenancylength: 1) }.to raise_error(ActiveRecord::RecordInvalid) expect { - CaseLog.create!(tenancy_type: "Fixed term – Assured Shorthold Tenancy (AST)", - fixed_term_tenancy: nil) + CaseLog.create!(tenancy: "Fixed term – Assured Shorthold Tenancy (AST)", + tenancylength: nil) }.to raise_error(ActiveRecord::RecordInvalid) expect { - CaseLog.create!(tenancy_type: "Fixed term – Assured Shorthold Tenancy (AST)", - fixed_term_tenancy: 2) + CaseLog.create!(tenancy: "Fixed term – Assured Shorthold Tenancy (AST)", + tenancylength: 2) }.not_to raise_error end it "Must be empty or between 2 and 99 if type of tenancy is Secure" do expect { - CaseLog.create!(tenancy_type: "Fixed term – Secure", - fixed_term_tenancy: 1) + CaseLog.create!(tenancy: "Fixed term – Secure", + tenancylength: 1) }.to raise_error(ActiveRecord::RecordInvalid) expect { - CaseLog.create!(tenancy_type: "Fixed term – Secure", - fixed_term_tenancy: 100) + CaseLog.create!(tenancy: "Fixed term – Secure", + tenancylength: 100) }.to raise_error(ActiveRecord::RecordInvalid) expect { - CaseLog.create!(tenancy_type: "Fixed term – Secure", - fixed_term_tenancy: nil) + CaseLog.create!(tenancy: "Fixed term – Secure", + tenancylength: nil) }.not_to raise_error expect { - CaseLog.create!(tenancy_type: "Fixed term – Secure", - fixed_term_tenancy: 2) + CaseLog.create!(tenancy: "Fixed term – Secure", + tenancylength: 2) }.not_to raise_error end end @@ -224,14 +224,14 @@ RSpec.describe Form, type: :model do it "must be answered if ever served in the forces as a regular" do expect { CaseLog.create!(armed_forces: "Yes - a regular", - armed_forces_active: nil) + leftreg: nil) }.to raise_error(ActiveRecord::RecordInvalid) end it "must not be answered if not ever served as a regular" do expect { CaseLog.create!(armed_forces: "No", - armed_forces_active: "Yes") + leftreg: "Yes") }.to raise_error(ActiveRecord::RecordInvalid) end @@ -239,68 +239,68 @@ RSpec.describe Form, type: :model do it "must be answered if ever served in the forces as a regular" do expect do CaseLog.create!(armed_forces: "Yes - a regular", - armed_forces_active: "Yes", - armed_forces_injured: "Yes") + leftreg: "Yes", + reservist: "Yes") end end end context "household_member_validations" do it "validate that persons aged under 16 must have relationship Child" do - expect { CaseLog.create!(person_2_age: 14, person_2_relationship: "Partner") }.to raise_error(ActiveRecord::RecordInvalid) + expect { CaseLog.create!(age2: 14, relat2: "Partner") }.to raise_error(ActiveRecord::RecordInvalid) end it "validate that persons aged over 70 must be retired" do - expect { CaseLog.create!(person_2_age: 71, person_2_economic_status: "Full-time - 30 hours or more") }.to raise_error(ActiveRecord::RecordInvalid) + expect { CaseLog.create!(age2: 71, ecstat2: "Full-time - 30 hours or more") }.to raise_error(ActiveRecord::RecordInvalid) end it "validate that a male, retired persons must be over 65" do - expect { CaseLog.create!(person_2_age: 64, person_2_gender: "Male", person_2_economic_status: "Retired") }.to raise_error(ActiveRecord::RecordInvalid) + expect { CaseLog.create!(age2: 64, sex2: "Male", ecstat2: "Retired") }.to raise_error(ActiveRecord::RecordInvalid) end it "validate that a female, retired persons must be over 60" do - expect { CaseLog.create!(person_2_age: 59, person_2_gender: "Female", person_2_economic_status: "Retired") }.to raise_error(ActiveRecord::RecordInvalid) + expect { CaseLog.create!(age2: 59, sex2: "Female", ecstat2: "Retired") }.to raise_error(ActiveRecord::RecordInvalid) end it "validate that persons aged under 16 must be a child (economically speaking)" do - expect { CaseLog.create!(person_2_age: 15, person_2_economic_status: "Full-time - 30 hours or more") }.to raise_error(ActiveRecord::RecordInvalid) + expect { CaseLog.create!(age2: 15, ecstat2: "Full-time - 30 hours or more") }.to raise_error(ActiveRecord::RecordInvalid) end it "validate that persons aged between 16 and 19 that are a child must be a full time student or economic status refused" do - expect { CaseLog.create!(person_2_age: 17, person_2_relationship: "Child - includes young adult and grown-up", person_2_economic_status: "Full-time - 30 hours or more") }.to raise_error(ActiveRecord::RecordInvalid) + expect { CaseLog.create!(age2: 17, relat2: "Child - includes young adult and grown-up", ecstat2: "Full-time - 30 hours or more") }.to raise_error(ActiveRecord::RecordInvalid) end it "validate that persons aged under 16 must be a child relationship" do - expect { CaseLog.create!(person_2_age: 15, person_2_relationship: "Partner") }.to raise_error(ActiveRecord::RecordInvalid) + expect { CaseLog.create!(age2: 15, relat2: "Partner") }.to raise_error(ActiveRecord::RecordInvalid) end it "validate that no more than 1 partner relationship exists" do - expect { CaseLog.create!(person_2_relationship: "Partner", person_3_relationship: "Partner") }.to raise_error(ActiveRecord::RecordInvalid) + expect { CaseLog.create!(relat2: "Partner", relat3: "Partner") }.to raise_error(ActiveRecord::RecordInvalid) end end context "other tenancy type validation" do it "must be provided if tenancy type was given as other" do expect { - CaseLog.create!(tenancy_type: "Other", - other_tenancy_type: nil) + CaseLog.create!(tenancy: "Other", + tenancyother: nil) }.to raise_error(ActiveRecord::RecordInvalid) expect { - CaseLog.create!(tenancy_type: "Other", - other_tenancy_type: "type") + CaseLog.create!(tenancy: "Other", + tenancyother: "type") }.not_to raise_error end it "must not be provided if tenancy type is not other" do expect { - CaseLog.create!(tenancy_type: "Fixed", - other_tenancy_type: "the other reason provided") + CaseLog.create!(tenancy: "Fixed term – Secure", + tenancyother: "the other reason provided") }.to raise_error(ActiveRecord::RecordInvalid) expect { - CaseLog.create!(tenancy_type: "Fixed", - other_tenancy_type: nil) + CaseLog.create!(tenancy: "Fixed term – Secure", + tenancyother: nil) }.not_to raise_error end end @@ -309,9 +309,9 @@ RSpec.describe Form, type: :model do it "validates net income maximum" do expect { CaseLog.create!( - person_1_economic_status: "Full-time - 30 hours or more", - net_income: 5000, - net_income_frequency: "Weekly", + ecstat1: "Full-time - 30 hours or more", + earnings: 5000, + incfreq: "Weekly", ) }.to raise_error(ActiveRecord::RecordInvalid) end @@ -319,9 +319,9 @@ RSpec.describe Form, type: :model do it "validates net income minimum" do expect { CaseLog.create!( - person_1_economic_status: "Full-time - 30 hours or more", - net_income: 1, - net_income_frequency: "Weekly", + ecstat1: "Full-time - 30 hours or more", + earnings: 1, + incfreq: "Weekly", ) }.to raise_error(ActiveRecord::RecordInvalid) end @@ -347,20 +347,20 @@ RSpec.describe Form, type: :model do describe "weekly_net_income" do let(:net_income) { 5000 } - let(:case_log) { FactoryBot.build(:case_log, net_income: net_income) } + let(:case_log) { FactoryBot.build(:case_log, earnings: net_income) } it "returns input income if frequency is already weekly" do - case_log.net_income_frequency = "Weekly" + case_log.incfreq = "Weekly" expect(case_log.weekly_net_income).to eq(net_income) end it "calculates the correct weekly income from monthly income" do - case_log.net_income_frequency = "Monthly" + case_log.incfreq = "Monthly" expect(case_log.weekly_net_income).to eq(1154) end it "calculates the correct weekly income from yearly income" do - case_log.net_income_frequency = "Yearly" + case_log.incfreq = "Yearly" expect(case_log.weekly_net_income).to eq(417) end end diff --git a/spec/models/form_spec.rb b/spec/models/form_spec.rb index f11431c8b..f4e554356 100644 --- a/spec/models/form_spec.rb +++ b/spec/models/form_spec.rb @@ -39,7 +39,7 @@ RSpec.describe Form, type: :model do it "returns all questions for subsection" do result = form.questions_for_subsection(subsection) expect(result.length).to eq(4) - expect(result.keys).to eq(%w[net_income net_income_frequency net_income_uc_proportion housing_benefit]) + expect(result.keys).to eq(%w[earnings incfreq benefits housing_benefit]) end end end diff --git a/spec/requests/case_log_controller_spec.rb b/spec/requests/case_log_controller_spec.rb index d3f67683b..55a1c9821 100644 --- a/spec/requests/case_log_controller_spec.rb +++ b/spec/requests/case_log_controller_spec.rb @@ -24,8 +24,8 @@ RSpec.describe CaseLogsController, type: :request do describe "POST #create" do let(:tenant_code) { "T365" } - let(:person_1_age) { 35 } - let(:property_number_of_times_relet) { 12 } + let(:age1) { 35 } + let(:offered) { 12 } let(:property_postcode) { "SE11 6TY" } let(:in_progress) { "in_progress" } let(:completed) { "completed" } @@ -33,9 +33,9 @@ RSpec.describe CaseLogsController, type: :request do let(:params) do { "tenant_code": tenant_code, - "person_1_age": person_1_age, + "age1": age1, "property_postcode": property_postcode, - "property_number_of_times_relet": property_number_of_times_relet, + "offered": offered, } end @@ -55,18 +55,18 @@ RSpec.describe CaseLogsController, type: :request do it "creates a case log with the values passed" do json_response = JSON.parse(response.body) expect(json_response["tenant_code"]).to eq(tenant_code) - expect(json_response["person_1_age"]).to eq(person_1_age) + expect(json_response["age1"]).to eq(age1) expect(json_response["property_postcode"]).to eq(property_postcode) end context "invalid json params" do - let(:person_1_age) { 2000 } - let(:property_number_of_times_relet) { 21 } + let(:age1) { 2000 } + let(:offered) { 21 } it "validates case log parameters" do json_response = JSON.parse(response.body) expect(response).to have_http_status(:unprocessable_entity) - expect(json_response["errors"]).to match_array([["property_number_of_times_relet", ["Property number of times relet must be between 0 and 20"]], ["person_1_age", ["Tenant age must be an integer between 16 and 120"]]]) + expect(json_response["errors"]).to match_array([["offered", ["Property number of times relet must be between 0 and 20"]], ["age1", ["Tenant age must be an integer between 16 and 120"]]]) end end @@ -157,7 +157,7 @@ RSpec.describe CaseLogsController, type: :request do end context "invalid case log params" do - let(:params) { { person_1_age: 200 } } + let(:params) { { age1: 200 } } it "returns 422" do expect(response).to have_http_status(:unprocessable_entity) @@ -165,7 +165,7 @@ RSpec.describe CaseLogsController, type: :request do it "returns an error message" do json_response = JSON.parse(response.body) - expect(json_response["errors"]).to eq({ "person_1_age" => ["Tenant age must be an integer between 16 and 120"] }) + expect(json_response["errors"]).to eq({ "age1" => ["Tenant age must be an integer between 16 and 120"] }) end end From 3a753364ebae5257b2e1d7c502def600831e5d87 Mon Sep 17 00:00:00 2001 From: Daniel Baark <5101747+baarkerlounger@users.noreply.github.com> Date: Fri, 5 Nov 2021 17:18:39 +0000 Subject: [PATCH 17/29] Soft validations with controllers (#77) * Working except for selenium checkbox issues * Remove old debug message * Make sure we only run the stimulus init once per page load * Revert that * Rubocop * Use data targets rather than id lookup, so that coupling is explicit * Use fetch * Schema update * No schema changes introduced here * Add a request spec for the new controller * Schema order did change * map over forEach * Update factory fields * Int for booleans :( * Fix spec fields * Lazy create --- Gemfile.lock | 8 ++-- app/controllers/case_logs_controller.rb | 4 +- .../soft_validations_controller.rb | 20 ++++++++++ .../conditional_question_controller.js | 7 ++-- .../soft_validations_controller.js | 28 +++++++++++++ app/validations/soft_validations.rb | 2 +- .../_validation_override_question.html.erb | 17 ++++---- app/views/form/page.html.erb | 8 ++-- config/routes.rb | 1 + ...0211105164644_change_net_income_overide.rb | 9 +++++ db/schema.rb | 4 +- spec/factories/case_log.rb | 6 +++ spec/features/case_log_spec.rb | 17 ++++++-- .../soft_validations_controller_spec.rb | 39 +++++++++++++++++++ 14 files changed, 142 insertions(+), 28 deletions(-) create mode 100644 app/controllers/soft_validations_controller.rb create mode 100644 app/javascript/controllers/soft_validations_controller.js create mode 100644 db/migrate/20211105164644_change_net_income_overide.rb create mode 100644 spec/requests/soft_validations_controller_spec.rb diff --git a/Gemfile.lock b/Gemfile.lock index 386f2d68b..fa3d1a27d 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -1,6 +1,6 @@ GIT remote: https://github.com/rspec/rspec-core.git - revision: d57c371ee92b16211b80ac7b0b025968438f5297 + revision: 42a9fe3a2dc9d5e68811ee646f4b9b4349c18b24 branch: main specs: rspec-core (3.11.0.pre) @@ -40,7 +40,7 @@ GIT GIT remote: https://github.com/rspec/rspec-support.git - revision: 2a17194b9fc868a4b4a41d7168103dca825c3004 + revision: 9499cb622f9feef43a53f357809f9e656e7cb6de branch: main specs: rspec-support (3.11.0.pre) @@ -182,7 +182,7 @@ GEM rails (>= 6.0.0) stimulus-rails turbo-rails - i18n (1.8.10) + i18n (1.8.11) concurrent-ruby (~> 1.0) inherited_resources (1.13.0) actionpack (>= 5.2, < 6.2) @@ -309,7 +309,7 @@ GEM rubocop-rails (= 2.12.2) rubocop-rake (= 0.6.0) rubocop-rspec (= 2.4.0) - rubocop-performance (1.11.5) + rubocop-performance (1.12.0) rubocop (>= 1.7.0, < 2.0) rubocop-ast (>= 0.4.0) rubocop-rails (2.12.2) diff --git a/app/controllers/case_logs_controller.rb b/app/controllers/case_logs_controller.rb index 460dfe71d..cc2a4b484 100644 --- a/app/controllers/case_logs_controller.rb +++ b/app/controllers/case_logs_controller.rb @@ -105,9 +105,9 @@ private question_params = params["case_log"][question_key] next unless question_params - if question_info["type"] == "checkbox" + if %w[checkbox validation_override].include?(question_info["type"]) question_info["answer_options"].keys.reject { |x| x.match(/divider/) }.each do |option| - result[option] = question_params.include?(option) ? "Yes" : "No" + result[option] = question_params.include?(option) ? 1 : 0 end else result[question_key] = question_params diff --git a/app/controllers/soft_validations_controller.rb b/app/controllers/soft_validations_controller.rb new file mode 100644 index 000000000..ad28ea25e --- /dev/null +++ b/app/controllers/soft_validations_controller.rb @@ -0,0 +1,20 @@ +class SoftValidationsController < ApplicationController + def show + @case_log = CaseLog.find(params[:case_log_id]) + page_key = request.env["PATH_INFO"].split("/")[-2] + form = FormHandler.instance.get_form("2021_2022") + page = form.all_pages[page_key] + if page_requires_soft_validation_override?(page) + errors = @case_log.soft_errors.values.first + render json: { show: true, label: errors.message, hint: errors.hint_text } + else + render json: { show: false } + end + end + +private + + def page_requires_soft_validation_override?(page) + @case_log.soft_errors.present? && @case_log.soft_errors.keys.first == page["soft_validations"]&.keys&.first + end +end diff --git a/app/javascript/controllers/conditional_question_controller.js b/app/javascript/controllers/conditional_question_controller.js index 9aa6fddee..53293543d 100644 --- a/app/javascript/controllers/conditional_question_controller.js +++ b/app/javascript/controllers/conditional_question_controller.js @@ -12,7 +12,6 @@ export default class extends Controller { case "radio": this.displayConditionalRadio() default: - console.log("Not yet implemented for " + this.element.type) break; } } @@ -22,7 +21,7 @@ export default class extends Controller { let selectedValue = this.element.value let conditional_for = JSON.parse(this.element.dataset.info) - Object.entries(conditional_for).forEach(([targetQuestion, conditions]) => { + Object.entries(conditional_for).map(([targetQuestion, conditions]) => { let div = document.getElementById(targetQuestion + "_div") if(conditions.includes(selectedValue)) { div.style.display = "block" @@ -32,7 +31,7 @@ export default class extends Controller { if (buttons.length == 0){ buttons = document.getElementsByName(`case_log[${targetQuestion}][]`); } - Object.entries(buttons).forEach(([idx, button]) => { + Object.entries(buttons).map(([idx, button]) => { button.checked = false; }) } @@ -44,7 +43,7 @@ export default class extends Controller { let enteredValue = this.element.value let conditional_for = JSON.parse(this.element.dataset.info) - Object.entries(conditional_for).forEach(([targetQuestion, condition]) => { + Object.entries(conditional_for).map(([targetQuestion, condition]) => { let div = document.getElementById(targetQuestion + "_div") if(eval((enteredValue + condition))) { div.style.display = "block" diff --git a/app/javascript/controllers/soft_validations_controller.js b/app/javascript/controllers/soft_validations_controller.js new file mode 100644 index 000000000..963dd7a76 --- /dev/null +++ b/app/javascript/controllers/soft_validations_controller.js @@ -0,0 +1,28 @@ +import { Controller } from "@hotwired/stimulus" + +export default class extends Controller { + static targets = [ "override" ] + + initialize() { + let url = window.location.href + "/soft_validations" + let div = this.overrideTarget + fetch(url, { headers: { accept: "application/json" } }) + .then(response => response.json()) + .then((response) => { + if(response["show"]){ + div.style.display = "block" + let innerHTML = div.innerHTML + innerHTML = innerHTML.replace("soft-validations-placeholder-message", response["label"]) + innerHTML = innerHTML.replace("soft-validations-placeholder-hint-text", response["hint"]) + div.innerHTML = innerHTML + } else { + div.style.display = "none" + let buttons = document.getElementsByName(`case_log[override_net_income_validation][]`) + Object.entries(buttons).map(([idx, button]) => { + button.checked = false + }) + } + } + ) + } +} diff --git a/app/validations/soft_validations.rb b/app/validations/soft_validations.rb index e9ce6d12b..ce03fafc6 100644 --- a/app/validations/soft_validations.rb +++ b/app/validations/soft_validations.rb @@ -8,7 +8,7 @@ module SoftValidations end def soft_errors_overridden? - public_send(soft_errors.keys.first) if soft_errors.present? + !public_send(soft_errors.keys.first).zero? if soft_errors.present? end private diff --git a/app/views/form/_validation_override_question.html.erb b/app/views/form/_validation_override_question.html.erb index 947791e75..5e42b32b8 100644 --- a/app/views/form/_validation_override_question.html.erb +++ b/app/views/form/_validation_override_question.html.erb @@ -1,11 +1,14 @@ -
- <%= f.govuk_check_boxes_fieldset @case_log.soft_errors.keys.first, - legend: { text: @case_log.soft_errors.values.first.message, size: "l" }, - hint: { text: @case_log.soft_errors.values.first.hint_text } do %> + diff --git a/app/views/form/page.html.erb b/app/views/form/page.html.erb index dca0b7672..188b16cda 100644 --- a/app/views/form/page.html.erb +++ b/app/views/form/page.html.erb @@ -1,7 +1,5 @@ - - <% content_for :before_content do %> - <%= link_to 'Back', :back, class: "govuk-back-link" %> + <%= link_to 'Back', 'javascript:history.back()', class: "govuk-back-link" %> <% end %> <%= turbo_frame_tag "case_log_form", target: "_top" do %> @@ -19,8 +17,8 @@
<% end %> - <% if @case_log.soft_errors.present? && @case_log.soft_errors.keys.first == page_info["soft_validations"]&.keys&.first %> - <%= render partial: "form/validation_override_question", locals: { f: f } %> + <% if page_info["soft_validations"]&.keys&.first %> + <%= render partial: "form/validation_override_question", locals: { f: f, page_key: page_key, page_info: page_info } %> <% end %> <%= f.hidden_field :page, value: page_key %> diff --git a/config/routes.rb b/config/routes.rb index 63163937b..3bbc0e161 100644 --- a/config/routes.rb +++ b/config/routes.rb @@ -11,6 +11,7 @@ Rails.application.routes.draw do resources :case_logs do form.all_pages.keys.map do |page| get page.to_s, to: "case_logs##{page}" + get "#{page}/soft_validations", to: "soft_validations#show" end form.all_subsections.keys.map do |subsection| get "#{subsection}/check_answers", to: "case_logs#check_answers" diff --git a/db/migrate/20211105164644_change_net_income_overide.rb b/db/migrate/20211105164644_change_net_income_overide.rb new file mode 100644 index 000000000..3c423dccf --- /dev/null +++ b/db/migrate/20211105164644_change_net_income_overide.rb @@ -0,0 +1,9 @@ +class ChangeNetIncomeOveride < ActiveRecord::Migration[6.1] + def up + change_column :case_logs, :override_net_income_validation, "integer USING CAST(override_net_income_validation AS integer)" + end + + def down + change_column :case_logs, :override_net_income_validation, "boolean USING override_net_income_validation::boolean" + end +end diff --git a/db/schema.rb b/db/schema.rb index 22eb3c9b2..91f0eff45 100644 --- a/db/schema.rb +++ b/db/schema.rb @@ -10,7 +10,7 @@ # # It's strongly recommended that you check this file into your version control system. -ActiveRecord::Schema.define(version: 2021_11_03_090530) do +ActiveRecord::Schema.define(version: 2021_11_05_164644) do # These are extensions that must be enabled in order to support this database enable_extension "plpgsql" @@ -133,7 +133,7 @@ ActiveRecord::Schema.define(version: 2021_11_03_090530) do t.integer "rp_dontknow" t.datetime "discarded_at" t.string "tenancyother" - t.boolean "override_net_income_validation" + t.integer "override_net_income_validation" t.string "net_income_known" t.string "gdpr_acceptance" t.string "gdpr_declined" diff --git a/spec/factories/case_log.rb b/spec/factories/case_log.rb index 5504800fa..4528a7749 100644 --- a/spec/factories/case_log.rb +++ b/spec/factories/case_log.rb @@ -13,6 +13,12 @@ FactoryBot.define do tenant_code { "BZ737" } property_postcode { "NW1 7TY" } end + trait :soft_validations_triggered do + status { 1 } + ecstat1 { "Full-time - 30 hours or more" } + earnings { 750 } + incfreq { "Weekly" } + end created_at { Time.zone.now } updated_at { Time.zone.now } end diff --git a/spec/features/case_log_spec.rb b/spec/features/case_log_spec.rb index be20f6b81..160bb883b 100644 --- a/spec/features/case_log_spec.rb +++ b/spec/features/case_log_spec.rb @@ -217,6 +217,17 @@ RSpec.describe "Test Features" do click_link(text: "Back") expect(page).to have_field("case-log-tenant-code-field") end + + it "doesn't get stuck in infinite loops", js: true do + visit("/case_logs") + visit("/case_logs/#{id}/net_income") + fill_in("case-log-earnings-field", with: 740) + choose("case-log-incfreq-weekly-field", allow_label_click: true) + click_button("Save and continue") + click_link(text: "Back") + click_link(text: "Back") + expect(page).to have_current_path("/case_logs") + end end end @@ -231,7 +242,7 @@ RSpec.describe "Test Features" do end end - context "when changing an answer from the check answers page" do + context "when changing an answer from the check answers page", js: true do it "the back button routes correctly" do visit("/case_logs/#{id}/household_characteristics/check_answers") first("a", text: /Answer/).click @@ -385,11 +396,11 @@ RSpec.describe "Test Features" do describe "Soft Validation" do context "given a weekly net income that is above the expected amount for the given economic status but below the hard max" do - let!(:case_log) { FactoryBot.create(:case_log, :in_progress, ecstat1: "Full-time - 30 hours or more") } + let(:case_log) { FactoryBot.create(:case_log, :in_progress, ecstat1: "Full-time - 30 hours or more") } let(:income_over_soft_limit) { 750 } let(:income_under_soft_limit) { 700 } - it "prompts the user to confirm the value is correct" do + it "prompts the user to confirm the value is correct", js: true do visit("/case_logs/#{case_log.id}/net_income") fill_in("case-log-earnings-field", with: income_over_soft_limit) choose("case-log-incfreq-weekly-field", allow_label_click: true) diff --git a/spec/requests/soft_validations_controller_spec.rb b/spec/requests/soft_validations_controller_spec.rb new file mode 100644 index 000000000..90bd51407 --- /dev/null +++ b/spec/requests/soft_validations_controller_spec.rb @@ -0,0 +1,39 @@ +require "rails_helper" + +RSpec.describe SoftValidationsController, type: :request do + let(:params) { { case_log_id: case_log.id } } + let(:url) { "/case_logs/#{case_log.id}/net_income/soft_validations" } + + before do + get url, params: {} + end + + describe "GET #show" do + context "Soft validation overide required" do + let(:case_log) { FactoryBot.create(:case_log, :soft_validations_triggered) } + + it "returns a success response" do + expect(response).to be_successful + end + + it "returns a json with the soft validation fields" do + json_response = JSON.parse(response.body) + expect(json_response["show"]).to eq(true) + expect(json_response["label"]).to match(/Are you sure this is correct?/) + end + end + + context "Soft validation overide not required" do + let(:case_log) { FactoryBot.create(:case_log, :in_progress) } + + it "returns a success response" do + expect(response).to be_successful + end + + it "returns a json with the soft validation fields" do + json_response = JSON.parse(response.body) + expect(json_response["show"]).to eq(false) + end + end + end +end From dc35b066a39e57e33f00b01ccc2e8aae979b490e Mon Sep 17 00:00:00 2001 From: kosiakkatrina <54268893+kosiakkatrina@users.noreply.github.com> Date: Mon, 8 Nov 2021 09:20:54 +0000 Subject: [PATCH 18/29] Migrate the remaining checkbox fields to integer; (#80) --- .../20211108091320_change_checkbox_types.rb | 15 +++++++++++++++ db/schema.rb | 6 +++--- 2 files changed, 18 insertions(+), 3 deletions(-) create mode 100644 db/migrate/20211108091320_change_checkbox_types.rb diff --git a/db/migrate/20211108091320_change_checkbox_types.rb b/db/migrate/20211108091320_change_checkbox_types.rb new file mode 100644 index 000000000..67b2ac00a --- /dev/null +++ b/db/migrate/20211108091320_change_checkbox_types.rb @@ -0,0 +1,15 @@ +class ChangeCheckboxTypes < ActiveRecord::Migration[6.1] + def up + change_table :case_logs, bulk: true do |t| + t.change :accessibility_requirements_prefer_not_to_say, "integer USING accessibility_requirements_prefer_not_to_say::integer" + t.change :condition_effects_prefer_not_to_say, "integer USING condition_effects_prefer_not_to_say::integer" + end + end + + def down + change_table :case_logs, bulk: true do |t| + t.change :accessibility_requirements_prefer_not_to_say, "boolean USING accessibility_requirements_prefer_not_to_say::boolean" + t.change :condition_effects_prefer_not_to_say, "boolean USING condition_effects_prefer_not_to_say::boolean" + end + end +end diff --git a/db/schema.rb b/db/schema.rb index 91f0eff45..005086022 100644 --- a/db/schema.rb +++ b/db/schema.rb @@ -10,7 +10,7 @@ # # It's strongly recommended that you check this file into your version control system. -ActiveRecord::Schema.define(version: 2021_11_05_164644) do +ActiveRecord::Schema.define(version: 2021_11_08_091320) do # These are extensions that must be enabled in order to support this database enable_extension "plpgsql" @@ -114,7 +114,7 @@ ActiveRecord::Schema.define(version: 2021_11_05_164644) do t.integer "housingneeds_f" t.integer "housingneeds_g" t.integer "housingneeds_h" - t.boolean "accessibility_requirements_prefer_not_to_say" + t.integer "accessibility_requirements_prefer_not_to_say" t.integer "illness_type_1" t.integer "illness_type_2" t.integer "illness_type_3" @@ -125,7 +125,7 @@ ActiveRecord::Schema.define(version: 2021_11_05_164644) do t.integer "illness_type_7" t.integer "illness_type_9" t.integer "illness_type_10" - t.boolean "condition_effects_prefer_not_to_say" + t.integer "condition_effects_prefer_not_to_say" t.integer "rp_homeless" t.integer "rp_insan_unsat" t.integer "rp_medwel" From dbef8dfba4fb091c4213c11aeb71a51153093f75 Mon Sep 17 00:00:00 2001 From: Daniel Baark <5101747+baarkerlounger@users.noreply.github.com> Date: Tue, 9 Nov 2021 13:36:52 +0000 Subject: [PATCH 19/29] CLDC-642: Soft validation UI bug fix (#82) * Soft validation UI needs to be on both questions being validated * Fix whether the box is checked or not * All checkboxes are integers now * Fix * Use enums as well for consistency * Use capybara matcher for less flakiness * Click link already waits * Add a retry to our fetch so tests are more resilient to intermittent network issues --- app/constants/db_enums.rb | 7 +++++++ .../controllers/soft_validations_controller.js | 14 +++++++++++--- app/models/case_log.rb | 1 + app/validations/soft_validations.rb | 2 +- .../form/_validation_override_question.html.erb | 3 ++- config/forms/2021_2022.json | 9 +++++++++ spec/features/case_log_spec.rb | 2 +- 7 files changed, 32 insertions(+), 6 deletions(-) diff --git a/app/constants/db_enums.rb b/app/constants/db_enums.rb index 536620915..84f7d3837 100644 --- a/app/constants/db_enums.rb +++ b/app/constants/db_enums.rb @@ -213,6 +213,13 @@ module DbEnums } end + def self.override_soft_validation + { + "No" => 0, + "Yes" => 1, + } + end + def self.benefits { "All" => 1, diff --git a/app/javascript/controllers/soft_validations_controller.js b/app/javascript/controllers/soft_validations_controller.js index 963dd7a76..a408e4460 100644 --- a/app/javascript/controllers/soft_validations_controller.js +++ b/app/javascript/controllers/soft_validations_controller.js @@ -5,8 +5,13 @@ export default class extends Controller { initialize() { let url = window.location.href + "/soft_validations" + this.fetch_retry(url, { headers: { accept: "application/json" } }, 2) + } + + fetch_retry(url, options, n) { + let self = this let div = this.overrideTarget - fetch(url, { headers: { accept: "application/json" } }) + fetch(url, options) .then(response => response.json()) .then((response) => { if(response["show"]){ @@ -22,7 +27,10 @@ export default class extends Controller { button.checked = false }) } - } - ) + }) + .catch(function(error) { + if (n === 1) throw error + return self.fetch_retry(url, options, n - 1) + }) } } diff --git a/app/models/case_log.rb b/app/models/case_log.rb index ac37461da..b77534795 100644 --- a/app/models/case_log.rb +++ b/app/models/case_log.rb @@ -65,6 +65,7 @@ class CaseLog < ApplicationRecord enum leftreg: DbEnums.leftreg, _suffix: true enum illness: DbEnums.illness, _suffix: true enum preg_occ: DbEnums.pregnancy, _suffix: true + enum override_net_income_validation: DbEnums.override_soft_validation, _suffix: true enum housingneeds_a: DbEnums.polar, _suffix: true enum housingneeds_b: DbEnums.polar, _suffix: true enum housingneeds_c: DbEnums.polar, _suffix: true diff --git a/app/validations/soft_validations.rb b/app/validations/soft_validations.rb index ce03fafc6..451988b66 100644 --- a/app/validations/soft_validations.rb +++ b/app/validations/soft_validations.rb @@ -8,7 +8,7 @@ module SoftValidations end def soft_errors_overridden? - !public_send(soft_errors.keys.first).zero? if soft_errors.present? + public_send(soft_errors.keys.first) == "Yes" if soft_errors.present? end private diff --git a/app/views/form/_validation_override_question.html.erb b/app/views/form/_validation_override_question.html.erb index 5e42b32b8..10a6a60e7 100644 --- a/app/views/form/_validation_override_question.html.erb +++ b/app/views/form/_validation_override_question.html.erb @@ -8,7 +8,8 @@ hint: { text: "soft-validations-placeholder-hint-text" } do %> <%= f.govuk_check_box page_info["soft_validations"]&.keys&.first, page_info["soft_validations"]&.keys&.first, - label: { text: "Yes" } + label: { text: "Yes" }, + checked: @case_log[page_info["soft_validations"]&.keys&.first] == "Yes" %> <% end %> diff --git a/config/forms/2021_2022.json b/config/forms/2021_2022.json index 498e064b2..5229155e0 100644 --- a/config/forms/2021_2022.json +++ b/config/forms/2021_2022.json @@ -315,6 +315,15 @@ "10": "Prefer not to say" } } + }, + "soft_validations": { + "override_net_income_validation": { + "check_answer_label": "Net income confirmed?", + "type": "validation_override", + "answer_options": { + "override_net_income_validation": "Yes" + } + } } }, "household_number_of_other_members": { diff --git a/spec/features/case_log_spec.rb b/spec/features/case_log_spec.rb index 160bb883b..0e2ae338b 100644 --- a/spec/features/case_log_spec.rb +++ b/spec/features/case_log_spec.rb @@ -431,7 +431,7 @@ RSpec.describe "Test Features" do fill_in("case-log-earnings-field", with: income_under_soft_limit) click_button("Save and continue") click_link(text: "Back") - expect(page).not_to have_content("Are you sure this is correct?") + expect(page).to have_no_content("Are you sure this is correct?") end it "does not clear the confirmation question if the page is returned to using the back button and the amount is still over the soft limit", js: true do From 15bbe798df52c1711b09fb09469917087d486917 Mon Sep 17 00:00:00 2001 From: kosiakkatrina <54268893+kosiakkatrina@users.noreply.github.com> Date: Wed, 10 Nov 2021 13:55:10 +0000 Subject: [PATCH 20/29] Cldc 591/further data changes (#83) * Remove condition_effects_prefer_not_to_say field * Change reason type * Remove prefer not to say from illness * add majorrepairs,propcode and infer postcode * Update previous location and la * Update majorrepairs, national and reasonpref * Update housing benefits fields * rename file * Add previous postcode * Move inferred postcode to model * refactor infered poscode method * Remove unneeded import * update miration and some mappings * Remove duplicate migration command --- Gemfile | 1 + Gemfile.lock | 2 + app/admin/case_logs.rb | 2 +- app/constants/db_enums.rb | 448 +++++++++++++++++- app/models/case_log.rb | 35 +- app/validations/financial_validations.rb | 8 +- app/validations/household_validations.rb | 4 +- config/forms/2021_2022.json | 63 +-- .../20211108134601_further_core_migrations.rb | 57 +++ db/schema.rb | 25 +- docs/api/DLUHC-CORE-Data.v1.json | 36 +- spec/controllers/case_logs_controller_spec.rb | 27 ++ spec/factories/case_log.rb | 4 +- spec/features/case_log_spec.rb | 6 +- spec/fixtures/complete_case_log.json | 23 +- spec/fixtures/forms/test_form.json | 12 +- spec/helpers/check_answers_helper_spec.rb | 2 +- spec/helpers/tasklist_helper_spec.rb | 2 +- spec/models/case_log_spec.rb | 14 +- spec/models/form_spec.rb | 2 +- 20 files changed, 676 insertions(+), 97 deletions(-) create mode 100644 db/migrate/20211108134601_further_core_migrations.rb diff --git a/Gemfile b/Gemfile index fa743fa4a..8308b7274 100644 --- a/Gemfile +++ b/Gemfile @@ -29,6 +29,7 @@ gem "discard" gem "activeadmin" # Admin charts gem "chartkick" +gem "uk_postcode" group :development, :test do # Call 'byebug' anywhere in the code to stop execution and get a debugger console diff --git a/Gemfile.lock b/Gemfile.lock index fa3d1a27d..c7ce5acfe 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -358,6 +358,7 @@ GEM rails (>= 6.0.0) tzinfo (2.0.4) concurrent-ruby (~> 1.0) + uk_postcode (2.1.6) unicode-display_width (2.1.0) view_component (2.39.0) activesupport (>= 5.0.0, < 8.0) @@ -417,6 +418,7 @@ DEPENDENCIES selenium-webdriver simplecov tzinfo-data + uk_postcode web-console (>= 4.1.0) webpacker (~> 5.0) diff --git a/app/admin/case_logs.rb b/app/admin/case_logs.rb index f14d33a3a..c3716ad6d 100644 --- a/app/admin/case_logs.rb +++ b/app/admin/case_logs.rb @@ -2,7 +2,7 @@ ActiveAdmin.register CaseLog do # See permitted parameters documentation: # https://github.com/activeadmin/activeadmin/blob/master/docs/2-resource-customization.md#setting-up-strong-parameters permit_params do - permitted = %i[status tenant_code age1 sex1 tenant_ethnic_group tenant_nationality previous_housing_situation armed_forces ecstat1 hhmemb relat2 age2 sex2 ecstat2 relat3 age3 sex3 ecstat3 relat4 age4 sex4 ecstat4 relat5 age5 sex5 ecstat5 relat6 age6 sex6 ecstat6 relat7 age7 person_7_gender ecstat7 relat8 age8 sex8 ecstat8 homelessness reason_for_leaving_last_settled_home benefit_cap_spare_room_subsidy armed_forces_active armed_forces_injured armed_forces_partner medical_conditions pregnancy accessibility_requirements condition_effects tenancy_code tenancy_start_date starter_tenancy fixed_term_tenancy tenancy_type letting_type letting_provider property_location previous_postcode property_relet property_vacancy_reason property_reference property_unit_type property_building_type property_number_of_bedrooms property_void_date property_major_repairs property_major_repairs_date property_number_of_times_relet property_wheelchair_accessible net_income net_income_frequency net_income_uc_proportion housing_benefit rent_frequency basic_rent service_charge personal_service_charge support_charge total_charge outstanding_amount time_lived_in_la time_on_la_waiting_list previous_la property_postcode reasonable_preference reasonable_preference_reason cbl_letting chr_letting cap_letting outstanding_rent_or_charges other_reason_for_leaving_last_settled_home accessibility_requirements_fully_wheelchair_accessible_housing accessibility_requirements_wheelchair_access_to_essential_rooms accessibility_requirements_level_access_housing accessibility_requirements_other_disability_requirements accessibility_requirements_no_disability_requirements accessibility_requirements_do_not_know accessibility_requirements_prefer_not_to_say condition_effects_vision condition_effects_hearing condition_effects_mobility condition_effects_dexterity condition_effects_stamina condition_effects_learning condition_effects_memory condition_effects_mental_health condition_effects_social_or_behavioral condition_effects_other condition_effects_prefer_not_to_say reasonable_preference_reason_homeless reasonable_preference_reason_unsatisfactory_housing reasonable_preference_reason_medical_grounds reasonable_preference_reason_avoid_hardship reasonable_preference_reason_do_not_know other_tenancy_type override_net_income_validation net_income_known] + permitted = %i[status tenant_code age1 sex1 tenant_ethnic_group tenant_nationality previous_housing_situation armed_forces ecstat1 hhmemb relat2 age2 sex2 ecstat2 relat3 age3 sex3 ecstat3 relat4 age4 sex4 ecstat4 relat5 age5 sex5 ecstat5 relat6 age6 sex6 ecstat6 relat7 age7 person_7_gender ecstat7 relat8 age8 sex8 ecstat8 homelessness reason benefit_cap_spare_room_subsidy armed_forces_active armed_forces_injured armed_forces_partner medical_conditions pregnancy accessibility_requirements condition_effects tenancy_code tenancy_start_date starter_tenancy fixed_term_tenancy tenancy_type letting_type letting_provider la previous_postcode property_relet property_vacancy_reason property_reference property_unit_type property_building_type property_number_of_bedrooms property_void_date property_major_repairs property_major_repairs_date property_number_of_times_relet property_wheelchair_accessible net_income net_income_frequency net_income_uc_proportion hb rent_frequency basic_rent service_charge personal_service_charge support_charge total_charge tshortfall time_lived_in_la time_on_la_waiting_list prevloc property_postcode reasonable_preference reasonable_preference_reason cbl_letting chr_letting cap_letting hbrentshortfall other_reason accessibility_requirements_fully_wheelchair_accessible_housing accessibility_requirements_wheelchair_access_to_essential_rooms accessibility_requirements_level_access_housing accessibility_requirements_other_disability_requirements accessibility_requirements_no_disability_requirements accessibility_requirements_do_not_know accessibility_requirements_prefer_not_to_say condition_effects_vision condition_effects_hearing condition_effects_mobility condition_effects_dexterity condition_effects_stamina condition_effects_learning condition_effects_memory condition_effects_mental_health condition_effects_social_or_behavioral condition_effects_other condition_effects_prefer_not_to_say reasonable_preference_reason_homeless reasonable_preference_reason_unsatisfactory_housing reasonable_preference_reason_medical_grounds reasonable_preference_reason_avoid_hardship reasonable_preference_reason_do_not_know other_tenancy_type override_net_income_validation net_income_known] permitted end diff --git a/app/constants/db_enums.rb b/app/constants/db_enums.rb index 84f7d3837..23e4b4bd4 100644 --- a/app/constants/db_enums.rb +++ b/app/constants/db_enums.rb @@ -20,7 +20,7 @@ module DbEnums "Not seeking work" => 6, "Full-time student" => 7, "Unable to work because of long term sick or disability" => 8, - "Child under 16" => 100, + "Child under 16" => 9, "Other" => 0, "Prefer not to say" => 10, } @@ -63,7 +63,6 @@ module DbEnums "Yes" => 1, "No" => 2, "Do not know" => 3, - "Prefer not to say" => 100, } end @@ -91,6 +90,8 @@ module DbEnums "Bulgaria" => 14, "Romania" => 15, "Ireland" => 17, + "Slovenia" => 10, + "Croatia" => 16, "Other EU Economic Area (EEA country)" => 11, "Any other country" => 12, "Prefer not to say" => 13, @@ -155,6 +156,14 @@ module DbEnums } end + def self.polar_with_unknown + { + "No" => 2, + "Yes" => 1, + "Do not know" => 3, + } + end + def self.tenancy { "Fixed term – Secure" => 1, @@ -256,4 +265,439 @@ module DbEnums "Do not know" => 6, } end + + def self.housing_benefit + { + "Housing Benefit, but not Universal Credit" => 1, + "Universal Credit with housing element, but not Housing Benefit" => 6, + "Universal Credit without housing element and no Housing Benefit" => 7, + "Universal Credit and Housing Benefit" => 8, + "Not Housing Benefit or Universal Credit" => 9, + "Do not know" => 3, + "Prefer not to say" => 100, + } + end + + def self.reason + { + "Permanently decanted from another property owned by this landlord" => 1, + "Left home country as a refugee" => 2, + "Loss of tied accommodation" => 4, + "Domestic abuse" => 7, + "(Non violent) relationship breakdown with partner" => 8, + "Asked to leave by family or friends" => 9, + "Racial harassment" => 10, + "Other problems with neighbours" => 11, + "Property unsuitable because of overcrowding" => 12, + "End of assured shorthold tenancy - no fault" => 40, + "End of assured shorthold tenancy - tenant's fault" => 41, + "End of fixed term tenancy - no fault" => 42, + "End of fixed term tenancy - tenant's fault" => 43, + "Repossession" => 34, + "Under occupation - offered incentive to downsize" => 29, + "Under occupation - no incentive" => 30, + "Property unsuitable because of ill health / disability" => 13, + "Property unsuitable because of poor condition" => 14, + "Couldn't afford fees attached to renewing the tenancy" => 35, + "Couldn't afford increase in rent" => 36, + "Couldn't afford rent or mortgage - welfare reforms" => 37, + "Couldn't afford rent or mortgage - employment" => 38, + "Couldn't afford rent or mortgage - other" => 39, + "To move nearer to family / friends / school" => 16, + "To move nearer to work" => 17, + "To move to accomodation with support" => 18, + "To move to independent accomodation" => 19, + "Hate crime" => 31, + "Death of household member in last settled accomodation" => 46, + "Discharged from prison" => 44, + "Discharged from long stay hospital or similar institution" => 45, + "Other" => 20, + "Do not know" => 28, + "Prefer not to say" => 100, + } + end + + def self.la + { + "Hartlepool" => "E06000001", + "Na h-Eileanan Siar" => "S12000013", + "Middlesbrough" => "E06000002", + "Redcar and Cleveland" => "E06000003", + "Stockton-on-Tees" => "E06000004", + "Darlington" => "E06000005", + "Halton" => "E06000006", + "Warrington" => "E06000007", + "Blackburn with Darwen" => "E06000008", + "Blackpool" => "E06000009", + "Kingston upon Hull, City of" => "E06000010", + "East Riding of Yorkshire" => "E06000011", + "North East Lincolnshire" => "E06000012", + "North Lincolnshire" => "E06000013", + "York" => "E06000014", + "Derby" => "E06000015", + "Leicester" => "E06000016", + "Rutland" => "E06000017", + "Nottingham" => "E06000018", + "Herefordshire, County of" => "E06000019", + "Telford and Wrekin" => "E06000020", + "Stoke-on-Trent" => "E06000021", + "Bath and North East Somerset" => "E06000022", + "Bristol, City of" => "E06000023", + "North Somerset" => "E06000024", + "South Gloucestershire" => "E06000025", + "Plymouth" => "E06000026", + "Torbay" => "E06000027", + "Swindon" => "E06000030", + "Peterborough" => "E06000031", + "Luton" => "E06000032", + "Southend-on-Sea" => "E06000033", + "Thurrock" => "E06000034", + "Medway" => "E06000035", + "Bracknell Forest" => "E06000036", + "West Berkshire" => "E06000037", + "Reading" => "E06000038", + "Slough" => "E06000039", + "Windsor and Maidenhead" => "E06000040", + "Wokingham" => "E06000041", + "Milton Keynes" => "E06000042", + "Brighton and Hove" => "E06000043", + "Portsmouth" => "E06000044", + "Southampton" => "E06000045", + "Isle of Wight" => "E06000046", + "County Durham" => "E06000047", + "Cheshire East" => "E06000049", + "Cheshire West and Chester" => "E06000050", + "Shropshire" => "E06000051", + "Cornwall" => "E06000052", + "Isles of Scilly" => "E06000053", + "Wiltshire" => "E06000054", + "Bedford" => "E06000055", + "Central Bedfordshire" => "E06000056", + "Northumberland" => "E06000057", + "Bournemouth, Christchurch and Poole" => "E06000058", + "North Warwickshire" => "E07000218", + "Nuneaton and Bedworth" => "E07000219", + "Rugby" => "E07000220", + "Stratford-on-Avon" => "E07000221", + "Warwick" => "E07000222", + "Adur" => "E07000223", + "Arun" => "E07000224", + "Chichester" => "E07000225", + "Crawley" => "E07000226", + "Horsham" => "E07000227", + "Mid Sussex" => "E07000228", + "Worthing" => "E07000229", + "Bromsgrove" => "E07000234", + "Malvern Hills" => "E07000235", + "Redditch" => "E07000236", + "Worcester" => "E07000237", + "Wychavon" => "E07000238", + "Wyre Forest" => "E07000239", + "St Albans" => "E07000240", + "Welwyn Hatfield" => "E07000241", + "East Hertfordshire" => "E07000242", + "Stevenage" => "E07000243", + "East Suffolk" => "E07000244", + "West Suffolk" => "E07000245", + "Somerset West and Taunton" => "E07000246", + "Bolton" => "E08000001", + "Bury" => "E08000002", + "Manchester" => "E08000003", + "Oldham" => "E08000004", + "Rochdale" => "E08000005", + "Salford" => "E08000006", + "Stockport" => "E08000007", + "Tameside" => "E08000008", + "Trafford" => "E08000009", + "Wigan" => "E08000010", + "Knowsley" => "E08000011", + "Liverpool" => "E08000012", + "St. Helens" => "E08000013", + "Sefton" => "E08000014", + "Wirral" => "E08000015", + "Barnsley" => "E08000016", + "Doncaster" => "E08000017", + "Rotherham" => "E08000018", + "Sheffield" => "E08000019", + "Newcastle upon Tyne" => "E08000021", + "North Tyneside" => "E08000022", + "South Tyneside" => "E08000023", + "Sunderland" => "E08000024", + "Birmingham" => "E08000025", + "Coventry" => "E08000026", + "Dudley" => "E08000027", + "Sandwell" => "E08000028", + "Solihull" => "E08000029", + "Walsall" => "E08000030", + "Dorset" => "E06000059", + "Wolverhampton" => "E08000031", + "Falkirk" => "S12000014", + "Highland" => "S12000017", + "Inverclyde" => "S12000018", + "Midlothian" => "S12000019", + "Moray" => "S12000020", + "North Ayrshire" => "S12000021", + "Orkney Islands" => "S12000023", + "Scottish Borders" => "S12000026", + "Shetland Islands" => "S12000027", + "South Ayrshire" => "S12000028", + "South Lanarkshire" => "S12000029", + "Stirling" => "S12000030", + "Aberdeen City" => "S12000033", + "Aberdeenshire" => "S12000034", + "Argyll and Bute" => "S12000035", + "City of Edinburgh" => "S12000036", + "Renfrewshire" => "S12000038", + "West Dunbartonshire" => "S12000039", + "West Lothian" => "S12000040", + "Angus" => "S12000041", + "Dundee City" => "S12000042", + "East Dunbartonshire" => "S12000045", + "Buckinghamshire" => "E06000060", + "Fife" => "S12000047", + "Cambridge" => "E07000008", + "Perth and Kinross" => "S12000048", + "East Cambridgeshire" => "E07000009", + "Glasgow City" => "S12000049", + "Fenland" => "E07000010", + "North Lanarkshire" => "S12000050", + "Huntingdonshire" => "E07000011", + "Isle of Anglesey" => "W06000001", + "South Cambridgeshire" => "E07000012", + "Gwynedd" => "W06000002", + "Allerdale" => "E07000026", + "Conwy" => "W06000003", + "Barrow-in-Furness" => "E07000027", + "Denbighshire" => "W06000004", + "Carlisle" => "E07000028", + "Flintshire" => "W06000005", + "Copeland" => "E07000029", + "Wrexham" => "W06000006", + "Eden" => "E07000030", + "Ceredigion" => "W06000008", + "South Lakeland" => "E07000031", + "Pembrokeshire" => "W06000009", + "Amber Valley" => "E07000032", + "Carmarthenshire" => "W06000010", + "Bolsover" => "E07000033", + "Swansea" => "W06000011", + "Chesterfield" => "E07000034", + "Neath Port Talbot" => "W06000012", + "Derbyshire Dales" => "E07000035", + "Bridgend" => "W06000013", + "Erewash" => "E07000036", + "Vale of Glamorgan" => "W06000014", + "High Peak" => "E07000037", + "Cardiff" => "W06000015", + "North East Derbyshire" => "E07000038", + "Rhondda Cynon Taf" => "W06000016", + "South Derbyshire" => "E07000039", + "Caerphilly" => "W06000018", + "East Devon" => "E07000040", + "Blaenau Gwent" => "W06000019", + "Exeter" => "E07000041", + "Torfaen" => "W06000020", + "Mid Devon" => "E07000042", + "Monmouthshire" => "W06000021", + "North Devon" => "E07000043", + "Newport" => "W06000022", + "South Hams" => "E07000044", + "Powys" => "W06000023", + "Teignbridge" => "E07000045", + "Merthyr Tydfil" => "W06000024", + "Torridge" => "E07000046", + "West Devon" => "E07000047", + "Eastbourne" => "E07000061", + "Hastings" => "E07000062", + "Lewes" => "E07000063", + "Rother" => "E07000064", + "Wealden" => "E07000065", + "Basildon" => "E07000066", + "Braintree" => "E07000067", + "Brentwood" => "E07000068", + "Castle Point" => "E07000069", + "Chelmsford" => "E07000070", + "Colchester" => "E07000071", + "Epping Forest" => "E07000072", + "Harlow" => "E07000073", + "Maldon" => "E07000074", + "Rochford" => "E07000075", + "Tendring" => "E07000076", + "Uttlesford" => "E07000077", + "Cheltenham" => "E07000078", + "Cotswold" => "E07000079", + "Forest of Dean" => "E07000080", + "Gloucester" => "E07000081", + "Stroud" => "E07000082", + "Tewkesbury" => "E07000083", + "Basingstoke and Deane" => "E07000084", + "East Hampshire" => "E07000085", + "King’s Lynn and West Norfolk" => "E07000146", + "Eastleigh" => "E07000086", + "North Norfolk" => "E07000147", + "Norwich" => "E07000148", + "South Norfolk" => "E07000149", + "Corby" => "E07000150", + "Daventry" => "E07000151", + "East Northamptonshire" => "E07000152", + "Kettering" => "E07000153", + "Northampton" => "E07000154", + "South Northamptonshire" => "E07000155", + "Wellingborough" => "E07000156", + "Craven" => "E07000163", + "Hambleton" => "E07000164", + "Harrogate" => "E07000165", + "Richmondshire" => "E07000166", + "Ryedale" => "E07000167", + "Scarborough" => "E07000168", + "Selby" => "E07000169", + "Ashfield" => "E07000170", + "Bassetlaw" => "E07000171", + "Broxtowe" => "E07000172", + "Gedling" => "E07000173", + "Mansfield" => "E07000174", + "Newark and Sherwood" => "E07000175", + "Rushcliffe" => "E07000176", + "Cherwell" => "E07000177", + "Oxford" => "E07000178", + "South Oxfordshire" => "E07000179", + "Vale of White Horse" => "E07000180", + "West Oxfordshire" => "E07000181", + "Mendip" => "E07000187", + "Sedgemoor" => "E07000188", + "South Somerset" => "E07000189", + "Cannock Chase" => "E07000192", + "East Staffordshire" => "E07000193", + "Lichfield" => "E07000194", + "Newcastle-under-Lyme" => "E07000195", + "South Staffordshire" => "E07000196", + "Stafford" => "E07000197", + "Staffordshire Moorlands" => "E07000198", + "Tamworth" => "E07000199", + "Babergh" => "E07000200", + "Ipswich" => "E07000202", + "Mid Suffolk" => "E07000203", + "Elmbridge" => "E07000207", + "Epsom and Ewell" => "E07000208", + "Guildford" => "E07000209", + "Mole Valley" => "E07000210", + "Reigate and Banstead" => "E07000211", + "Runnymede" => "E07000212", + "Spelthorne" => "E07000213", + "Surrey Heath" => "E07000214", + "Tandridge" => "E07000215", + "Waverley" => "E07000216", + "Woking" => "E07000217", + "Fareham" => "E07000087", + "Gosport" => "E07000088", + "Hart" => "E07000089", + "Havant" => "E07000090", + "New Forest" => "E07000091", + "Rushmoor" => "E07000092", + "Test Valley" => "E07000093", + "Winchester" => "E07000094", + "Broxbourne" => "E07000095", + "Dacorum" => "E07000096", + "Hertsmere" => "E07000098", + "North Hertfordshire" => "E07000099", + "Three Rivers" => "E07000102", + "Watford" => "E07000103", + "Ashford" => "E07000105", + "Canterbury" => "E07000106", + "Dartford" => "E07000107", + "Dover" => "E07000108", + "Gravesham" => "E07000109", + "Maidstone" => "E07000110", + "Sevenoaks" => "E07000111", + "Folkestone and Hythe" => "E07000112", + "Swale" => "E07000113", + "Thanet" => "E07000114", + "Tonbridge and Malling" => "E07000115", + "Tunbridge Wells" => "E07000116", + "Burnley" => "E07000117", + "Chorley" => "E07000118", + "Fylde" => "E07000119", + "Hyndburn" => "E07000120", + "Lancaster" => "E07000121", + "Pendle" => "E07000122", + "Preston" => "E07000123", + "Ribble Valley" => "E07000124", + "Rossendale" => "E07000125", + "South Ribble" => "E07000126", + "West Lancashire" => "E07000127", + "Wyre" => "E07000128", + "Blaby" => "E07000129", + "Charnwood" => "E07000130", + "Harborough" => "E07000131", + "Hinckley and Bosworth" => "E07000132", + "Melton" => "E07000133", + "North West Leicestershire" => "E07000134", + "Oadby and Wigston" => "E07000135", + "Boston" => "E07000136", + "East Lindsey" => "E07000137", + "Lincoln" => "E07000138", + "North Kesteven" => "E07000139", + "South Holland" => "E07000140", + "South Kesteven" => "E07000141", + "West Lindsey" => "E07000142", + "Breckland" => "E07000143", + "Broadland" => "E07000144", + "Great Yarmouth" => "E07000145", + "Bradford" => "E08000032", + "Calderdale" => "E08000033", + "Kirklees" => "E08000034", + "Leeds" => "E08000035", + "Wakefield" => "E08000036", + "Gateshead" => "E08000037", + "City of London" => "E09000001", + "Barking and Dagenham" => "E09000002", + "Barnet" => "E09000003", + "Bexley" => "E09000004", + "Brent" => "E09000005", + "Bromley" => "E09000006", + "Camden" => "E09000007", + "Croydon" => "E09000008", + "Ealing" => "E09000009", + "Enfield" => "E09000010", + "Greenwich" => "E09000011", + "Hackney" => "E09000012", + "Hammersmith and Fulham" => "E09000013", + "Haringey" => "E09000014", + "Harrow" => "E09000015", + "Havering" => "E09000016", + "Hillingdon" => "E09000017", + "Hounslow" => "E09000018", + "Islington" => "E09000019", + "Kensington and Chelsea" => "E09000020", + "Kingston upon Thames" => "E09000021", + "Lambeth" => "E09000022", + "Lewisham" => "E09000023", + "Merton" => "E09000024", + "Newham" => "E09000025", + "Redbridge" => "E09000026", + "Richmond upon Thames" => "E09000027", + "Southwark" => "E09000028", + "Sutton" => "E09000029", + "Tower Hamlets" => "E09000030", + "Waltham Forest" => "E09000031", + "Wandsworth" => "E09000032", + "Westminster" => "E09000033", + "Antrim and Newtownabbey" => "N09000001", + "Armagh City, Banbridge and Craigavon" => "N09000002", + "Belfast" => "N09000003", + "Causeway Coast and Glens" => "N09000004", + "Derry City and Strabane" => "N09000005", + "Fermanagh and Omagh" => "N09000006", + "Lisburn and Castlereagh" => "N09000007", + "Mid and East Antrim" => "N09000008", + "Mid Ulster" => "N09000009", + "Newry, Mourne and Down" => "N09000010", + "Ards and North Down" => "N09000011", + "Clackmannanshire" => "S12000005", + "Dumfries and Galloway" => "S12000006", + "East Ayrshire" => "S12000008", + "East Lothian" => "S12000010", + "East Renfrewshire" => "S12000011", + } + end end diff --git a/app/models/case_log.rb b/app/models/case_log.rb index b77534795..c058fb5f3 100644 --- a/app/models/case_log.rb +++ b/app/models/case_log.rb @@ -101,7 +101,14 @@ class CaseLog < ApplicationRecord enum period: DbEnums.period, _suffix: true enum layear: DbEnums.latime, _suffix: true enum lawaitlist: DbEnums.latime, _suffix: true - enum reasonpref: DbEnums.polar2, _suffix: true + enum reasonpref: DbEnums.polar_with_unknown, _suffix: true + enum reason: DbEnums.reason, _suffix: true + enum la: DbEnums.la, _suffix: true + enum prevloc: DbEnums.la, _suffix: true + enum majorrepairs: DbEnums.polar, _suffix: true + enum hb: DbEnums.housing_benefit, _suffix: true + enum hbrentshortfall: DbEnums.polar_with_unknown, _suffix: true + enum property_relet: DbEnums.polar, _suffix: true AUTOGENERATED_FIELDS = %w[id status created_at updated_at discarded_at].freeze @@ -132,6 +139,30 @@ class CaseLog < ApplicationRecord end end + def postcode + if property_postcode.present? + UKPostcode.parse(property_postcode).outcode + end + end + + def postcod2 + if property_postcode.present? + UKPostcode.parse(property_postcode).incode + end + end + + def ppostc1 + if previous_postcode.present? + UKPostcode.parse(previous_postcode).outcode + end + end + + def ppostc2 + if previous_postcode.present? + UKPostcode.parse(previous_postcode).incode + end + end + def applicable_income_range return unless ecstat1 @@ -163,7 +194,7 @@ private dynamically_not_required = [] - if reason_for_leaving_last_settled_home != "Other" + if reason != "Other" dynamically_not_required << "other_reason_for_leaving_last_settled_home" end diff --git a/app/validations/financial_validations.rb b/app/validations/financial_validations.rb index dd4b58baf..3d2ce8732 100644 --- a/app/validations/financial_validations.rb +++ b/app/validations/financial_validations.rb @@ -2,11 +2,11 @@ module FinancialValidations # Validations methods need to be called 'validate_' to run on model save # or 'validate_' to run on submit as well def validate_outstanding_rent_amount(record) - if record.outstanding_rent_or_charges == "Yes" && record.outstanding_amount.blank? - record.errors.add :outstanding_amount, "You must answer the oustanding amout question if you have outstanding rent or charges." + if record.hbrentshortfall == "Yes" && record.tshortfall.blank? + record.errors.add :tshortfall, "You must answer the oustanding amout question if you have outstanding rent or charges." end - if record.outstanding_rent_or_charges == "No" && record.outstanding_amount.present? - record.errors.add :outstanding_amount, "You must not answer the oustanding amout question if you don't have outstanding rent or charges." + if record.hbrentshortfall == "No" && record.tshortfall.present? + record.errors.add :tshortfall, "You must not answer the oustanding amout question if you don't have outstanding rent or charges." end end diff --git a/app/validations/household_validations.rb b/app/validations/household_validations.rb index ca8d887e9..b36972667 100644 --- a/app/validations/household_validations.rb +++ b/app/validations/household_validations.rb @@ -16,11 +16,11 @@ module HouseholdValidations end def validate_other_reason_for_leaving_last_settled_home(record) - validate_other_field(record, "reason_for_leaving_last_settled_home", "other_reason_for_leaving_last_settled_home") + validate_other_field(record, "reason", "other_reason_for_leaving_last_settled_home") end def validate_reason_for_leaving_last_settled_home(record) - if record.reason_for_leaving_last_settled_home == "Do not know" && record.underoccupation_benefitcap != "Do not know" + if record.reason == "Do not know" && record.underoccupation_benefitcap != "Do not know" record.errors.add :underoccupation_benefitcap, "must be do not know if tenant’s main reason for leaving is do not know" end end diff --git a/config/forms/2021_2022.json b/config/forms/2021_2022.json index 5229155e0..52d80f8ee 100644 --- a/config/forms/2021_2022.json +++ b/config/forms/2021_2022.json @@ -273,21 +273,23 @@ "type": "radio", "answer_options": { "0": "UK national resident in UK", - "1": "A current or former reserve in the UK Armed Forces (exc. National Service)", - "2": "UK national returning from residence overseas", - "3": "Czech Republic", - "4": "Estonia", - "5": "Hungary", - "6": "Latvia", - "7": "Lithuania", - "8": "Poland", - "9": "Slovakia", - "10": "Bulgaria", - "11": "Romania", - "12": "Ireland", - "13": "Other EU Economic Area (EEA country)", - "14": "Any other country", - "15": "Prefer not to say" + "1": "UK national returning from residence overseas", + "2": "Czech Republic", + "3": "Estonia", + "4": "Hungary", + "5": "Latvia", + "6": "Lithuania", + "7": "Poland", + "8": "Slovakia", + "9": "Bulgaria", + "10": "Romania", + "11": "Ireland", + "12": "Slovakia", + "13":"Slovenia", + "14": "Croatia", + "15": "Other EU Economic Area (EEA country)", + "16": "Any other country", + "17": "Prefer not to say" } } } @@ -796,7 +798,7 @@ "header": "Leaving their last settled home", "description": "", "questions": { - "reason_for_leaving_last_settled_home": { + "reason": { "header": "What is the tenant’s main reason for leaving?", "hint_text": "", "type": "radio", @@ -934,8 +936,7 @@ "answer_options": { "0": "Yes", "1": "No", - "2": "Do not know", - "3": "Prefer not to say" + "2": "Prefer not to say" } } } @@ -999,9 +1000,7 @@ "illness_type_6": "Memory", "illness_type_7": "Mental health - such as depression, anxiety, schizophrenia or bipolar", "illness_type_9": "Socially or behaviourally - such as those associated with autism spectral disorder (ASD) including Aspergers’ or attention deficit hyperactivity disorder (ADHD))", - "illness_type_10": "Other", - "divider": true, - "condition_effects_prefer_not_to_say": "Prefer not to say" + "illness_type_10": "Other" } } } @@ -1144,7 +1143,7 @@ "header": "", "description": "", "questions": { - "property_location": { + "la": { "check_answer_label": "Property Location", "header": "Property location", "hint_text": "", @@ -1527,7 +1526,7 @@ "header": "", "description": "", "questions": { - "property_reference": { + "propcode": { "check_answer_label": "What’s the property reference?", "header": "What's the property reference?", "hint_text": "", @@ -1576,7 +1575,7 @@ "header": "", "description": "", "questions": { - "property_major_repairs": { + "majorrepairs": { "check_answer_label": "Were major repairs carried out during the void period?", "header": "Were any major repairs completed during the void period?", "hint_text": "", @@ -1709,7 +1708,7 @@ "header": "", "description": "", "questions": { - "housing_benefit": { + "hb": { "check_answer_label": "Universal Credit & Housing Benefit", "header": "Is the tenant likely to be in receipt of any of these housing-related benefits?", "hint_text": "", @@ -1822,20 +1821,21 @@ "step": 1, "readonly": true }, - "outstanding_rent_or_charges": { + "hbrentshortfall": { "check_answer_label": "After housing benefit and/or housing element of UC payment is received, will there be an outstanding amount for basic rent and/or benefit eligible charges?", "header": "After housing benefit and/or housing element of UC payment is received, will there be an outstanding amount for basic rent and/or benefit eligible charges?", "hint_text": "", "type": "radio", "answer_options": { "0": "Yes", - "1": "No" + "1": "No", + "2": "Do not know" }, "conditional_for": { - "outstanding_amount": ["Yes"] + "tshortfall": ["Yes"] } }, - "outstanding_amount": { + "tshortfall": { "check_answer_label": "Outstanding amount", "header": "What do you expect the amount to be?", "hint_text": "If the amount is unknown you can estimate", @@ -1903,7 +1903,7 @@ "header": "", "description": "", "questions": { - "previous_la": { + "prevloc": { "check_answer_label": "The LA in which household lived immediately before this letting\t", "header": "Which local authority area did the household live in immediately before this letting?", "hint_text": "Includes temporary accommodation", @@ -2249,7 +2249,8 @@ "type": "radio", "answer_options": { "0": "Yes", - "1": "No" + "1": "No", + "2": "Do not know" }, "conditional_for": { "reasonable_preference_reason": ["Yes"] diff --git a/db/migrate/20211108134601_further_core_migrations.rb b/db/migrate/20211108134601_further_core_migrations.rb new file mode 100644 index 000000000..b6008e66e --- /dev/null +++ b/db/migrate/20211108134601_further_core_migrations.rb @@ -0,0 +1,57 @@ +class FurtherCoreMigrations < ActiveRecord::Migration[6.1] + def up + change_table :case_logs, bulk: true do |t| + t.remove :condition_effects_prefer_not_to_say + t.remove :reason_for_leaving_last_settled_home + t.column :reason, :integer + t.remove :property_reference + t.column :propcode, :string + t.remove :property_major_repairs + t.column :majorrepairs, :integer + t.remove :property_location + t.column :la, :string + t.remove :previous_la + t.column :prevloc, :string + t.remove :housing_benefit + t.column :hb, :integer + t.remove :outstanding_rent_or_charges + t.column :hbrentshortfall, :integer + t.remove :outstanding_amount + t.column :tshortfall, :integer + t.column :postcode, :string + t.column :postcod2, :string + t.column :ppostc1, :string + t.column :ppostc2, :string + t.remove :property_relet + t.column :property_relet, :integer + end + end + + def down + change_table :case_logs, bulk: true do |t| + t.column :condition_effects_prefer_not_to_say, :integer + t.column :reason_for_leaving_last_settled_home, :string + t.remove :reason + t.column :property_reference, :string + t.remove :propcode + t.column :property_major_repairs, :string + t.remove :majorrepairs + t.column :property_location, :string + t.remove :la + t.column :previous_la, :string + t.remove :prevloc + t.column :housing_benefit, :string + t.remove :hb + t.column :outstanding_rent_or_charges, :string + t.remove :hbrentshortfall + t.column :outstanding_amount, :string + t.remove :tshortfall + t.remove :postcode + t.remove :postcod2 + t.remove :ppostc1 + t.remove :ppostc2 + t.remove :property_relet + t.column :property_relet, :string + end + end +end diff --git a/db/schema.rb b/db/schema.rb index 005086022..a1b19f7f2 100644 --- a/db/schema.rb +++ b/db/schema.rb @@ -10,7 +10,7 @@ # # It's strongly recommended that you check this file into your version control system. -ActiveRecord::Schema.define(version: 2021_11_08_091320) do +ActiveRecord::Schema.define(version: 2021_11_08_134601) do # These are extensions that must be enabled in order to support this database enable_extension "plpgsql" @@ -57,7 +57,6 @@ ActiveRecord::Schema.define(version: 2021_11_08_091320) do t.string "sex8" t.integer "ecstat8" t.integer "homeless" - t.string "reason_for_leaving_last_settled_home" t.integer "underoccupation_benefitcap" t.integer "leftreg" t.integer "reservist" @@ -73,40 +72,32 @@ ActiveRecord::Schema.define(version: 2021_11_08_091320) do t.integer "tenancy" t.string "lettype" t.integer "landlord" - t.string "property_location" t.string "previous_postcode" - t.string "property_relet" t.integer "rsnvac" - t.string "property_reference" t.integer "unittype_gn" t.string "property_building_type" t.integer "beds" t.string "property_void_date" - t.string "property_major_repairs" t.string "property_major_repairs_date" t.integer "offered" t.integer "wchair" t.integer "earnings" t.integer "incfreq" t.integer "benefits" - t.string "housing_benefit" t.integer "period" t.integer "brent" t.integer "scharge" t.integer "pscharge" t.integer "supcharg" t.integer "tcharge" - t.string "outstanding_amount" t.integer "layear" t.integer "lawaitlist" - t.string "previous_la" t.string "property_postcode" t.integer "reasonpref" t.string "reasonable_preference_reason" t.integer "cbl" t.integer "chr" t.integer "cap" - t.string "outstanding_rent_or_charges" t.string "other_reason_for_leaving_last_settled_home" t.integer "housingneeds_a" t.integer "housingneeds_b" @@ -125,7 +116,6 @@ ActiveRecord::Schema.define(version: 2021_11_08_091320) do t.integer "illness_type_7" t.integer "illness_type_9" t.integer "illness_type_10" - t.integer "condition_effects_prefer_not_to_say" t.integer "rp_homeless" t.integer "rp_insan_unsat" t.integer "rp_medwel" @@ -146,6 +136,19 @@ ActiveRecord::Schema.define(version: 2021_11_08_091320) do t.string "needs_type" t.string "sale_completion_date" t.string "purchaser_code" + t.integer "reason" + t.string "propcode" + t.integer "majorrepairs" + t.string "la" + t.string "prevloc" + t.integer "hb" + t.integer "hbrentshortfall" + t.integer "tshortfall" + t.string "postcode" + t.string "postcod2" + t.string "ppostc1" + t.string "ppostc2" + t.integer "property_relet" t.index ["discarded_at"], name: "index_case_logs_on_discarded_at" end diff --git a/docs/api/DLUHC-CORE-Data.v1.json b/docs/api/DLUHC-CORE-Data.v1.json index 47c068472..654307a59 100644 --- a/docs/api/DLUHC-CORE-Data.v1.json +++ b/docs/api/DLUHC-CORE-Data.v1.json @@ -293,7 +293,7 @@ "sex8": "Prefer not to say", "ecstat8": "Child under 16", "homeless": "No", - "reason_for_leaving_last_settled_home": "Other problems with neighbours", + "reason": "Other problems with neighbours", "underoccupation_benefitcap": "No", "leftreg": "No", "reservist": "No", @@ -309,7 +309,7 @@ "tenancy": "Fixed term – Secure", "lettype": "Affordable Rent - General Needs", "landlord": "This landlord", - "property_location": "Barnet", + "la": "Barnet", "previous_postcode": "NW1 5TY", "property_relet": "No", "rsnvac": "Relet - tenant abandoned property", @@ -325,24 +325,24 @@ "earnings": 1000, "incfreq": "Monthly", "benefits": "Some", - "housing_benefit": "Universal Credit with housing element, but not Housing Benefit", + "hb": "Universal Credit with housing element, but not Housing Benefit", "period": "Weekly", "brent": 200, "scharge": 50, "pscharge": 40, "supcharg": 35, "tcharge": 325, - "outstanding_amount": "Yes", + "tshortfall": "Yes", "layear": "1 to 2 years", "lawaitlist": "Less than 1 year", - "previous_la": "Ashford", + "prevloc": "Ashford", "property_postcode": "SE2 6RT", "reasonpref": "Yes", "reasonable_preference_reason": "dummy", "cbl": true, "chr": false, "cap": false, - "outstanding_rent_or_charges": 25, + "hbrentshortfall": "Yes", "other_reason_for_leaving_last_settled_home": "Other reason", "housingneeds_a": true, "housingneeds_b": false, @@ -727,7 +727,7 @@ "type": "string", "minLength": 1 }, - "reason_for_leaving_last_settled_home": { + "reason": { "type": "string", "minLength": 1, "enum": [ @@ -836,7 +836,7 @@ "type": "string", "minLength": 1 }, - "property_location": { + "la": { "type": "string", "minLength": 1 }, @@ -902,7 +902,7 @@ "minLength": 1, "enum": ["All", "Some", "None", "Do not know"] }, - "housing_benefit": { + "hb": { "type": "string", "minLength": 1 }, @@ -925,7 +925,7 @@ "tcharge": { "type": "number" }, - "outstanding_amount": { + "tshortfall": { "type": "string", "minLength": 1 }, @@ -937,7 +937,7 @@ "type": "string", "minLength": 1 }, - "previous_la": { + "prevloc": { "type": "string", "minLength": 1 }, @@ -962,7 +962,7 @@ "cap": { "type": "boolean" }, - "outstanding_rent_or_charges": { + "hbrentshortfall": { "type": "number" }, "other_reason_for_leaving_last_settled_home": { @@ -1082,7 +1082,7 @@ "sex8", "ecstat8", "homeless", - "reason_for_leaving_last_settled_home", + "reason", "underoccupation_benefitcap", "leftreg", "reservist", @@ -1098,7 +1098,7 @@ "tenancy", "lettype", "landlord", - "property_location", + "la", "previous_postcode", "property_relet", "rsnvac", @@ -1114,24 +1114,24 @@ "earnings", "incfreq", "benefits", - "housing_benefit", + "hb", "period", "brent", "scharge", "pscharge", "supcharg", "tcharge", - "outstanding_amount", + "tshortfall", "layear", "lawaitlist", - "previous_la", + "prevloc", "property_postcode", "reasonpref", "reasonable_preference_reason", "cbl", "chr", "cap", - "outstanding_rent_or_charges", + "hbrentshortfall", "other_reason_for_leaving_last_settled_home", "housingneeds_a", "housingneeds_b", diff --git a/spec/controllers/case_logs_controller_spec.rb b/spec/controllers/case_logs_controller_spec.rb index 2eecfdfe2..40d93cc59 100644 --- a/spec/controllers/case_logs_controller_spec.rb +++ b/spec/controllers/case_logs_controller_spec.rb @@ -150,6 +150,33 @@ RSpec.describe CaseLogsController, type: :controller do expect(response).to redirect_to("/case_logs/#{id}/conditional_question_no_page") end end + + context "partition postcode" do + let(:case_log_with_postcode) do + { + property_postcode: "M1 1AE", + previous_postcode: "M2 2AE", + page: "property_postcode", + } + end + it "saves full and partial postcodes" do + post :submit_form, params: { id: id, case_log: case_log_with_postcode } + case_log.reload + + expect(case_log.property_postcode).to eq("M1 1AE") + expect(case_log.postcode).to eq("M1") + expect(case_log.postcod2).to eq("1AE") + end + + it "saves full and partial previous postcodes" do + post :submit_form, params: { id: id, case_log: case_log_with_postcode } + case_log.reload + + expect(case_log.previous_postcode).to eq("M2 2AE") + expect(case_log.ppostc1).to eq("M2") + expect(case_log.ppostc2).to eq("2AE") + end + end end describe "get_next_page_path" do diff --git a/spec/factories/case_log.rb b/spec/factories/case_log.rb index 4528a7749..b46606279 100644 --- a/spec/factories/case_log.rb +++ b/spec/factories/case_log.rb @@ -4,8 +4,8 @@ FactoryBot.define do trait :in_progress do status { 1 } tenant_code { "TH356" } - property_postcode { "SW2 6HI" } - previous_postcode { "P0 5ST" } + property_postcode { "P0 5ST" } + previous_postcode { "SW2 6HI" } age1 { "17" } end trait :completed do diff --git a/spec/features/case_log_spec.rb b/spec/features/case_log_spec.rb index 0e2ae338b..aa53b8c7d 100644 --- a/spec/features/case_log_spec.rb +++ b/spec/features/case_log_spec.rb @@ -25,7 +25,7 @@ RSpec.describe "Test Features" do click_button("Save and continue") choose("case-log-benefits-all-field") click_button("Save and continue") - choose("case-log-housing-benefit-housing-benefit-but-not-universal-credit-field") + choose("case-log-hb-housing-benefit-but-not-universal-credit-field") click_button("Save and continue") end @@ -175,8 +175,8 @@ RSpec.describe "Test Features" do end it "displays number answers in inputs if they are already saved" do - visit("/case_logs/#{id}/previous_postcode") - expect(page).to have_field("case-log-previous-postcode-field", with: "P0 5ST") + visit("/case_logs/#{id}/property_postcode") + expect(page).to have_field("case-log-property-postcode-field", with: "P0 5ST") end it "displays text answers in inputs if they are already saved" do diff --git a/spec/fixtures/complete_case_log.json b/spec/fixtures/complete_case_log.json index 3d466170b..7bca4a575 100644 --- a/spec/fixtures/complete_case_log.json +++ b/spec/fixtures/complete_case_log.json @@ -38,7 +38,7 @@ "sex8": "Prefer not to say", "ecstat8": "Child under 16", "homeless": "Yes - other homelessness", - "reason_for_leaving_last_settled_home": "Other problems with neighbours", + "reason": 1, "underoccupation_benefitcap": "No", "leftreg": "No - they left up to 5 years ago", "reservist": "No", @@ -54,8 +54,8 @@ "tenancy": "Fixed term – Secure", "lettype": "Affordable Rent - General Needs", "landlord": "This landlord", - "property_location": "Barnet", - "previous_postcode": "NW1 5TY", + "la": "Barnet", + "property_postcode": "NW1 5TY", "property_relet": "No", "rsnvac": "Relet - tenant abandoned property", "property_reference": "P9876", @@ -71,7 +71,7 @@ "earnings": 0, "incfreq": null, "benefits": "Some", - "housing_benefit": "Universal Credit with housing element, but not Housing Benefit", + "hb": "Universal Credit with housing element, but not Housing Benefit", "period": "Fortnightly", "brent": 200, "scharge": 50, @@ -81,14 +81,15 @@ "outstanding_amount": "Yes", "layear": "1 to 2 years", "lawaitlist": "Less than 1 year", - "previous_la": "Ashford", - "property_postcode": "SE2 6RT", + "prevloc": "Ashford", + "previous_postcode": "SE2 6RT", "reasonpref": "Yes", "reasonable_preference_reason": "dummy", "cbl": "Yes", "chr": "Yes", "cap": "No", - "outstanding_rent_or_charges": 25, + "hbrentshortfall": "Yes", + "tshortfall": 12, "other_reason_for_leaving_last_settled_home": null, "housingneeds_a": "Yes", "housingneeds_b": "No", @@ -125,6 +126,12 @@ "intermediate_rent_product_name": "", "needs_type": "", "sale_completion_date": "", - "purchaser_code": "" + "purchaser_code": "", + "propcode": "123", + "majorrepairs": "Yes", + "postcode": "a1", + "postcod2": "w3", + "ppostc1": "w3", + "ppostc2": "w3" } } diff --git a/spec/fixtures/forms/test_form.json b/spec/fixtures/forms/test_form.json index a52768299..15764300b 100644 --- a/spec/fixtures/forms/test_form.json +++ b/spec/fixtures/forms/test_form.json @@ -348,7 +348,7 @@ }, "housing_benefit": { "questions": { - "housing_benefit": { + "hb": { "check_answer_label": "Universal Credit & Housing Benefit", "header": "Is the tenant likely to be in receipt of any of these housing-related benefits?", "type": "radio", @@ -494,14 +494,20 @@ } } }, - "previous_postcode": { + "property_postcode": { "questions": { - "previous_postcode": { + "property_postcode": { "check_answer_label": "Postcode of previous accomodation if the household has moved from settled accommodation", "header": "Postcode for the previous accommodation", "hint_text": "If the household has moved from settled accommodation immediately prior to being re-housed", "type": "text", "conditional_for": { "faake_key": "fake_condition" } + }, + "previous_postcode": { + "check_answer_label": "Postcode of previous accomodation if the household has moved from settled accommodation", + "header": "Postcode for the previous accommodation", + "hint_text": "If the household has moved from settled accommodation immediately prior to being re-housed", + "type": "text" } } } diff --git a/spec/helpers/check_answers_helper_spec.rb b/spec/helpers/check_answers_helper_spec.rb index fb8deec77..7ad04f081 100644 --- a/spec/helpers/check_answers_helper_spec.rb +++ b/spec/helpers/check_answers_helper_spec.rb @@ -127,7 +127,7 @@ RSpec.describe CheckAnswersHelper do it "returns total questions" do result = total_questions(subsection, case_log, form) expect(result.class).to eq(Hash) - expected_keys = %w[earnings incfreq benefits housing_benefit] + expected_keys = %w[earnings incfreq benefits hb] expect(result.keys).to eq(expected_keys) end diff --git a/spec/helpers/tasklist_helper_spec.rb b/spec/helpers/tasklist_helper_spec.rb index db9ac3cae..e900363f2 100644 --- a/spec/helpers/tasklist_helper_spec.rb +++ b/spec/helpers/tasklist_helper_spec.rb @@ -33,7 +33,7 @@ RSpec.describe TasklistHelper do case_log["earnings"] = "value" case_log["incfreq"] = "Weekly" case_log["benefits"] = "All" - case_log["housing_benefit"] = "Do not know" + case_log["hb"] = "Do not know" status = get_subsection_status("income_and_benefits", case_log, income_and_benefits_questions) expect(status).to eq(:completed) diff --git a/spec/models/case_log_spec.rb b/spec/models/case_log_spec.rb index 75bc1f1a6..438bf3c55 100644 --- a/spec/models/case_log_spec.rb +++ b/spec/models/case_log_spec.rb @@ -60,7 +60,7 @@ RSpec.describe Form, type: :model do context "reason for leaving last settled home validation" do it "Reason for leaving must be don't know if reason for leaving settled home (Q9a) is don't know." do expect { - CaseLog.create!(reason_for_leaving_last_settled_home: "Do not know", + CaseLog.create!(reason: "Do not know", underoccupation_benefitcap: "Yes - benefit cap") }.to raise_error(ActiveRecord::RecordInvalid) end @@ -68,14 +68,14 @@ RSpec.describe Form, type: :model do context "other reason for leaving last settled home validation" do it "must be provided if main reason for leaving last settled home was given as other" do expect { - CaseLog.create!(reason_for_leaving_last_settled_home: "Other", + CaseLog.create!(reason: "Other", other_reason_for_leaving_last_settled_home: nil) }.to raise_error(ActiveRecord::RecordInvalid) end it "must not be provided if the main reason for leaving settled home is not other" do expect { - CaseLog.create!(reason_for_leaving_last_settled_home: "Repossession", + CaseLog.create!(reason: "Repossession", other_reason_for_leaving_last_settled_home: "the other reason provided") }.to raise_error(ActiveRecord::RecordInvalid) end @@ -139,15 +139,15 @@ RSpec.describe Form, type: :model do context "outstanding rent or charges validation" do it "must be anwered if answered yes to outstanding rent or charges" do expect { - CaseLog.create!(outstanding_rent_or_charges: "Yes", - outstanding_amount: nil) + CaseLog.create!(hbrentshortfall: "Yes", + tshortfall: nil) }.to raise_error(ActiveRecord::RecordInvalid) end it "must be not be anwered if answered no to outstanding rent or charges" do expect { - CaseLog.create!(outstanding_rent_or_charges: "No", - outstanding_amount: 99) + CaseLog.create!(hbrentshortfall: "No", + tshortfall: 99) }.to raise_error(ActiveRecord::RecordInvalid) end end diff --git a/spec/models/form_spec.rb b/spec/models/form_spec.rb index f4e554356..18e15c6b4 100644 --- a/spec/models/form_spec.rb +++ b/spec/models/form_spec.rb @@ -39,7 +39,7 @@ RSpec.describe Form, type: :model do it "returns all questions for subsection" do result = form.questions_for_subsection(subsection) expect(result.length).to eq(4) - expect(result.keys).to eq(%w[earnings incfreq benefits housing_benefit]) + expect(result.keys).to eq(%w[earnings incfreq benefits hb]) end end end From 109947bb97a6040eb4083fe636ac8b9e9de65f41 Mon Sep 17 00:00:00 2001 From: Kat Date: Thu, 11 Nov 2021 09:28:09 +0000 Subject: [PATCH 21/29] Update majorrepairs field name in docs and test file --- app/admin/case_logs.rb | 2 +- docs/api/DLUHC-CORE-Data.v1.json | 6 +++--- spec/fixtures/complete_case_log.json | 2 +- 3 files changed, 5 insertions(+), 5 deletions(-) diff --git a/app/admin/case_logs.rb b/app/admin/case_logs.rb index c3716ad6d..6768befae 100644 --- a/app/admin/case_logs.rb +++ b/app/admin/case_logs.rb @@ -2,7 +2,7 @@ ActiveAdmin.register CaseLog do # See permitted parameters documentation: # https://github.com/activeadmin/activeadmin/blob/master/docs/2-resource-customization.md#setting-up-strong-parameters permit_params do - permitted = %i[status tenant_code age1 sex1 tenant_ethnic_group tenant_nationality previous_housing_situation armed_forces ecstat1 hhmemb relat2 age2 sex2 ecstat2 relat3 age3 sex3 ecstat3 relat4 age4 sex4 ecstat4 relat5 age5 sex5 ecstat5 relat6 age6 sex6 ecstat6 relat7 age7 person_7_gender ecstat7 relat8 age8 sex8 ecstat8 homelessness reason benefit_cap_spare_room_subsidy armed_forces_active armed_forces_injured armed_forces_partner medical_conditions pregnancy accessibility_requirements condition_effects tenancy_code tenancy_start_date starter_tenancy fixed_term_tenancy tenancy_type letting_type letting_provider la previous_postcode property_relet property_vacancy_reason property_reference property_unit_type property_building_type property_number_of_bedrooms property_void_date property_major_repairs property_major_repairs_date property_number_of_times_relet property_wheelchair_accessible net_income net_income_frequency net_income_uc_proportion hb rent_frequency basic_rent service_charge personal_service_charge support_charge total_charge tshortfall time_lived_in_la time_on_la_waiting_list prevloc property_postcode reasonable_preference reasonable_preference_reason cbl_letting chr_letting cap_letting hbrentshortfall other_reason accessibility_requirements_fully_wheelchair_accessible_housing accessibility_requirements_wheelchair_access_to_essential_rooms accessibility_requirements_level_access_housing accessibility_requirements_other_disability_requirements accessibility_requirements_no_disability_requirements accessibility_requirements_do_not_know accessibility_requirements_prefer_not_to_say condition_effects_vision condition_effects_hearing condition_effects_mobility condition_effects_dexterity condition_effects_stamina condition_effects_learning condition_effects_memory condition_effects_mental_health condition_effects_social_or_behavioral condition_effects_other condition_effects_prefer_not_to_say reasonable_preference_reason_homeless reasonable_preference_reason_unsatisfactory_housing reasonable_preference_reason_medical_grounds reasonable_preference_reason_avoid_hardship reasonable_preference_reason_do_not_know other_tenancy_type override_net_income_validation net_income_known] + permitted = %i[status tenant_code age1 sex1 tenant_ethnic_group tenant_nationality previous_housing_situation armed_forces ecstat1 hhmemb relat2 age2 sex2 ecstat2 relat3 age3 sex3 ecstat3 relat4 age4 sex4 ecstat4 relat5 age5 sex5 ecstat5 relat6 age6 sex6 ecstat6 relat7 age7 person_7_gender ecstat7 relat8 age8 sex8 ecstat8 homelessness reason benefit_cap_spare_room_subsidy armed_forces_active armed_forces_injured armed_forces_partner medical_conditions pregnancy accessibility_requirements condition_effects tenancy_code tenancy_start_date starter_tenancy fixed_term_tenancy tenancy_type letting_type letting_provider la previous_postcode property_relet property_vacancy_reason property_reference property_unit_type property_building_type property_number_of_bedrooms property_void_date majorrepairs property_major_repairs_date property_number_of_times_relet property_wheelchair_accessible net_income net_income_frequency net_income_uc_proportion hb rent_frequency basic_rent service_charge personal_service_charge support_charge total_charge tshortfall time_lived_in_la time_on_la_waiting_list prevloc property_postcode reasonable_preference reasonable_preference_reason cbl_letting chr_letting cap_letting hbrentshortfall other_reason accessibility_requirements_fully_wheelchair_accessible_housing accessibility_requirements_wheelchair_access_to_essential_rooms accessibility_requirements_level_access_housing accessibility_requirements_other_disability_requirements accessibility_requirements_no_disability_requirements accessibility_requirements_do_not_know accessibility_requirements_prefer_not_to_say condition_effects_vision condition_effects_hearing condition_effects_mobility condition_effects_dexterity condition_effects_stamina condition_effects_learning condition_effects_memory condition_effects_mental_health condition_effects_social_or_behavioral condition_effects_other condition_effects_prefer_not_to_say reasonable_preference_reason_homeless reasonable_preference_reason_unsatisfactory_housing reasonable_preference_reason_medical_grounds reasonable_preference_reason_avoid_hardship reasonable_preference_reason_do_not_know other_tenancy_type override_net_income_validation net_income_known] permitted end diff --git a/docs/api/DLUHC-CORE-Data.v1.json b/docs/api/DLUHC-CORE-Data.v1.json index 654307a59..860255260 100644 --- a/docs/api/DLUHC-CORE-Data.v1.json +++ b/docs/api/DLUHC-CORE-Data.v1.json @@ -318,7 +318,7 @@ "property_building_type": "dummy", "beds": 3, "property_void_date": "03/11/2019", - "property_major_repairs": "Yes", + "majorrepairs": "Yes", "property_major_repairs_date": "05/05/2020", "offered": 2, "wchair": true, @@ -871,7 +871,7 @@ "type": "string", "minLength": 1 }, - "property_major_repairs": { + "majorrepairs": { "type": "string", "minLength": 1 }, @@ -1107,7 +1107,7 @@ "property_building_type", "beds", "property_void_date", - "property_major_repairs", + "majorrepairs", "property_major_repairs_date", "offered", "wchair", diff --git a/spec/fixtures/complete_case_log.json b/spec/fixtures/complete_case_log.json index 7bca4a575..01fc5d998 100644 --- a/spec/fixtures/complete_case_log.json +++ b/spec/fixtures/complete_case_log.json @@ -63,7 +63,7 @@ "property_building_type": "dummy", "beds": 3, "property_void_date": "03/11/2019", - "property_major_repairs": "Yes", + "majorrepairs": "Yes", "property_major_repairs_date": "05/05/2020", "offered": 2, "wchair": "Yes", From 20bda98d4b8faff2337bc73a9ecdd72835174e2a Mon Sep 17 00:00:00 2001 From: kosiakkatrina <54268893+kosiakkatrina@users.noreply.github.com> Date: Thu, 11 Nov 2021 14:44:55 +0000 Subject: [PATCH 22/29] Save mcr date as datetime, fix saving the dates (#85) --- app/admin/case_logs.rb | 2 +- app/controllers/case_logs_controller.rb | 6 +++++ app/models/case_log.rb | 20 +++++++++++++++++ config/forms/2021_2022.json | 4 ++-- db/migrate/20211110140928_add_mrc_dates.rb | 21 ++++++++++++++++++ db/schema.rb | 7 ++++-- docs/api/DLUHC-CORE-Data.v1.json | 6 ++--- spec/controllers/case_logs_controller_spec.rb | 22 +++++++++++++++++++ spec/fixtures/complete_case_log.json | 5 ++++- spec/fixtures/forms/test_form.json | 10 +++++++++ spec/models/form_handler_spec.rb | 2 +- 11 files changed, 95 insertions(+), 10 deletions(-) create mode 100644 db/migrate/20211110140928_add_mrc_dates.rb diff --git a/app/admin/case_logs.rb b/app/admin/case_logs.rb index 6768befae..f32cff52b 100644 --- a/app/admin/case_logs.rb +++ b/app/admin/case_logs.rb @@ -2,7 +2,7 @@ ActiveAdmin.register CaseLog do # See permitted parameters documentation: # https://github.com/activeadmin/activeadmin/blob/master/docs/2-resource-customization.md#setting-up-strong-parameters permit_params do - permitted = %i[status tenant_code age1 sex1 tenant_ethnic_group tenant_nationality previous_housing_situation armed_forces ecstat1 hhmemb relat2 age2 sex2 ecstat2 relat3 age3 sex3 ecstat3 relat4 age4 sex4 ecstat4 relat5 age5 sex5 ecstat5 relat6 age6 sex6 ecstat6 relat7 age7 person_7_gender ecstat7 relat8 age8 sex8 ecstat8 homelessness reason benefit_cap_spare_room_subsidy armed_forces_active armed_forces_injured armed_forces_partner medical_conditions pregnancy accessibility_requirements condition_effects tenancy_code tenancy_start_date starter_tenancy fixed_term_tenancy tenancy_type letting_type letting_provider la previous_postcode property_relet property_vacancy_reason property_reference property_unit_type property_building_type property_number_of_bedrooms property_void_date majorrepairs property_major_repairs_date property_number_of_times_relet property_wheelchair_accessible net_income net_income_frequency net_income_uc_proportion hb rent_frequency basic_rent service_charge personal_service_charge support_charge total_charge tshortfall time_lived_in_la time_on_la_waiting_list prevloc property_postcode reasonable_preference reasonable_preference_reason cbl_letting chr_letting cap_letting hbrentshortfall other_reason accessibility_requirements_fully_wheelchair_accessible_housing accessibility_requirements_wheelchair_access_to_essential_rooms accessibility_requirements_level_access_housing accessibility_requirements_other_disability_requirements accessibility_requirements_no_disability_requirements accessibility_requirements_do_not_know accessibility_requirements_prefer_not_to_say condition_effects_vision condition_effects_hearing condition_effects_mobility condition_effects_dexterity condition_effects_stamina condition_effects_learning condition_effects_memory condition_effects_mental_health condition_effects_social_or_behavioral condition_effects_other condition_effects_prefer_not_to_say reasonable_preference_reason_homeless reasonable_preference_reason_unsatisfactory_housing reasonable_preference_reason_medical_grounds reasonable_preference_reason_avoid_hardship reasonable_preference_reason_do_not_know other_tenancy_type override_net_income_validation net_income_known] + permitted = %i[status tenant_code age1 sex1 tenant_ethnic_group tenant_nationality previous_housing_situation armed_forces ecstat1 hhmemb relat2 age2 sex2 ecstat2 relat3 age3 sex3 ecstat3 relat4 age4 sex4 ecstat4 relat5 age5 sex5 ecstat5 relat6 age6 sex6 ecstat6 relat7 age7 person_7_gender ecstat7 relat8 age8 sex8 ecstat8 homelessness reason benefit_cap_spare_room_subsidy armed_forces_active armed_forces_injured armed_forces_partner medical_conditions pregnancy accessibility_requirements condition_effects tenancy_code tenancy_start_date starter_tenancy fixed_term_tenancy tenancy_type letting_type letting_provider la previous_postcode property_relet property_vacancy_reason property_reference property_unit_type property_building_type property_number_of_bedrooms property_void_date majorrepairs mrcdate property_number_of_times_relet property_wheelchair_accessible net_income net_income_frequency net_income_uc_proportion hb rent_frequency basic_rent service_charge personal_service_charge support_charge total_charge tshortfall time_lived_in_la time_on_la_waiting_list prevloc property_postcode reasonable_preference reasonable_preference_reason cbl_letting chr_letting cap_letting hbrentshortfall other_reason accessibility_requirements_fully_wheelchair_accessible_housing accessibility_requirements_wheelchair_access_to_essential_rooms accessibility_requirements_level_access_housing accessibility_requirements_other_disability_requirements accessibility_requirements_no_disability_requirements accessibility_requirements_do_not_know accessibility_requirements_prefer_not_to_say condition_effects_vision condition_effects_hearing condition_effects_mobility condition_effects_dexterity condition_effects_stamina condition_effects_learning condition_effects_memory condition_effects_mental_health condition_effects_social_or_behavioral condition_effects_other condition_effects_prefer_not_to_say reasonable_preference_reason_homeless reasonable_preference_reason_unsatisfactory_housing reasonable_preference_reason_medical_grounds reasonable_preference_reason_avoid_hardship reasonable_preference_reason_do_not_know other_tenancy_type override_net_income_validation net_income_known] permitted end diff --git a/app/controllers/case_logs_controller.rb b/app/controllers/case_logs_controller.rb index cc2a4b484..8eb60af6a 100644 --- a/app/controllers/case_logs_controller.rb +++ b/app/controllers/case_logs_controller.rb @@ -103,6 +103,12 @@ private form = FormHandler.instance.get_form("2021_2022") form.expected_responses_for_page(page).each_with_object({}) do |(question_key, question_info), result| question_params = params["case_log"][question_key] + if question_info["type"] == "date" + day = params["case_log"]["#{question_key}(3i)"] + month = params["case_log"]["#{question_key}(2i)"] + year = params["case_log"]["#{question_key}(1i)"] + result[question_key] = Date.new(year.to_i, month.to_i, day.to_i) + end next unless question_params if %w[checkbox validation_override].include?(question_info["type"]) diff --git a/app/models/case_log.rb b/app/models/case_log.rb index c058fb5f3..4d59ea91a 100644 --- a/app/models/case_log.rb +++ b/app/models/case_log.rb @@ -169,6 +169,26 @@ class CaseLog < ApplicationRecord IncomeRange::ALLOWED[ecstat1.to_sym] end + def mrcday + if mrcdate.present? + mrcdate.day + end + end + + def mrcmonth + if mrcdate.present? + mrcdate.month + end + end + + def mrcyear + if mrcdate.present? + mrcdate.year + end + end + + + private def update_status! diff --git a/config/forms/2021_2022.json b/config/forms/2021_2022.json index 52d80f8ee..5606f956e 100644 --- a/config/forms/2021_2022.json +++ b/config/forms/2021_2022.json @@ -1585,10 +1585,10 @@ "1": "No" }, "conditional_for": { - "property_major_repairs_date": ["Yes"] + "mrcdate": ["Yes"] } }, - "property_major_repairs_date": { + "mrcdate": { "check_answer_label": "What was the major repairs completion date?", "header": "What was the major repairs completion date?", "hint_text": "For example, 27 3 2007", diff --git a/db/migrate/20211110140928_add_mrc_dates.rb b/db/migrate/20211110140928_add_mrc_dates.rb new file mode 100644 index 000000000..08c1c70d3 --- /dev/null +++ b/db/migrate/20211110140928_add_mrc_dates.rb @@ -0,0 +1,21 @@ +class AddMrcDates < ActiveRecord::Migration[6.1] + def up + change_table :case_logs, bulk: true do |t| + t.remove :property_major_repairs_date + t.column :mrcdate, :datetime + t.column :mrcday, :integer + t.column :mrcmonth, :integer + t.column :mrcyear, :integer + end + end + + def down + change_table :case_logs, bulk: true do |t| + t.column :property_major_repairs_date, :string + t.remove :mrcdate + t.remove :mrcday + t.remove :mrcmonth + t.remove :mrcyear + end + end +end diff --git a/db/schema.rb b/db/schema.rb index a1b19f7f2..ba9b956dd 100644 --- a/db/schema.rb +++ b/db/schema.rb @@ -10,7 +10,7 @@ # # It's strongly recommended that you check this file into your version control system. -ActiveRecord::Schema.define(version: 2021_11_08_134601) do +ActiveRecord::Schema.define(version: 2021_11_10_140928) do # These are extensions that must be enabled in order to support this database enable_extension "plpgsql" @@ -78,7 +78,6 @@ ActiveRecord::Schema.define(version: 2021_11_08_134601) do t.string "property_building_type" t.integer "beds" t.string "property_void_date" - t.string "property_major_repairs_date" t.integer "offered" t.integer "wchair" t.integer "earnings" @@ -149,6 +148,10 @@ ActiveRecord::Schema.define(version: 2021_11_08_134601) do t.string "ppostc1" t.string "ppostc2" t.integer "property_relet" + t.datetime "mrcdate" + t.integer "mrcday" + t.integer "mrcmonth" + t.integer "mrcyear" t.index ["discarded_at"], name: "index_case_logs_on_discarded_at" end diff --git a/docs/api/DLUHC-CORE-Data.v1.json b/docs/api/DLUHC-CORE-Data.v1.json index 860255260..e13ad4f17 100644 --- a/docs/api/DLUHC-CORE-Data.v1.json +++ b/docs/api/DLUHC-CORE-Data.v1.json @@ -319,7 +319,7 @@ "beds": 3, "property_void_date": "03/11/2019", "majorrepairs": "Yes", - "property_major_repairs_date": "05/05/2020", + "mrcdate": "05/05/2020", "offered": 2, "wchair": true, "earnings": 1000, @@ -875,7 +875,7 @@ "type": "string", "minLength": 1 }, - "property_major_repairs_date": { + "mrcdate": { "type": "string", "minLength": 1 }, @@ -1108,7 +1108,7 @@ "beds", "property_void_date", "majorrepairs", - "property_major_repairs_date", + "mrcdate", "offered", "wchair", "earnings", diff --git a/spec/controllers/case_logs_controller_spec.rb b/spec/controllers/case_logs_controller_spec.rb index 40d93cc59..007b76f8c 100644 --- a/spec/controllers/case_logs_controller_spec.rb +++ b/spec/controllers/case_logs_controller_spec.rb @@ -177,6 +177,28 @@ RSpec.describe CaseLogsController, type: :controller do expect(case_log.ppostc2).to eq("2AE") end end + + context "partition date" do + let(:case_log_with_date) do + { + :"mrcdate(1i)" => "2021", + :"mrcdate(2i)" => "05", + :"mrcdate(3i)" => "04", + :page => "major_repairs_date", + } + end + it "saves full and partial dates" do + post :submit_form, params: { id: id, case_log: case_log_with_date } + case_log.reload + + expect(case_log.mrcdate.day).to eq(4) + expect(case_log.mrcdate.month).to eq(5) + expect(case_log.mrcdate.year).to eq(2021) + expect(case_log.mrcday).to eq(4) + expect(case_log.mrcmonth).to eq(5) + expect(case_log.mrcyear).to eq(2021) + end + end end describe "get_next_page_path" do diff --git a/spec/fixtures/complete_case_log.json b/spec/fixtures/complete_case_log.json index 01fc5d998..97afaeaa0 100644 --- a/spec/fixtures/complete_case_log.json +++ b/spec/fixtures/complete_case_log.json @@ -64,7 +64,10 @@ "beds": 3, "property_void_date": "03/11/2019", "majorrepairs": "Yes", - "property_major_repairs_date": "05/05/2020", + "mrcdate": "05/05/2020", + "mrcday": 5, + "mrcmonth": 5, + "mrcyear": 2020, "offered": 2, "wchair": "Yes", "net_income_known": "Yes", diff --git a/spec/fixtures/forms/test_form.json b/spec/fixtures/forms/test_form.json index 15764300b..95ac050da 100644 --- a/spec/fixtures/forms/test_form.json +++ b/spec/fixtures/forms/test_form.json @@ -510,6 +510,16 @@ "type": "text" } } + }, + "major_repairs_date": { + "questions": { + "mrcdate": { + "check_answer_label": "What was the major repairs completion date?", + "header": "What was the major repairs completion date?", + "hint_text": "For example, 27 3 2007", + "type": "date" + } + } } } } diff --git a/spec/models/form_handler_spec.rb b/spec/models/form_handler_spec.rb index ff6d4dc0f..f998c5557 100644 --- a/spec/models/form_handler_spec.rb +++ b/spec/models/form_handler_spec.rb @@ -15,7 +15,7 @@ RSpec.describe FormHandler do form_handler = FormHandler.instance form = form_handler.get_form("test_form") expect(form).to be_a(Form) - expect(form.all_pages.count).to eq(22) + expect(form.all_pages.count).to eq(23) end end From 894228c02e455d7b21ade57a6690c75c133352bb Mon Sep 17 00:00:00 2001 From: kosiakkatrina <54268893+kosiakkatrina@users.noreply.github.com> Date: Thu, 11 Nov 2021 15:50:05 +0000 Subject: [PATCH 23/29] CLDC-678: Store total household members (#86) * Store other housdehold members and infer total household members * Remove redundant question --- app/admin/case_logs.rb | 2 +- app/models/case_log.rb | 8 +++++++- app/validations/household_validations.rb | 2 +- config/forms/2021_2022.json | 16 ++-------------- .../20211111143319_add_other_members_column.rb | 7 +++++++ db/schema.rb | 3 ++- docs/api/DLUHC-CORE-Data.v1.json | 6 +++--- spec/features/case_log_spec.rb | 4 ++-- spec/fixtures/complete_case_log.json | 3 ++- spec/fixtures/forms/test_form.json | 2 +- spec/helpers/check_answers_helper_spec.rb | 2 +- spec/models/case_log_spec.rb | 4 ++-- 12 files changed, 31 insertions(+), 28 deletions(-) create mode 100644 db/migrate/20211111143319_add_other_members_column.rb diff --git a/app/admin/case_logs.rb b/app/admin/case_logs.rb index f32cff52b..2a15fbb2a 100644 --- a/app/admin/case_logs.rb +++ b/app/admin/case_logs.rb @@ -2,7 +2,7 @@ ActiveAdmin.register CaseLog do # See permitted parameters documentation: # https://github.com/activeadmin/activeadmin/blob/master/docs/2-resource-customization.md#setting-up-strong-parameters permit_params do - permitted = %i[status tenant_code age1 sex1 tenant_ethnic_group tenant_nationality previous_housing_situation armed_forces ecstat1 hhmemb relat2 age2 sex2 ecstat2 relat3 age3 sex3 ecstat3 relat4 age4 sex4 ecstat4 relat5 age5 sex5 ecstat5 relat6 age6 sex6 ecstat6 relat7 age7 person_7_gender ecstat7 relat8 age8 sex8 ecstat8 homelessness reason benefit_cap_spare_room_subsidy armed_forces_active armed_forces_injured armed_forces_partner medical_conditions pregnancy accessibility_requirements condition_effects tenancy_code tenancy_start_date starter_tenancy fixed_term_tenancy tenancy_type letting_type letting_provider la previous_postcode property_relet property_vacancy_reason property_reference property_unit_type property_building_type property_number_of_bedrooms property_void_date majorrepairs mrcdate property_number_of_times_relet property_wheelchair_accessible net_income net_income_frequency net_income_uc_proportion hb rent_frequency basic_rent service_charge personal_service_charge support_charge total_charge tshortfall time_lived_in_la time_on_la_waiting_list prevloc property_postcode reasonable_preference reasonable_preference_reason cbl_letting chr_letting cap_letting hbrentshortfall other_reason accessibility_requirements_fully_wheelchair_accessible_housing accessibility_requirements_wheelchair_access_to_essential_rooms accessibility_requirements_level_access_housing accessibility_requirements_other_disability_requirements accessibility_requirements_no_disability_requirements accessibility_requirements_do_not_know accessibility_requirements_prefer_not_to_say condition_effects_vision condition_effects_hearing condition_effects_mobility condition_effects_dexterity condition_effects_stamina condition_effects_learning condition_effects_memory condition_effects_mental_health condition_effects_social_or_behavioral condition_effects_other condition_effects_prefer_not_to_say reasonable_preference_reason_homeless reasonable_preference_reason_unsatisfactory_housing reasonable_preference_reason_medical_grounds reasonable_preference_reason_avoid_hardship reasonable_preference_reason_do_not_know other_tenancy_type override_net_income_validation net_income_known] + permitted = %i[status tenant_code age1 sex1 tenant_ethnic_group tenant_nationality previous_housing_situation armed_forces ecstat1 other_hhmemb relat2 age2 sex2 ecstat2 relat3 age3 sex3 ecstat3 relat4 age4 sex4 ecstat4 relat5 age5 sex5 ecstat5 relat6 age6 sex6 ecstat6 relat7 age7 person_7_gender ecstat7 relat8 age8 sex8 ecstat8 homelessness reason benefit_cap_spare_room_subsidy armed_forces_active armed_forces_injured armed_forces_partner medical_conditions pregnancy accessibility_requirements condition_effects tenancy_code tenancy_start_date starter_tenancy fixed_term_tenancy tenancy_type letting_type letting_provider la previous_postcode property_relet property_vacancy_reason property_reference property_unit_type property_building_type property_number_of_bedrooms property_void_date majorrepairs mrcdate property_number_of_times_relet property_wheelchair_accessible net_income net_income_frequency net_income_uc_proportion hb rent_frequency basic_rent service_charge personal_service_charge support_charge total_charge tshortfall time_lived_in_la time_on_la_waiting_list prevloc property_postcode reasonable_preference reasonable_preference_reason cbl_letting chr_letting cap_letting hbrentshortfall other_reason accessibility_requirements_fully_wheelchair_accessible_housing accessibility_requirements_wheelchair_access_to_essential_rooms accessibility_requirements_level_access_housing accessibility_requirements_other_disability_requirements accessibility_requirements_no_disability_requirements accessibility_requirements_do_not_know accessibility_requirements_prefer_not_to_say condition_effects_vision condition_effects_hearing condition_effects_mobility condition_effects_dexterity condition_effects_stamina condition_effects_learning condition_effects_memory condition_effects_mental_health condition_effects_social_or_behavioral condition_effects_other condition_effects_prefer_not_to_say reasonable_preference_reason_homeless reasonable_preference_reason_unsatisfactory_housing reasonable_preference_reason_medical_grounds reasonable_preference_reason_avoid_hardship reasonable_preference_reason_do_not_know other_tenancy_type override_net_income_validation net_income_known] permitted end diff --git a/app/models/case_log.rb b/app/models/case_log.rb index 4d59ea91a..f21b3338d 100644 --- a/app/models/case_log.rb +++ b/app/models/case_log.rb @@ -163,6 +163,12 @@ class CaseLog < ApplicationRecord end end + def hhmemb + if other_hhmemb.present? + other_hhmemb + end + end + def applicable_income_range return unless ecstat1 @@ -239,7 +245,7 @@ private dynamically_not_required << "incfreq" end - start_range = (hhmemb || 0) + 2 + start_range = (other_hhmemb || 0) + 2 (start_range..8).each do |n| dynamically_not_required << "age#{n}" dynamically_not_required << "sex#{n}" diff --git a/app/validations/household_validations.rb b/app/validations/household_validations.rb index b36972667..d3536ae8a 100644 --- a/app/validations/household_validations.rb +++ b/app/validations/household_validations.rb @@ -80,7 +80,7 @@ module HouseholdValidations record.errors.add :unittype_gn, "A bedsit can only have one bedroom" end - if !record.hhmemb.nil? && record.hhmemb.positive? && (record.unittype_gn.include?("Shared") && !record.beds.to_i.between?(1, 7)) + if !record.other_hhmemb.nil? && record.other_hhmemb.positive? && (record.unittype_gn.include?("Shared") && !record.beds.to_i.between?(1, 7)) record.errors.add :unittype_gn, "A shared house must have 1 to 7 bedrooms" end diff --git a/config/forms/2021_2022.json b/config/forms/2021_2022.json index 5606f956e..5d06b8bd3 100644 --- a/config/forms/2021_2022.json +++ b/config/forms/2021_2022.json @@ -104,7 +104,7 @@ "header": "About this log", "description": "", "questions": { - "tenancy_start_date": { + "startdate": { "check_answer_label": "When is the tenancy start date?", "header": "What is the tenancy start date?", "hint_text": "For example, 27 3 2007", @@ -332,7 +332,7 @@ "header": "", "description": "", "questions": { - "hhmemb": { + "other_hhmemb": { "check_answer_label": "Number of Other Household Members", "header": "How many other people are there in the household?", "hint_text": "The maximum number of others is 7", @@ -1027,18 +1027,6 @@ } } }, - "tenancy_start_date": { - "header": "", - "description": "", - "questions": { - "startdate": { - "check_answer_label": "When is the tenancy start date?", - "header": "What is the tenancy start date?", - "hint_text": "For example, 27 3 2007", - "type": "date" - } - } - }, "starter_tenancy": { "header": "", "description": "", diff --git a/db/migrate/20211111143319_add_other_members_column.rb b/db/migrate/20211111143319_add_other_members_column.rb new file mode 100644 index 000000000..2c6ca2658 --- /dev/null +++ b/db/migrate/20211111143319_add_other_members_column.rb @@ -0,0 +1,7 @@ +class AddOtherMembersColumn < ActiveRecord::Migration[6.1] + def change + change_table :case_logs, bulk: true do |t| + t.column :other_hhmemb, :integer + end + end +end diff --git a/db/schema.rb b/db/schema.rb index ba9b956dd..5b1c02e62 100644 --- a/db/schema.rb +++ b/db/schema.rb @@ -10,7 +10,7 @@ # # It's strongly recommended that you check this file into your version control system. -ActiveRecord::Schema.define(version: 2021_11_10_140928) do +ActiveRecord::Schema.define(version: 2021_11_11_143319) do # These are extensions that must be enabled in order to support this database enable_extension "plpgsql" @@ -152,6 +152,7 @@ ActiveRecord::Schema.define(version: 2021_11_10_140928) do t.integer "mrcday" t.integer "mrcmonth" t.integer "mrcyear" + t.integer "other_hhmemb" t.index ["discarded_at"], name: "index_case_logs_on_discarded_at" end diff --git a/docs/api/DLUHC-CORE-Data.v1.json b/docs/api/DLUHC-CORE-Data.v1.json index e13ad4f17..17560d14c 100644 --- a/docs/api/DLUHC-CORE-Data.v1.json +++ b/docs/api/DLUHC-CORE-Data.v1.json @@ -263,7 +263,7 @@ "prevten": "Private sector tenancy", "armed_forces": "Yes - a regular", "ecstat1": "Full-time - 30 hours or more", - "hhmemb": 7, + "other_hhmemb": 7, "relat2": "Partner", "age2": 32, "sex2": "Male", @@ -459,7 +459,7 @@ "Prefer not to say" ] }, - "hhmemb": { + "other_hhmemb": { "type": "number", "minimum": 0, "maximum": 7 @@ -1052,7 +1052,7 @@ "prevten", "armed_forces", "ecstat1", - "hhmemb", + "other_hhmemb", "relat2", "age2", "sex2", diff --git a/spec/features/case_log_spec.rb b/spec/features/case_log_spec.rb index aa53b8c7d..b48572d62 100644 --- a/spec/features/case_log_spec.rb +++ b/spec/features/case_log_spec.rb @@ -9,7 +9,7 @@ RSpec.describe "Test Features" do tenant_code: { type: "text", answer: "BZ737", path: "tenant_code" }, age1: { type: "numeric", answer: 25, path: "person_1_age" }, sex1: { type: "radio", answer: "Female", path: "person_1_gender" }, - hhmemb: { type: "numeric", answer: 2, path: "household_number_of_other_members" }, + other_hhmemb: { type: "numeric", answer: 2, path: "household_number_of_other_members" }, } def fill_in_number_question(case_log_id, question, value, path) @@ -265,7 +265,7 @@ RSpec.describe "Test Features" do let(:last_question_for_subsection) { "household_number_of_other_members" } it "redirects to the check answers page when answering the last question and clicking save and continue" do - fill_in_number_question(id, "hhmemb", 0, last_question_for_subsection) + fill_in_number_question(id, "other_hhmemb", 0, last_question_for_subsection) expect(page).to have_current_path("/case_logs/#{id}/#{subsection}/check_answers") end diff --git a/spec/fixtures/complete_case_log.json b/spec/fixtures/complete_case_log.json index 97afaeaa0..4656a04f8 100644 --- a/spec/fixtures/complete_case_log.json +++ b/spec/fixtures/complete_case_log.json @@ -8,7 +8,8 @@ "prevten": "Private sector tenancy", "armed_forces": "Yes - a regular", "ecstat1": "Full-time - 30 hours or more", - "hhmemb": 7, + "other_hhmemb": 7, + "hhmemb": 8, "relat2": "Partner", "age2": 32, "sex2": "Male", diff --git a/spec/fixtures/forms/test_form.json b/spec/fixtures/forms/test_form.json index 95ac050da..988d2176e 100644 --- a/spec/fixtures/forms/test_form.json +++ b/spec/fixtures/forms/test_form.json @@ -45,7 +45,7 @@ }, "household_number_of_other_members": { "questions": { - "hhmemb": { + "other_hhmemb": { "check_answer_label": "Number of Other Household Members", "header": "How many other people are there in the household?", "hint_text": "The maximum number of others is 1", diff --git a/spec/helpers/check_answers_helper_spec.rb b/spec/helpers/check_answers_helper_spec.rb index 7ad04f081..ac3000f6b 100644 --- a/spec/helpers/check_answers_helper_spec.rb +++ b/spec/helpers/check_answers_helper_spec.rb @@ -6,7 +6,7 @@ RSpec.describe CheckAnswersHelper do FactoryBot.create( :case_log, :in_progress, - hhmemb: 1, + other_hhmemb: 1, relat2: "Partner", ) end diff --git a/spec/models/case_log_spec.rb b/spec/models/case_log_spec.rb index 438bf3c55..e663937db 100644 --- a/spec/models/case_log_spec.rb +++ b/spec/models/case_log_spec.rb @@ -109,7 +109,7 @@ RSpec.describe Form, type: :model do expect { CaseLog.create!(unittype_gn: "Shared bungalow", beds: 8, - hhmemb: 1) + other_hhmemb: 1) }.to raise_error(ActiveRecord::RecordInvalid) end @@ -117,7 +117,7 @@ RSpec.describe Form, type: :model do expect { CaseLog.create!(unittype_gn: "Shared bungalow", beds: 4, - hhmemb: 0) + other_hhmemb: 0) }.to raise_error(ActiveRecord::RecordInvalid) end From 3f885b4bc3101519784e0b0777a0c78207db8e54 Mon Sep 17 00:00:00 2001 From: magicmilo Date: Thu, 11 Nov 2021 15:57:19 +0000 Subject: [PATCH 24/29] fix duplicate keys in form json letting_type --- config/forms/2021_2022.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/config/forms/2021_2022.json b/config/forms/2021_2022.json index 5606f956e..f28753d14 100644 --- a/config/forms/2021_2022.json +++ b/config/forms/2021_2022.json @@ -112,7 +112,7 @@ } } }, - "letting_type": { + "rent_type": { "header": "About this log", "description": "", "questions": { From 8a6207fb0091f641da2c35cc1531b4b664cc14ba Mon Sep 17 00:00:00 2001 From: magicmilo Date: Thu, 11 Nov 2021 16:49:46 +0000 Subject: [PATCH 25/29] Revert "fix duplicate keys in form json letting_type" This reverts commit 3f885b4bc3101519784e0b0777a0c78207db8e54. --- config/forms/2021_2022.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/config/forms/2021_2022.json b/config/forms/2021_2022.json index 859e5fa14..5d06b8bd3 100644 --- a/config/forms/2021_2022.json +++ b/config/forms/2021_2022.json @@ -112,7 +112,7 @@ } } }, - "rent_type": { + "letting_type": { "header": "About this log", "description": "", "questions": { From a714efeaf6b7b3646213ecdd51a49dc82124870f Mon Sep 17 00:00:00 2001 From: magicmilo Date: Thu, 11 Nov 2021 16:52:40 +0000 Subject: [PATCH 26/29] aggh reverted wrong commit --- config/forms/2021_2022.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/config/forms/2021_2022.json b/config/forms/2021_2022.json index 5d06b8bd3..859e5fa14 100644 --- a/config/forms/2021_2022.json +++ b/config/forms/2021_2022.json @@ -112,7 +112,7 @@ } } }, - "letting_type": { + "rent_type": { "header": "About this log", "description": "", "questions": { From 6d2a0a11b697d6c49b420c8fd1a5b7eac0a4c6c1 Mon Sep 17 00:00:00 2001 From: magicmilo Date: Thu, 11 Nov 2021 19:44:57 +0000 Subject: [PATCH 27/29] Revert "Merge branch 'main' of https://github.com/communitiesuk/mhclg-data-collection-beta" This reverts commit d1ae40dc3bd4a03c6805e7c2462b1d6c706dfed6, reversing changes made to 3f885b4bc3101519784e0b0777a0c78207db8e54. --- app/admin/case_logs.rb | 2 +- app/models/case_log.rb | 8 +------- app/validations/household_validations.rb | 2 +- config/forms/2021_2022.json | 16 ++++++++++++++-- .../20211111143319_add_other_members_column.rb | 7 ------- db/schema.rb | 3 +-- docs/api/DLUHC-CORE-Data.v1.json | 6 +++--- spec/features/case_log_spec.rb | 4 ++-- spec/fixtures/complete_case_log.json | 3 +-- spec/fixtures/forms/test_form.json | 2 +- spec/helpers/check_answers_helper_spec.rb | 2 +- spec/models/case_log_spec.rb | 4 ++-- 12 files changed, 28 insertions(+), 31 deletions(-) delete mode 100644 db/migrate/20211111143319_add_other_members_column.rb diff --git a/app/admin/case_logs.rb b/app/admin/case_logs.rb index 2a15fbb2a..f32cff52b 100644 --- a/app/admin/case_logs.rb +++ b/app/admin/case_logs.rb @@ -2,7 +2,7 @@ ActiveAdmin.register CaseLog do # See permitted parameters documentation: # https://github.com/activeadmin/activeadmin/blob/master/docs/2-resource-customization.md#setting-up-strong-parameters permit_params do - permitted = %i[status tenant_code age1 sex1 tenant_ethnic_group tenant_nationality previous_housing_situation armed_forces ecstat1 other_hhmemb relat2 age2 sex2 ecstat2 relat3 age3 sex3 ecstat3 relat4 age4 sex4 ecstat4 relat5 age5 sex5 ecstat5 relat6 age6 sex6 ecstat6 relat7 age7 person_7_gender ecstat7 relat8 age8 sex8 ecstat8 homelessness reason benefit_cap_spare_room_subsidy armed_forces_active armed_forces_injured armed_forces_partner medical_conditions pregnancy accessibility_requirements condition_effects tenancy_code tenancy_start_date starter_tenancy fixed_term_tenancy tenancy_type letting_type letting_provider la previous_postcode property_relet property_vacancy_reason property_reference property_unit_type property_building_type property_number_of_bedrooms property_void_date majorrepairs mrcdate property_number_of_times_relet property_wheelchair_accessible net_income net_income_frequency net_income_uc_proportion hb rent_frequency basic_rent service_charge personal_service_charge support_charge total_charge tshortfall time_lived_in_la time_on_la_waiting_list prevloc property_postcode reasonable_preference reasonable_preference_reason cbl_letting chr_letting cap_letting hbrentshortfall other_reason accessibility_requirements_fully_wheelchair_accessible_housing accessibility_requirements_wheelchair_access_to_essential_rooms accessibility_requirements_level_access_housing accessibility_requirements_other_disability_requirements accessibility_requirements_no_disability_requirements accessibility_requirements_do_not_know accessibility_requirements_prefer_not_to_say condition_effects_vision condition_effects_hearing condition_effects_mobility condition_effects_dexterity condition_effects_stamina condition_effects_learning condition_effects_memory condition_effects_mental_health condition_effects_social_or_behavioral condition_effects_other condition_effects_prefer_not_to_say reasonable_preference_reason_homeless reasonable_preference_reason_unsatisfactory_housing reasonable_preference_reason_medical_grounds reasonable_preference_reason_avoid_hardship reasonable_preference_reason_do_not_know other_tenancy_type override_net_income_validation net_income_known] + permitted = %i[status tenant_code age1 sex1 tenant_ethnic_group tenant_nationality previous_housing_situation armed_forces ecstat1 hhmemb relat2 age2 sex2 ecstat2 relat3 age3 sex3 ecstat3 relat4 age4 sex4 ecstat4 relat5 age5 sex5 ecstat5 relat6 age6 sex6 ecstat6 relat7 age7 person_7_gender ecstat7 relat8 age8 sex8 ecstat8 homelessness reason benefit_cap_spare_room_subsidy armed_forces_active armed_forces_injured armed_forces_partner medical_conditions pregnancy accessibility_requirements condition_effects tenancy_code tenancy_start_date starter_tenancy fixed_term_tenancy tenancy_type letting_type letting_provider la previous_postcode property_relet property_vacancy_reason property_reference property_unit_type property_building_type property_number_of_bedrooms property_void_date majorrepairs mrcdate property_number_of_times_relet property_wheelchair_accessible net_income net_income_frequency net_income_uc_proportion hb rent_frequency basic_rent service_charge personal_service_charge support_charge total_charge tshortfall time_lived_in_la time_on_la_waiting_list prevloc property_postcode reasonable_preference reasonable_preference_reason cbl_letting chr_letting cap_letting hbrentshortfall other_reason accessibility_requirements_fully_wheelchair_accessible_housing accessibility_requirements_wheelchair_access_to_essential_rooms accessibility_requirements_level_access_housing accessibility_requirements_other_disability_requirements accessibility_requirements_no_disability_requirements accessibility_requirements_do_not_know accessibility_requirements_prefer_not_to_say condition_effects_vision condition_effects_hearing condition_effects_mobility condition_effects_dexterity condition_effects_stamina condition_effects_learning condition_effects_memory condition_effects_mental_health condition_effects_social_or_behavioral condition_effects_other condition_effects_prefer_not_to_say reasonable_preference_reason_homeless reasonable_preference_reason_unsatisfactory_housing reasonable_preference_reason_medical_grounds reasonable_preference_reason_avoid_hardship reasonable_preference_reason_do_not_know other_tenancy_type override_net_income_validation net_income_known] permitted end diff --git a/app/models/case_log.rb b/app/models/case_log.rb index f21b3338d..4d59ea91a 100644 --- a/app/models/case_log.rb +++ b/app/models/case_log.rb @@ -163,12 +163,6 @@ class CaseLog < ApplicationRecord end end - def hhmemb - if other_hhmemb.present? - other_hhmemb - end - end - def applicable_income_range return unless ecstat1 @@ -245,7 +239,7 @@ private dynamically_not_required << "incfreq" end - start_range = (other_hhmemb || 0) + 2 + start_range = (hhmemb || 0) + 2 (start_range..8).each do |n| dynamically_not_required << "age#{n}" dynamically_not_required << "sex#{n}" diff --git a/app/validations/household_validations.rb b/app/validations/household_validations.rb index d3536ae8a..b36972667 100644 --- a/app/validations/household_validations.rb +++ b/app/validations/household_validations.rb @@ -80,7 +80,7 @@ module HouseholdValidations record.errors.add :unittype_gn, "A bedsit can only have one bedroom" end - if !record.other_hhmemb.nil? && record.other_hhmemb.positive? && (record.unittype_gn.include?("Shared") && !record.beds.to_i.between?(1, 7)) + if !record.hhmemb.nil? && record.hhmemb.positive? && (record.unittype_gn.include?("Shared") && !record.beds.to_i.between?(1, 7)) record.errors.add :unittype_gn, "A shared house must have 1 to 7 bedrooms" end diff --git a/config/forms/2021_2022.json b/config/forms/2021_2022.json index 859e5fa14..f28753d14 100644 --- a/config/forms/2021_2022.json +++ b/config/forms/2021_2022.json @@ -104,7 +104,7 @@ "header": "About this log", "description": "", "questions": { - "startdate": { + "tenancy_start_date": { "check_answer_label": "When is the tenancy start date?", "header": "What is the tenancy start date?", "hint_text": "For example, 27 3 2007", @@ -332,7 +332,7 @@ "header": "", "description": "", "questions": { - "other_hhmemb": { + "hhmemb": { "check_answer_label": "Number of Other Household Members", "header": "How many other people are there in the household?", "hint_text": "The maximum number of others is 7", @@ -1027,6 +1027,18 @@ } } }, + "tenancy_start_date": { + "header": "", + "description": "", + "questions": { + "startdate": { + "check_answer_label": "When is the tenancy start date?", + "header": "What is the tenancy start date?", + "hint_text": "For example, 27 3 2007", + "type": "date" + } + } + }, "starter_tenancy": { "header": "", "description": "", diff --git a/db/migrate/20211111143319_add_other_members_column.rb b/db/migrate/20211111143319_add_other_members_column.rb deleted file mode 100644 index 2c6ca2658..000000000 --- a/db/migrate/20211111143319_add_other_members_column.rb +++ /dev/null @@ -1,7 +0,0 @@ -class AddOtherMembersColumn < ActiveRecord::Migration[6.1] - def change - change_table :case_logs, bulk: true do |t| - t.column :other_hhmemb, :integer - end - end -end diff --git a/db/schema.rb b/db/schema.rb index 5b1c02e62..ba9b956dd 100644 --- a/db/schema.rb +++ b/db/schema.rb @@ -10,7 +10,7 @@ # # It's strongly recommended that you check this file into your version control system. -ActiveRecord::Schema.define(version: 2021_11_11_143319) do +ActiveRecord::Schema.define(version: 2021_11_10_140928) do # These are extensions that must be enabled in order to support this database enable_extension "plpgsql" @@ -152,7 +152,6 @@ ActiveRecord::Schema.define(version: 2021_11_11_143319) do t.integer "mrcday" t.integer "mrcmonth" t.integer "mrcyear" - t.integer "other_hhmemb" t.index ["discarded_at"], name: "index_case_logs_on_discarded_at" end diff --git a/docs/api/DLUHC-CORE-Data.v1.json b/docs/api/DLUHC-CORE-Data.v1.json index 17560d14c..e13ad4f17 100644 --- a/docs/api/DLUHC-CORE-Data.v1.json +++ b/docs/api/DLUHC-CORE-Data.v1.json @@ -263,7 +263,7 @@ "prevten": "Private sector tenancy", "armed_forces": "Yes - a regular", "ecstat1": "Full-time - 30 hours or more", - "other_hhmemb": 7, + "hhmemb": 7, "relat2": "Partner", "age2": 32, "sex2": "Male", @@ -459,7 +459,7 @@ "Prefer not to say" ] }, - "other_hhmemb": { + "hhmemb": { "type": "number", "minimum": 0, "maximum": 7 @@ -1052,7 +1052,7 @@ "prevten", "armed_forces", "ecstat1", - "other_hhmemb", + "hhmemb", "relat2", "age2", "sex2", diff --git a/spec/features/case_log_spec.rb b/spec/features/case_log_spec.rb index b48572d62..aa53b8c7d 100644 --- a/spec/features/case_log_spec.rb +++ b/spec/features/case_log_spec.rb @@ -9,7 +9,7 @@ RSpec.describe "Test Features" do tenant_code: { type: "text", answer: "BZ737", path: "tenant_code" }, age1: { type: "numeric", answer: 25, path: "person_1_age" }, sex1: { type: "radio", answer: "Female", path: "person_1_gender" }, - other_hhmemb: { type: "numeric", answer: 2, path: "household_number_of_other_members" }, + hhmemb: { type: "numeric", answer: 2, path: "household_number_of_other_members" }, } def fill_in_number_question(case_log_id, question, value, path) @@ -265,7 +265,7 @@ RSpec.describe "Test Features" do let(:last_question_for_subsection) { "household_number_of_other_members" } it "redirects to the check answers page when answering the last question and clicking save and continue" do - fill_in_number_question(id, "other_hhmemb", 0, last_question_for_subsection) + fill_in_number_question(id, "hhmemb", 0, last_question_for_subsection) expect(page).to have_current_path("/case_logs/#{id}/#{subsection}/check_answers") end diff --git a/spec/fixtures/complete_case_log.json b/spec/fixtures/complete_case_log.json index 4656a04f8..97afaeaa0 100644 --- a/spec/fixtures/complete_case_log.json +++ b/spec/fixtures/complete_case_log.json @@ -8,8 +8,7 @@ "prevten": "Private sector tenancy", "armed_forces": "Yes - a regular", "ecstat1": "Full-time - 30 hours or more", - "other_hhmemb": 7, - "hhmemb": 8, + "hhmemb": 7, "relat2": "Partner", "age2": 32, "sex2": "Male", diff --git a/spec/fixtures/forms/test_form.json b/spec/fixtures/forms/test_form.json index 988d2176e..95ac050da 100644 --- a/spec/fixtures/forms/test_form.json +++ b/spec/fixtures/forms/test_form.json @@ -45,7 +45,7 @@ }, "household_number_of_other_members": { "questions": { - "other_hhmemb": { + "hhmemb": { "check_answer_label": "Number of Other Household Members", "header": "How many other people are there in the household?", "hint_text": "The maximum number of others is 1", diff --git a/spec/helpers/check_answers_helper_spec.rb b/spec/helpers/check_answers_helper_spec.rb index ac3000f6b..7ad04f081 100644 --- a/spec/helpers/check_answers_helper_spec.rb +++ b/spec/helpers/check_answers_helper_spec.rb @@ -6,7 +6,7 @@ RSpec.describe CheckAnswersHelper do FactoryBot.create( :case_log, :in_progress, - other_hhmemb: 1, + hhmemb: 1, relat2: "Partner", ) end diff --git a/spec/models/case_log_spec.rb b/spec/models/case_log_spec.rb index e663937db..438bf3c55 100644 --- a/spec/models/case_log_spec.rb +++ b/spec/models/case_log_spec.rb @@ -109,7 +109,7 @@ RSpec.describe Form, type: :model do expect { CaseLog.create!(unittype_gn: "Shared bungalow", beds: 8, - other_hhmemb: 1) + hhmemb: 1) }.to raise_error(ActiveRecord::RecordInvalid) end @@ -117,7 +117,7 @@ RSpec.describe Form, type: :model do expect { CaseLog.create!(unittype_gn: "Shared bungalow", beds: 4, - other_hhmemb: 0) + hhmemb: 0) }.to raise_error(ActiveRecord::RecordInvalid) end From ea992e8cf36d6617a550552c708c594e8bcb070f Mon Sep 17 00:00:00 2001 From: magicmilo Date: Fri, 12 Nov 2021 10:26:58 +0000 Subject: [PATCH 28/29] Revert "Revert "Merge branch 'main' of https://github.com/communitiesuk/mhclg-data-collection-beta"" This reverts commit 6d2a0a11b697d6c49b420c8fd1a5b7eac0a4c6c1. --- app/admin/case_logs.rb | 2 +- app/models/case_log.rb | 8 +++++++- app/validations/household_validations.rb | 2 +- config/forms/2021_2022.json | 16 ++-------------- .../20211111143319_add_other_members_column.rb | 7 +++++++ db/schema.rb | 3 ++- docs/api/DLUHC-CORE-Data.v1.json | 6 +++--- spec/features/case_log_spec.rb | 4 ++-- spec/fixtures/complete_case_log.json | 3 ++- spec/fixtures/forms/test_form.json | 2 +- spec/helpers/check_answers_helper_spec.rb | 2 +- spec/models/case_log_spec.rb | 4 ++-- 12 files changed, 31 insertions(+), 28 deletions(-) create mode 100644 db/migrate/20211111143319_add_other_members_column.rb diff --git a/app/admin/case_logs.rb b/app/admin/case_logs.rb index f32cff52b..2a15fbb2a 100644 --- a/app/admin/case_logs.rb +++ b/app/admin/case_logs.rb @@ -2,7 +2,7 @@ ActiveAdmin.register CaseLog do # See permitted parameters documentation: # https://github.com/activeadmin/activeadmin/blob/master/docs/2-resource-customization.md#setting-up-strong-parameters permit_params do - permitted = %i[status tenant_code age1 sex1 tenant_ethnic_group tenant_nationality previous_housing_situation armed_forces ecstat1 hhmemb relat2 age2 sex2 ecstat2 relat3 age3 sex3 ecstat3 relat4 age4 sex4 ecstat4 relat5 age5 sex5 ecstat5 relat6 age6 sex6 ecstat6 relat7 age7 person_7_gender ecstat7 relat8 age8 sex8 ecstat8 homelessness reason benefit_cap_spare_room_subsidy armed_forces_active armed_forces_injured armed_forces_partner medical_conditions pregnancy accessibility_requirements condition_effects tenancy_code tenancy_start_date starter_tenancy fixed_term_tenancy tenancy_type letting_type letting_provider la previous_postcode property_relet property_vacancy_reason property_reference property_unit_type property_building_type property_number_of_bedrooms property_void_date majorrepairs mrcdate property_number_of_times_relet property_wheelchair_accessible net_income net_income_frequency net_income_uc_proportion hb rent_frequency basic_rent service_charge personal_service_charge support_charge total_charge tshortfall time_lived_in_la time_on_la_waiting_list prevloc property_postcode reasonable_preference reasonable_preference_reason cbl_letting chr_letting cap_letting hbrentshortfall other_reason accessibility_requirements_fully_wheelchair_accessible_housing accessibility_requirements_wheelchair_access_to_essential_rooms accessibility_requirements_level_access_housing accessibility_requirements_other_disability_requirements accessibility_requirements_no_disability_requirements accessibility_requirements_do_not_know accessibility_requirements_prefer_not_to_say condition_effects_vision condition_effects_hearing condition_effects_mobility condition_effects_dexterity condition_effects_stamina condition_effects_learning condition_effects_memory condition_effects_mental_health condition_effects_social_or_behavioral condition_effects_other condition_effects_prefer_not_to_say reasonable_preference_reason_homeless reasonable_preference_reason_unsatisfactory_housing reasonable_preference_reason_medical_grounds reasonable_preference_reason_avoid_hardship reasonable_preference_reason_do_not_know other_tenancy_type override_net_income_validation net_income_known] + permitted = %i[status tenant_code age1 sex1 tenant_ethnic_group tenant_nationality previous_housing_situation armed_forces ecstat1 other_hhmemb relat2 age2 sex2 ecstat2 relat3 age3 sex3 ecstat3 relat4 age4 sex4 ecstat4 relat5 age5 sex5 ecstat5 relat6 age6 sex6 ecstat6 relat7 age7 person_7_gender ecstat7 relat8 age8 sex8 ecstat8 homelessness reason benefit_cap_spare_room_subsidy armed_forces_active armed_forces_injured armed_forces_partner medical_conditions pregnancy accessibility_requirements condition_effects tenancy_code tenancy_start_date starter_tenancy fixed_term_tenancy tenancy_type letting_type letting_provider la previous_postcode property_relet property_vacancy_reason property_reference property_unit_type property_building_type property_number_of_bedrooms property_void_date majorrepairs mrcdate property_number_of_times_relet property_wheelchair_accessible net_income net_income_frequency net_income_uc_proportion hb rent_frequency basic_rent service_charge personal_service_charge support_charge total_charge tshortfall time_lived_in_la time_on_la_waiting_list prevloc property_postcode reasonable_preference reasonable_preference_reason cbl_letting chr_letting cap_letting hbrentshortfall other_reason accessibility_requirements_fully_wheelchair_accessible_housing accessibility_requirements_wheelchair_access_to_essential_rooms accessibility_requirements_level_access_housing accessibility_requirements_other_disability_requirements accessibility_requirements_no_disability_requirements accessibility_requirements_do_not_know accessibility_requirements_prefer_not_to_say condition_effects_vision condition_effects_hearing condition_effects_mobility condition_effects_dexterity condition_effects_stamina condition_effects_learning condition_effects_memory condition_effects_mental_health condition_effects_social_or_behavioral condition_effects_other condition_effects_prefer_not_to_say reasonable_preference_reason_homeless reasonable_preference_reason_unsatisfactory_housing reasonable_preference_reason_medical_grounds reasonable_preference_reason_avoid_hardship reasonable_preference_reason_do_not_know other_tenancy_type override_net_income_validation net_income_known] permitted end diff --git a/app/models/case_log.rb b/app/models/case_log.rb index 4d59ea91a..f21b3338d 100644 --- a/app/models/case_log.rb +++ b/app/models/case_log.rb @@ -163,6 +163,12 @@ class CaseLog < ApplicationRecord end end + def hhmemb + if other_hhmemb.present? + other_hhmemb + end + end + def applicable_income_range return unless ecstat1 @@ -239,7 +245,7 @@ private dynamically_not_required << "incfreq" end - start_range = (hhmemb || 0) + 2 + start_range = (other_hhmemb || 0) + 2 (start_range..8).each do |n| dynamically_not_required << "age#{n}" dynamically_not_required << "sex#{n}" diff --git a/app/validations/household_validations.rb b/app/validations/household_validations.rb index b36972667..d3536ae8a 100644 --- a/app/validations/household_validations.rb +++ b/app/validations/household_validations.rb @@ -80,7 +80,7 @@ module HouseholdValidations record.errors.add :unittype_gn, "A bedsit can only have one bedroom" end - if !record.hhmemb.nil? && record.hhmemb.positive? && (record.unittype_gn.include?("Shared") && !record.beds.to_i.between?(1, 7)) + if !record.other_hhmemb.nil? && record.other_hhmemb.positive? && (record.unittype_gn.include?("Shared") && !record.beds.to_i.between?(1, 7)) record.errors.add :unittype_gn, "A shared house must have 1 to 7 bedrooms" end diff --git a/config/forms/2021_2022.json b/config/forms/2021_2022.json index f28753d14..859e5fa14 100644 --- a/config/forms/2021_2022.json +++ b/config/forms/2021_2022.json @@ -104,7 +104,7 @@ "header": "About this log", "description": "", "questions": { - "tenancy_start_date": { + "startdate": { "check_answer_label": "When is the tenancy start date?", "header": "What is the tenancy start date?", "hint_text": "For example, 27 3 2007", @@ -332,7 +332,7 @@ "header": "", "description": "", "questions": { - "hhmemb": { + "other_hhmemb": { "check_answer_label": "Number of Other Household Members", "header": "How many other people are there in the household?", "hint_text": "The maximum number of others is 7", @@ -1027,18 +1027,6 @@ } } }, - "tenancy_start_date": { - "header": "", - "description": "", - "questions": { - "startdate": { - "check_answer_label": "When is the tenancy start date?", - "header": "What is the tenancy start date?", - "hint_text": "For example, 27 3 2007", - "type": "date" - } - } - }, "starter_tenancy": { "header": "", "description": "", diff --git a/db/migrate/20211111143319_add_other_members_column.rb b/db/migrate/20211111143319_add_other_members_column.rb new file mode 100644 index 000000000..2c6ca2658 --- /dev/null +++ b/db/migrate/20211111143319_add_other_members_column.rb @@ -0,0 +1,7 @@ +class AddOtherMembersColumn < ActiveRecord::Migration[6.1] + def change + change_table :case_logs, bulk: true do |t| + t.column :other_hhmemb, :integer + end + end +end diff --git a/db/schema.rb b/db/schema.rb index ba9b956dd..5b1c02e62 100644 --- a/db/schema.rb +++ b/db/schema.rb @@ -10,7 +10,7 @@ # # It's strongly recommended that you check this file into your version control system. -ActiveRecord::Schema.define(version: 2021_11_10_140928) do +ActiveRecord::Schema.define(version: 2021_11_11_143319) do # These are extensions that must be enabled in order to support this database enable_extension "plpgsql" @@ -152,6 +152,7 @@ ActiveRecord::Schema.define(version: 2021_11_10_140928) do t.integer "mrcday" t.integer "mrcmonth" t.integer "mrcyear" + t.integer "other_hhmemb" t.index ["discarded_at"], name: "index_case_logs_on_discarded_at" end diff --git a/docs/api/DLUHC-CORE-Data.v1.json b/docs/api/DLUHC-CORE-Data.v1.json index e13ad4f17..17560d14c 100644 --- a/docs/api/DLUHC-CORE-Data.v1.json +++ b/docs/api/DLUHC-CORE-Data.v1.json @@ -263,7 +263,7 @@ "prevten": "Private sector tenancy", "armed_forces": "Yes - a regular", "ecstat1": "Full-time - 30 hours or more", - "hhmemb": 7, + "other_hhmemb": 7, "relat2": "Partner", "age2": 32, "sex2": "Male", @@ -459,7 +459,7 @@ "Prefer not to say" ] }, - "hhmemb": { + "other_hhmemb": { "type": "number", "minimum": 0, "maximum": 7 @@ -1052,7 +1052,7 @@ "prevten", "armed_forces", "ecstat1", - "hhmemb", + "other_hhmemb", "relat2", "age2", "sex2", diff --git a/spec/features/case_log_spec.rb b/spec/features/case_log_spec.rb index aa53b8c7d..b48572d62 100644 --- a/spec/features/case_log_spec.rb +++ b/spec/features/case_log_spec.rb @@ -9,7 +9,7 @@ RSpec.describe "Test Features" do tenant_code: { type: "text", answer: "BZ737", path: "tenant_code" }, age1: { type: "numeric", answer: 25, path: "person_1_age" }, sex1: { type: "radio", answer: "Female", path: "person_1_gender" }, - hhmemb: { type: "numeric", answer: 2, path: "household_number_of_other_members" }, + other_hhmemb: { type: "numeric", answer: 2, path: "household_number_of_other_members" }, } def fill_in_number_question(case_log_id, question, value, path) @@ -265,7 +265,7 @@ RSpec.describe "Test Features" do let(:last_question_for_subsection) { "household_number_of_other_members" } it "redirects to the check answers page when answering the last question and clicking save and continue" do - fill_in_number_question(id, "hhmemb", 0, last_question_for_subsection) + fill_in_number_question(id, "other_hhmemb", 0, last_question_for_subsection) expect(page).to have_current_path("/case_logs/#{id}/#{subsection}/check_answers") end diff --git a/spec/fixtures/complete_case_log.json b/spec/fixtures/complete_case_log.json index 97afaeaa0..4656a04f8 100644 --- a/spec/fixtures/complete_case_log.json +++ b/spec/fixtures/complete_case_log.json @@ -8,7 +8,8 @@ "prevten": "Private sector tenancy", "armed_forces": "Yes - a regular", "ecstat1": "Full-time - 30 hours or more", - "hhmemb": 7, + "other_hhmemb": 7, + "hhmemb": 8, "relat2": "Partner", "age2": 32, "sex2": "Male", diff --git a/spec/fixtures/forms/test_form.json b/spec/fixtures/forms/test_form.json index 95ac050da..988d2176e 100644 --- a/spec/fixtures/forms/test_form.json +++ b/spec/fixtures/forms/test_form.json @@ -45,7 +45,7 @@ }, "household_number_of_other_members": { "questions": { - "hhmemb": { + "other_hhmemb": { "check_answer_label": "Number of Other Household Members", "header": "How many other people are there in the household?", "hint_text": "The maximum number of others is 1", diff --git a/spec/helpers/check_answers_helper_spec.rb b/spec/helpers/check_answers_helper_spec.rb index 7ad04f081..ac3000f6b 100644 --- a/spec/helpers/check_answers_helper_spec.rb +++ b/spec/helpers/check_answers_helper_spec.rb @@ -6,7 +6,7 @@ RSpec.describe CheckAnswersHelper do FactoryBot.create( :case_log, :in_progress, - hhmemb: 1, + other_hhmemb: 1, relat2: "Partner", ) end diff --git a/spec/models/case_log_spec.rb b/spec/models/case_log_spec.rb index 438bf3c55..e663937db 100644 --- a/spec/models/case_log_spec.rb +++ b/spec/models/case_log_spec.rb @@ -109,7 +109,7 @@ RSpec.describe Form, type: :model do expect { CaseLog.create!(unittype_gn: "Shared bungalow", beds: 8, - hhmemb: 1) + other_hhmemb: 1) }.to raise_error(ActiveRecord::RecordInvalid) end @@ -117,7 +117,7 @@ RSpec.describe Form, type: :model do expect { CaseLog.create!(unittype_gn: "Shared bungalow", beds: 4, - hhmemb: 0) + other_hhmemb: 0) }.to raise_error(ActiveRecord::RecordInvalid) end From 7942dec5c4ada3a295a58045eb929475097c1bed Mon Sep 17 00:00:00 2001 From: kosiakkatrina <54268893+kosiakkatrina@users.noreply.github.com> Date: Fri, 12 Nov 2021 10:59:14 +0000 Subject: [PATCH 29/29] Add incref column (#87) * Add incref column * Rubocop * update migration version --- app/models/case_log.rb | 14 ++++++++++---- db/migrate/20211112105348_add_incref_field.rb | 8 ++++++++ db/schema.rb | 3 ++- spec/controllers/case_logs_controller_spec.rb | 8 ++++---- 4 files changed, 24 insertions(+), 9 deletions(-) create mode 100644 db/migrate/20211112105348_add_incref_field.rb diff --git a/app/models/case_log.rb b/app/models/case_log.rb index f21b3338d..1842dc55a 100644 --- a/app/models/case_log.rb +++ b/app/models/case_log.rb @@ -164,9 +164,7 @@ class CaseLog < ApplicationRecord end def hhmemb - if other_hhmemb.present? - other_hhmemb - end + other_hhmemb.presence end def applicable_income_range @@ -193,7 +191,11 @@ class CaseLog < ApplicationRecord end end - + def incref + if net_income_known == "Prefer not to say" + 1 + end + end private @@ -253,6 +255,10 @@ private dynamically_not_required << "ecstat#{n}" end + if net_income_known != "Prefer not to say" + dynamically_not_required << "incref" + end + required.delete_if { |key, _value| dynamically_not_required.include?(key) } end end diff --git a/db/migrate/20211112105348_add_incref_field.rb b/db/migrate/20211112105348_add_incref_field.rb new file mode 100644 index 000000000..65df53aca --- /dev/null +++ b/db/migrate/20211112105348_add_incref_field.rb @@ -0,0 +1,8 @@ +class AddIncrefField < ActiveRecord::Migration[6.1] + def change + change_table :case_logs, bulk: true do |t| + t.column :incref, :integer + end + end +end + diff --git a/db/schema.rb b/db/schema.rb index 5b1c02e62..614c895c2 100644 --- a/db/schema.rb +++ b/db/schema.rb @@ -10,7 +10,7 @@ # # It's strongly recommended that you check this file into your version control system. -ActiveRecord::Schema.define(version: 2021_11_11_143319) do +ActiveRecord::Schema.define(version: 2021_11_12_105348) do # These are extensions that must be enabled in order to support this database enable_extension "plpgsql" @@ -153,6 +153,7 @@ ActiveRecord::Schema.define(version: 2021_11_11_143319) do t.integer "mrcmonth" t.integer "mrcyear" t.integer "other_hhmemb" + t.integer "incref" t.index ["discarded_at"], name: "index_case_logs_on_discarded_at" end diff --git a/spec/controllers/case_logs_controller_spec.rb b/spec/controllers/case_logs_controller_spec.rb index 007b76f8c..8192173fc 100644 --- a/spec/controllers/case_logs_controller_spec.rb +++ b/spec/controllers/case_logs_controller_spec.rb @@ -181,10 +181,10 @@ RSpec.describe CaseLogsController, type: :controller do context "partition date" do let(:case_log_with_date) do { - :"mrcdate(1i)" => "2021", - :"mrcdate(2i)" => "05", - :"mrcdate(3i)" => "04", - :page => "major_repairs_date", + "mrcdate(1i)": "2021", + "mrcdate(2i)": "05", + "mrcdate(3i)": "04", + page: "major_repairs_date", } end it "saves full and partial dates" do