Skip to content

Commit

Permalink
Add person specs
Browse files Browse the repository at this point in the history
  • Loading branch information
hunchr committed Aug 20, 2024
1 parent 9ccc668 commit 67b0d17
Showing 1 changed file with 87 additions and 11 deletions.
98 changes: 87 additions & 11 deletions spec/models/person_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -252,24 +252,100 @@ def create_role(**attrs)
end

describe "#data_quality" do
it "is ok by default" do
person = people(:mitglied)
expect(person.data_quality).to eq("ok")
expect(person.data_quality_issues).to eq([])
let(:person) { people(:mitglied).tap { |p| p.roles.destroy_all } }

context "on create" do
it "is ok by default" do
expect(person.data_quality).to eq("ok")
expect(person.data_quality_issues).to eq([])
end

it "is set with value and stored as int" do
person = Fabricate.build(:person, data_quality: "error")
expect(person.data_quality).to eq("error")
expect(person[:data_quality]).to eq(3)
end
end

it "is set with value and stored as int" do
person = Fabricate.build(:person, data_quality: "error")
expect(person.data_quality).to eq("error")
expect(person[:data_quality]).to eq(3)
context "on update" do
it "removes the data_quality_issue if the attribute is valid again" do
expect do
person.update!(first_name: nil)
end.to change(person.data_quality_issues, :count).by(1)
expect do
person.update!(first_name: "Puzzle")
end.to change(person.data_quality_issues, :count).by(-1)
end

it "doesnt validate attributes if another attribute that shouldnt be checked is updated" do
expect do
person.update!(first_name: nil)
person.data_quality_issues.destroy_all
person.update!(sac_remark_section_1: "ignored")
end.not_to change(person.data_quality_issues, :count)
end

describe "person" do
it "validates the first name" do
expect do
person.update!(company_name: nil, first_name: nil)
end.to change(person.data_quality_issues, :count).by(1)
expect(person.data_quality_issues.first.message).to eq("Vorname ist leer")
end

it "validates the last name" do
expect do
person.update!(company_name: nil, last_name: nil)
end.to change(person.data_quality_issues, :count).by(1)
expect(person.data_quality_issues.first.message).to eq("Nachname ist leer")
end
end

describe "member" do
before do
person.phone_numbers.create!(number: "+41791234567", label: "mobile")
person.roles.create!(
type: Group::SektionsMitglieder::Mitglied.sti_name,
group: groups(:bluemlisalp_mitglieder),
delete_on: Time.zone.tomorrow,
created_at: Time.zone.now
)
end

it "validates the birthday" do
expect do
person.update!(birthday: nil)
end.to change(person.data_quality_issues, :count).by(1)
expect(person.data_quality_issues.first.message).to eq("Geburtstag ist leer")

person.update!(birthday: Time.zone.today)
expect(person.data_quality_issues.first.message)
.to eq("Geburtstag liegt weniger als 6 Jahre vor dem SAC-Eintritt")
end

it "validates the street, zip_code, and town" do
expect do
person.update!(street: nil, zip_code: nil, town: nil)
end.to change(person.data_quality_issues, :count).by(3)
expect(person.data_quality_issues.map(&:message))
.to include("Strasse ist leer", "PLZ ist leer", "Ort ist leer")
end

it "validates the email and phone_numbers" do
expect do
person.phone_numbers.destroy_all
person.update!(email: nil)
end.to change(person.data_quality_issues, :count).by(2)
expect(person.data_quality_issues.map(&:message))
.to include("Haupt-E-Mail ist leer", "Telefonnummern sind leer")
end
end
end

context "on destroy" do
let(:person) { people(:mitglied) }

it "is destroys the data quality issues too" do
expect do
person.data_quality_issues.create!(attr: "first_name", key: "-", severity: "error")
person.data_quality_issues.create!(attr: "first_name", key: "ist leer", severity: "error")
end.to change(Person::DataQualityIssue, :count).by(1)
expect do
person.destroy!
Expand Down

0 comments on commit 67b0d17

Please sign in to comment.