require "rails_helper" RSpec.describe Form::Sales::Questions::UprnKnown, type: :model do include FormattingHelper subject(:question) { described_class.new(question_id, question_definition, page) } let(:question_id) { nil } let(:question_definition) { nil } let(:page) { instance_double(Form::Page, subsection: instance_double(Form::Subsection, form: instance_double(Form, start_date: Time.zone.local(2023, 4, 1)))) } it "has correct page" do expect(question.page).to eq(page) end it "has the correct id" do expect(question.id).to eq("uprn_known") end it "has the correct type" do expect(question.type).to eq("radio") end it "is not marked as derived" do expect(question.derived?(nil)).to be false end it "has the correct answer_options" do expect(question.answer_options).to eq({ "0" => { "value" => "No" }, "1" => { "value" => "Yes" }, }) end it "has correct conditional for" do expect(question.conditional_for).to eq({ "uprn" => [1] }) end it "has the correct unanswered_error_message" do expect(question.unanswered_error_message).to eq("You must answer #{format_ending(I18n.t('forms.2023.sales.property_information.uprn.uprn_known.check_answer_label'))}") end it "has the correct hidden_in_check_answers" do expect(question.hidden_in_check_answers).to eq({ "depends_on" => [ { "uprn_known" => 0 }, { "uprn_known" => 1 }, ], }) end it "has the correct inferred_check_answers_value" do expect(question.inferred_check_answers_value).to eq([ { "condition" => { "uprn_known" => 0 }, "value" => "Not known", }, ]) end end