Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Faith Schools Flow Target branch #7230

Open
wants to merge 12 commits into
base: main
Choose a base branch
from
Open

Faith Schools Flow Target branch #7230

wants to merge 12 commits into from

Conversation

starswan
Copy link
Contributor

@starswan starswan commented Nov 4, 2024

Trello card URL

Changes in this PR:

  • Is there anything specific you want feedback on?

Screenshots of UI changes:

Before

After

Next steps:

  • Terraform deployment required?

  • New development configuration to be shared?

@starswan starswan force-pushed the faith-schools-flow branch 2 times, most recently from b05a974 to b2c49e7 Compare November 5, 2024 12:04
@starswan starswan force-pushed the faith-schools-flow branch 2 times, most recently from d03f02e to 7ebf923 Compare November 21, 2024 11:11
@starswan starswan force-pushed the faith-schools-flow branch 2 times, most recently from c22557f to 3528559 Compare December 4, 2024 09:40
@starswan starswan marked this pull request as ready for review December 12, 2024 12:19
Comment on lines +174 to +195
catholic_following_religion:
heading: Religious information
title: Religious information — Application
is_a_catholic_school: "%{name} is a Catholic school."
preference_to_catholics: Schools, academies and colleges of a religious character can give preference to Catholic applicants when recruiting for teaching roles.
preference_for_support_staff: They can also give preference to Catholic applicants for support staff roles where there is a genuine occupational requirement.
non_catholics_apply: Applicants who do not follow a faith or religion are still encouraged to apply.
non_catholic_following_religion:
heading: Religious information
title: Religious information — Application
catholic_religion_details:
heading: Religious information
title: Religious information — Application
non_catholic_religion_details:
heading: Religious information
title: Religious information — Application
school_ethos:
heading: Religious information
title: Religious information — Application
has_a_religious_character: "%{name} has a religious character."
preference_to_religious_applicants: Schools, academies and colleges of a religious character can give preference to religious applicants when recruiting for teaching roles, but candidates who do not follow a faith or religion are still encouraged to apply.
ethos_and_aims: How will you support the school's ethos and aims?
Copy link
Collaborator

@scruti scruti Dec 12, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggestion 💡
The bit repeating across all the blocks could be extracted and re-used using YAML anchors.

Something like the example bellow. Or the anchor could be defined in one of the steps that only has header/title and reused without having to be defined separately:

Suggested change
catholic_following_religion:
heading: Religious information
title: Religious information — Application
is_a_catholic_school: "%{name} is a Catholic school."
preference_to_catholics: Schools, academies and colleges of a religious character can give preference to Catholic applicants when recruiting for teaching roles.
preference_for_support_staff: They can also give preference to Catholic applicants for support staff roles where there is a genuine occupational requirement.
non_catholics_apply: Applicants who do not follow a faith or religion are still encouraged to apply.
non_catholic_following_religion:
heading: Religious information
title: Religious information — Application
catholic_religion_details:
heading: Religious information
title: Religious information — Application
non_catholic_religion_details:
heading: Religious information
title: Religious information — Application
school_ethos:
heading: Religious information
title: Religious information — Application
has_a_religious_character: "%{name} has a religious character."
preference_to_religious_applicants: Schools, academies and colleges of a religious character can give preference to religious applicants when recruiting for teaching roles, but candidates who do not follow a faith or religion are still encouraged to apply.
ethos_and_aims: How will you support the school's ethos and aims?
religious_information: &religious_information
heading: Religious information
title: Religious information — Application
catholic_following_religion:
<<: *religious_information
is_a_catholic_school: "%{name} is a Catholic school."
preference_to_catholics: Schools, academies and colleges of a religious character can give preference to Catholic applicants when recruiting for teaching roles.
preference_for_support_staff: They can also give preference to Catholic applicants for support staff roles where there is a genuine occupational requirement.
non_catholics_apply: Applicants who do not follow a faith or religion are still encouraged to apply.
non_catholic_following_religion: *religious_information
catholic_religion_details: *religious_information
non_catholic_religion_details: *religious_information
school_ethos:
<<: *religious_information
has_a_religious_character: "%{name} has a religious character."
preference_to_religious_applicants: Schools, academies and colleges of a religious character can give preference to religious applicants when recruiting for teaching roles, but candidates who do not follow a faith or religion are still encouraged to apply.
ethos_and_aims: How will you support the school's ethos and aims?

