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

fix: Shallow copy group_entities and person_entity when cloning TBS #294

Merged
merged 3 commits into from
Oct 17, 2024

Conversation

anth-volk
Copy link
Contributor

@anth-volk anth-volk commented Oct 16, 2024

Fixes #293.

Previous fixes to -core ensured that when a TaxBenefitSystem object was cloned via its internal .clone() method, entities themselves were shallow copied to prevent stale variable versions from being transferred between systems. However, this fix assumed that GroupEntity and PopulationEntity objects were included within the TaxBenefitySystem's entities key, when they are not.

This led structural reform runs to crash, as the GroupEntity and PopulationEntity would possess stale variable versions from the API's first instantiation of the default tax-benefit system, attempt to calculate using this, then crash when they couldn't find a variable that had been newly created as part of a structural reform.

This PR ensures that GroupEntity and PopulationEntity objects are also shallow-copied to prevent this behavior. This PR does not add tests at the moment, but I have opened an issue in the -api package laying out a comprehensive series of tests around structural reforms at PolicyEngine/policyengine-api#1885. I have also opened a draft PR in the -us package to ensure these changes cause no test failures there (PolicyEngine/policyengine-us#5240).

@anth-volk anth-volk marked this pull request as draft October 16, 2024 17:52
@anth-volk
Copy link
Contributor Author

Temporarily moving to draft; I think we can actually re-enable the two tests removed previously, but want to confirm

@nikhilwoodruff nikhilwoodruff merged commit 7772b24 into PolicyEngine:master Oct 17, 2024
3 checks passed
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.

App white screens on Varying your earnings for select households
2 participants