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: Use org unit stored path [DHIS2-18234] #19626

Merged
merged 39 commits into from
Jan 10, 2025
Merged

Conversation

larshelge
Copy link
Member

@larshelge larshelge commented Jan 8, 2025

Introduces a new method getStoredPath() on OrganisationUnit.

Note that the path property is mapped with the "property access" mode in Hibernate. Per the Hibernate docs:

Property access mode implies the JPA provider accessing the entity’s state through its getter and setter methods. These methods can be used for encapsulation and additional logic as well.

This means that Hibernate will call getPath() and set the path property as part of all persistence operations. This in turn means that we don't have to recalculate the path value in the DHIS 2 application every time we need the value, as it will be persisted in the database.

The exception is when code modifies the ancestors/parents and relies on an up-to-date path value. Though in those special cases, one can simply call the getPath() method. In all other scenarios, the getStoredPath() method can be called, which should introduce a significant performance gain.

For the getStoredPath() method, if the path is not defined, typically as part of an integration test where the state is not yet flushed to the database, the calculated path based on the org unit ancestors is returned.

Reducing the pressure from re-calculating the path may alleviate the problem of DHIS2-18234 where the UID of the ancestor org units are not reflecting the persisted value.

@larshelge larshelge changed the title WIP: fix: Org unit persisted path WIP: fix: Use org unit stored path [DHIS2-18234] Jan 9, 2025
@larshelge larshelge changed the title WIP: fix: Use org unit stored path [DHIS2-18234] fix: Use org unit stored path [DHIS2-18234] Jan 9, 2025
@larshelge larshelge requested review from netroms and jbee January 9, 2025 16:44
@larshelge larshelge marked this pull request as ready for review January 9, 2025 16:44
@larshelge larshelge requested a review from a team as a code owner January 9, 2025 16:44
@teleivo teleivo requested a review from muilpp January 10, 2025 05:37
Copy link
Contributor

@jbee jbee left a comment

Choose a reason for hiding this comment

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

At some point we have to change how we keep the path consistent in DB but until then this might be a good improvement to avoid walking the tree and potentially triggering lazy loading from DB when reading the path.

@larshelge
Copy link
Member Author

Yes agree @jbee , I noticed that if you make a change using the maintenance app > org unit hierarchy operations by moving e.g. an org unit at level 3 to under another org unit at level 2, the path property of org units at level 4 below the moved org unit are not updated. So we possibly should trigger a path update after hierarchy operations.

@jbee
Copy link
Contributor

jbee commented Jan 10, 2025

I noticed that if you make a change using the maintenance app > org unit hierarchy operations by moving e.g. an org unit at level 3 to under another org unit at level 2, the path property of org units at level 4 below the moved org unit are not updated.

I also found that and then got reminded that this is "by design" or at least a known issue because we do have a dedicated action in the maintenance controller to then run a full update. Jason P. told me that this is something implementations use regularly when they suspect something is off.

So we possibly should trigger a path update after hierarchy operations.

@larshelge We had a long chat about the issue in November, I think, and the TLDR is: it is really complicated problem to make this consistent. Most likely our best bet is to utilize some sort of DB functionality to update paths based on parent reference and not have any logic in Java. But for all the "simple" ideas we quickly found reasons why it does not work but only shifts the problem to somewhere else.

@david-mackessy
Copy link
Contributor

My understanding of this PR is that it might help with the issue concerned, but is yet to be proven. Should we not try to prove there is some improvement before merging to master? Liaise with the reporter and ask them to try the proposed fix?
Who's to say this doesn't make things worse?

@larshelge
Copy link
Member Author

larshelge commented Jan 10, 2025

I mostly agree @david-mackessy , I am working on a "backport" to 40, after which I will create a custom build and ask for feedback.

That said, I see this as a general improvement which I suggest should be merged whether it fixes DHIS2-18234 or not. Since the getPath call is quite expensive, and since Hibernate will take care of the persistence aspect, this may mean significant performance gains. Again, that should ideally be benchmarked, but we are essentially avoiding an expensive, unnecessary call here.

@larshelge
Copy link
Member Author

@jbee agree on your comments on moving complexity around. Perhaps i) running the path update function after a an explicit hierarchy operation is triggered, and ii) having a system job which updates the paths nightly will be a good enough solution.

@david-mackessy
Copy link
Contributor

@larshelge that sounds ok. With the merge to master (42), at least there is no chance of us releasing a patch until the main release of 42 (hopefully it is tested by that time).
With a backport to 40, is the intention to merge to 40 also or test from a branch build on 40? (trying to avoid potentially releasing code without testing, in a patch release of 40)

@larshelge larshelge merged commit 5b5d602 into master Jan 10, 2025
17 checks passed
@larshelge larshelge deleted the org-unit-persisted-path branch January 10, 2025 10:21
@larshelge
Copy link
Member Author

Sounds good @david-mackessy . Sorry - the idea is to create a branch off 40 branch, backport/reimplement the fix, create a custom build of that branch and test. If the test is successful, create a PR, review and hopefully merge to 40.

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