Comment on lines +148 to +159
- following_religion
- religious_reference_type
- faith
- place_of_worship
- religious_referee_name
- religious_referee_address
- religious_referee_role
- religious_referee_email
- religious_referee_phone
- baptism_address
- baptism_date
- ethos_and_aims
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🙋‍♂️
The majority of these new fields could be considered PII. Adding them to analytics.yml file will expose them in plain to BigQ Analytics platform.

This list needs to be curated with our data analyst (Brandon) and:

  • Fields containing PII that Brandon wants in analytics will also need to be listed in analytics_hidden_pii.yml so they get masked before being pushed to BigQ.
  • Fields containing PII that Brandon doesn't need in BigQ will need to be listed in analytics_blocklist.yml instead of here.
  • Fields not considered PII can be left here.

From the list of new fields here, I would guess the only ones not purely PII are the "following religion" are these three:

- following_religion
- religious_reference_type
- faith

They're still personal sensitive data and one would wonder if they actually could be combined with other fields to identify a particular person.

I guess "following_religion" is generic enough, but I believe the particular faith of an applicant should be masked?

The docs on the gem referencing the different config files usage: https://github.com/DFE-Digital/dfe-analytics?tab=readme-ov-file#5-send-database-events


scenario "follows the flow" do
it "follows the flow" do
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

❓ out of curiosity. What criteria are you applying to set it vs scenario for the feature tests?

We have a tech debt ticket (and a pending team discussion on it) regarding normalising the feature specs it/scenario, but I see you're using both on the same feature specs file. So I wonder if you apply a particular rule regarding whether to use it or scenario in each case.

Comment on lines +51 to +52
.select { |step| relevant_steps.include?(step) }
.map { |step| form_fields_from_step(step) }
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggestion (that may come to personal preference).

Suggested change
.select { |step| relevant_steps.include?(step) }
.map { |step| form_fields_from_step(step) }
.filter_map { |step| form_fields_from_step(step) if relevant_steps.include?(step) }

Comment on lines +24 to +25
attributes = attributes_to_copy
if attributes.include? :baptism_certificate
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🙋‍♂️

Reading this code I think :baptism_certificate is missing from the #attributes_to_copy list.

If I read this right, if not included there, if attributes.include? :baptism_certificate would never return true ?

Comment on lines +4 to +5
.map { |form_class| form_class.load_form(model) }
.map(&:values)
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We can reduce it to a single loop:

Suggested change
.map { |form_class| form_class.load_form(model) }
.map(&:values)
.map { |form_class| form_class.load_form(model).values }

.map { |form_class| form_class.load_form(model) }
.map(&:values)
.flatten
.any? { |value| !value.nil? }
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I know this was pre-existing code, but isn't this just a

Suggested change
.any? { |value| !value.nil? }
.any?

starswan and others added 7 commits December 19, 2024 09:11
Co-authored-by: EllieNodder <94541493+EllieNodder@users.noreply.github.com>
Co-authored-by: EllieNodder <94541493+EllieNodder@users.noreply.github.com>
Co-authored-by: EllieNodder <94541493+EllieNodder@users.noreply.github.com>
Co-authored-by: EllieNodder <94541493+EllieNodder@users.noreply.github.com>
Co-authored-by: EllieNodder <94541493+EllieNodder@users.noreply.github.com>
Co-authored-by: EllieNodder <94541493+EllieNodder@users.noreply.github.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants