From a4a388a954bc13008a471cf35bc36b9b931ec233 Mon Sep 17 00:00:00 2001 From: Felicia Yi Date: Sat, 28 Sep 2024 11:10:03 -0400 Subject: [PATCH 1/2] refactor create_org --- db/seeds.rb | 33 ++++++- db/seeds/db_populator.rb | 191 ++++++++++++++++++--------------------- 2 files changed, 118 insertions(+), 106 deletions(-) diff --git a/db/seeds.rb b/db/seeds.rb index 7654a41cc7..4862a44214 100644 --- a/db/seeds.rb +++ b/db/seeds.rb @@ -31,12 +31,21 @@ def seed db_populator.create_all_casa_admin("allcasaadmin@example.com") db_populator.create_all_casa_admin("all_casa_admin1@example.com") db_populator.create_all_casa_admin("admin1@example.com") - db_populator.create_org(CasaOrgPopulatorPresets.for_environment.merge({org_name: "Prince George CASA"})) - db_populator.create_org(CasaOrgPopulatorPresets.minimal_dataset_options) + + options1 = OpenStruct.new(CasaOrgPopulatorPresets.for_environment.merge({org_name: "Prince George CASA"})) + org1 = db_populator.create_org(options1) + create_org_related_data(db_populator, org1, options1) + + options2 = OpenStruct.new(CasaOrgPopulatorPresets.minimal_dataset_options) + org2 = db_populator.create_org(options2) + create_org_related_data(db_populator, org2, options2) + SmsNotificationEventPopulator.populate 2.times do - DbPopulator.new(rng, case_fourteen_years_old: true) - .create_org(CasaOrgPopulatorPresets.minimal_dataset_options) + options3 = OpenStruct.new(CasaOrgPopulatorPresets.minimal_dataset_options) + org3 = DbPopulator.new(rng, case_fourteen_years_old: true) + .create_org(options3) + create_org_related_data(db_populator, org3, options3) end post_process_data @@ -44,6 +53,8 @@ def seed log "\nDone.\n\n" end + + private # ------------------------------------------------------------------------------------------------------- # Used for reporting record counts after completion: @@ -113,6 +124,20 @@ def log(message) puts message end + + def create_org_related_data(db_populator, casa_org, options) + db_populator.create_users(casa_org, options) + db_populator.create_cases(casa_org, options) + db_populator.create_hearing_types(casa_org) + db_populator.create_checklist_items + db_populator.create_judges(casa_org) + db_populator.create_languages(casa_org) + db_populator.create_mileage_rates(casa_org) + db_populator.create_learning_hour_types(casa_org) + db_populator.create_learning_hour_topics(casa_org) + db_populator.create_learning_hours(casa_org) + db_populator.create_other_duties + end end SeederMain.new.seed diff --git a/db/seeds/db_populator.rb b/db/seeds/db_populator.rb index a6d6983865..3d9c872edd 100644 --- a/db/seeds/db_populator.rb +++ b/db/seeds/db_populator.rb @@ -26,8 +26,7 @@ def create_all_casa_admin(email) AllCasaAdmin.create!(email: email, password: SEED_PASSWORD, password_confirmation: SEED_PASSWORD) end - def create_org(options_hash) - options = OpenStruct.new(options_hash) + def create_org(options) @casa_org_counter += 1 options.org_name ||= "CASA Organization ##{@casa_org_counter}" @@ -42,23 +41,9 @@ def create_org(options_hash) ] org.logo.attach(io: File.open(CasaOrg::CASA_DEFAULT_LOGO), filename: CasaOrg::CASA_DEFAULT_LOGO.basename.to_s) } - - create_users(casa_org, options) - create_cases(casa_org, options) - create_hearing_types(casa_org) - create_checklist_items - create_judges(casa_org) - create_languages(casa_org) - create_mileage_rates(casa_org) - create_learning_hour_types(casa_org) - create_learning_hour_topics(casa_org) - create_learning_hours(casa_org) - create_other_duties - casa_org + casa_org end - private # ------------------------------------------------------------------------------------------------------- - # Create 2 judges for each casa_org. def create_judges(casa_org) 2.times { Judge.create(name: Faker::Name.name, casa_org: casa_org) } @@ -123,54 +108,6 @@ def create_other_duties end end - def generate_case_number - # CINA-YY-XXXX - years = ((DateTime.now.year - 20)..DateTime.now.year).to_a - yy = years.sample(random: rng).to_s[2..3] - @case_number_sequence += 1 - "CINA-#{yy}-#{@case_number_sequence}" - end - - def generate_court_date - ((Date.today + 1.month)..(Date.today + 5.months)).to_a.sample - end - - def random_true_false - @true_false_array ||= [true, false] - @true_false_array.sample(random: rng) - end - - def random_case_contact_count - @random_case_contact_counts ||= [0, 1, 2, 2, 2, 3, 3, 3, 11, 11, 11] - @random_case_contact_counts.sample(random: rng) - end - - def random_past_court_date_count - @random_past_court_date_counts ||= [0, 2, 3, 4, 5] - @random_past_court_date_counts.sample(random: rng) - end - - def random_zero_one_count - @random_zero_one_count ||= [0, 1] - @random_zero_one_count.sample(random: rng) - end - - def random_court_order_count - @random_court_order_counts ||= [0, 3, 5, 10] - @random_court_order_counts.sample(random: rng) - end - - def likely_contact_durations - @likely_contact_durations ||= [15, 30, 60, 75, 4 * 60, 6 * 60] - end - - def note_generator - paragraph_count = Random.rand(6) - (0..paragraph_count).map { |index| - Faker::Lorem.paragraph(sentence_count: 5, supplemental: true, random_sentences_to_add: 20) - }.join("\n\n") - end - def create_case_contacts(casa_case) draft_statuses = %w[started details notes expenses] @@ -196,43 +133,6 @@ def create_case_contact(casa_case, status: "active") CaseContact.create!(params) end - def base_case_contact_params(casa_case, status) - { - casa_case: casa_case, - creator: casa_case.volunteers.sample(random: rng), - duration_minutes: likely_contact_durations.sample(random: rng), - occurred_at: rng.rand(0..6).months.ago, - contact_types: ContactType.all.sample(2, random: rng), - medium_type: CaseContact::CONTACT_MEDIUMS.sample(random: rng), - miles_driven: rng.rand(5..40), - want_driving_reimbursement: random_true_false, - contact_made: random_true_false, - notes: note_generator, - status: status, - draft_case_ids: [casa_case&.id] - } - end - - def order_choices - [ - "Limited guardianship of the children for medical and educational purposes to [name] shall be rescinded;", - "The children shall remain children in need of assistance (cina), under the jurisdiction of the juvenile court, and shall remain committed to the department of health and human services/child welfare services, for continued placement on a trial home visit with [NAME]", - "The youth shall continue to participate in educational tutoring, under the direction of the department;", - "The youth shall continue to participate in family therapy with [name], under the direction of the department;", - "The permanency plan for all the children of reunification is reaffirmed;", - "Visitation between the youth and the father shall be unsupervised, minimum once weekly, in the community or at his home, and may include overnights when he has the appropriate space for the children to sleep, under the direction of the department;", - "Youth shall continue to participate in individual therapy, under the direction of the department;", - "The youth shall continue to maintain stable employment;", - "The youth shall maintain appropriate housing while working towards obtaining housing that can accommodate all of the children being reunified, and make home available for inspection, under the direction of the department;", - "The youth shall participate in case management services, under the direction of the department;", - "The youth shall participate in mental health treatment and medication management, under the direction of the department;" - ] - end - - def transition_aged_youth?(birth_month_year_youth) - (Date.today - birth_month_year_youth).days.in_years > CasaCase::TRANSITION_AGE - end - def create_cases(casa_org, options) ContactTypePopulator.populate options.case_count.times do |index| @@ -454,6 +354,7 @@ def create_learning_hours(casa_org) end end + private # ------------------------------------------------------------------------------------------------------- def most_recent_past_court_date(casa_case_id) CourtDate.where( "date < ? AND casa_case_id = ?", @@ -477,4 +378,90 @@ def case_contact_after_last_court_date?(case_case_id, date) case_case_id ).any? end + + def order_choices + [ + "Limited guardianship of the children for medical and educational purposes to [name] shall be rescinded;", + "The children shall remain children in need of assistance (cina), under the jurisdiction of the juvenile court, and shall remain committed to the department of health and human services/child welfare services, for continued placement on a trial home visit with [NAME]", + "The youth shall continue to participate in educational tutoring, under the direction of the department;", + "The youth shall continue to participate in family therapy with [name], under the direction of the department;", + "The permanency plan for all the children of reunification is reaffirmed;", + "Visitation between the youth and the father shall be unsupervised, minimum once weekly, in the community or at his home, and may include overnights when he has the appropriate space for the children to sleep, under the direction of the department;", + "Youth shall continue to participate in individual therapy, under the direction of the department;", + "The youth shall continue to maintain stable employment;", + "The youth shall maintain appropriate housing while working towards obtaining housing that can accommodate all of the children being reunified, and make home available for inspection, under the direction of the department;", + "The youth shall participate in case management services, under the direction of the department;", + "The youth shall participate in mental health treatment and medication management, under the direction of the department;" + ] + end + + def transition_aged_youth?(birth_month_year_youth) + (Date.today - birth_month_year_youth).days.in_years > CasaCase::TRANSITION_AGE + end + + def base_case_contact_params(casa_case, status) + { + casa_case: casa_case, + creator: casa_case.volunteers.sample(random: rng), + duration_minutes: likely_contact_durations.sample(random: rng), + occurred_at: rng.rand(0..6).months.ago, + contact_types: ContactType.all.sample(2, random: rng), + medium_type: CaseContact::CONTACT_MEDIUMS.sample(random: rng), + miles_driven: rng.rand(5..40), + want_driving_reimbursement: random_true_false, + contact_made: random_true_false, + notes: note_generator, + status: status, + draft_case_ids: [casa_case&.id] + } + end + + def random_case_contact_count + @random_case_contact_counts ||= [0, 1, 2, 2, 2, 3, 3, 3, 11, 11, 11] + @random_case_contact_counts.sample(random: rng) + end + + def random_past_court_date_count + @random_past_court_date_counts ||= [0, 2, 3, 4, 5] + @random_past_court_date_counts.sample(random: rng) + end + + def random_zero_one_count + @random_zero_one_count ||= [0, 1] + @random_zero_one_count.sample(random: rng) + end + + def random_court_order_count + @random_court_order_counts ||= [0, 3, 5, 10] + @random_court_order_counts.sample(random: rng) + end + + def likely_contact_durations + @likely_contact_durations ||= [15, 30, 60, 75, 4 * 60, 6 * 60] + end + + def note_generator + paragraph_count = Random.rand(6) + (0..paragraph_count).map { |index| + Faker::Lorem.paragraph(sentence_count: 5, supplemental: true, random_sentences_to_add: 20) + }.join("\n\n") + end + + def generate_case_number + # CINA-YY-XXXX + years = ((DateTime.now.year - 20)..DateTime.now.year).to_a + yy = years.sample(random: rng).to_s[2..3] + @case_number_sequence += 1 + "CINA-#{yy}-#{@case_number_sequence}" + end + + def generate_court_date + ((Date.today + 1.month)..(Date.today + 5.months)).to_a.sample + end + + def random_true_false + @true_false_array ||= [true, false] + @true_false_array.sample(random: rng) + end + end From f76eb30447a27512c4937ecfc9cc48511eab136c Mon Sep 17 00:00:00 2001 From: Felicia Yi Date: Sat, 28 Sep 2024 11:27:49 -0400 Subject: [PATCH 2/2] fixed formatting errors --- db/seeds.rb | 2 -- db/seeds/db_populator.rb | 5 ++--- 2 files changed, 2 insertions(+), 5 deletions(-) diff --git a/db/seeds.rb b/db/seeds.rb index 4862a44214..e26550defb 100644 --- a/db/seeds.rb +++ b/db/seeds.rb @@ -53,8 +53,6 @@ def seed log "\nDone.\n\n" end - - private # ------------------------------------------------------------------------------------------------------- # Used for reporting record counts after completion: diff --git a/db/seeds/db_populator.rb b/db/seeds/db_populator.rb index 3d9c872edd..a5080cd4a7 100644 --- a/db/seeds/db_populator.rb +++ b/db/seeds/db_populator.rb @@ -30,7 +30,7 @@ def create_org(options) @casa_org_counter += 1 options.org_name ||= "CASA Organization ##{@casa_org_counter}" - casa_org = CasaOrg.find_or_create_by!(name: options.org_name) { |org| + CasaOrg.find_or_create_by!(name: options.org_name) { |org| org.name = options.org_name org.display_name = options.org_name org.address = Faker::Address.full_address @@ -41,7 +41,6 @@ def create_org(options) ] org.logo.attach(io: File.open(CasaOrg::CASA_DEFAULT_LOGO), filename: CasaOrg::CASA_DEFAULT_LOGO.basename.to_s) } - casa_org end # Create 2 judges for each casa_org. @@ -355,6 +354,7 @@ def create_learning_hours(casa_org) end private # ------------------------------------------------------------------------------------------------------- + def most_recent_past_court_date(casa_case_id) CourtDate.where( "date < ? AND casa_case_id = ?", @@ -463,5 +463,4 @@ def random_true_false @true_false_array ||= [true, false] @true_false_array.sample(random: rng) end - end