-
Notifications
You must be signed in to change notification settings - Fork 357
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
Conversation
There was a problem hiding this 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.
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 |
Quality Gate passedIssues Measures |
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.
@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. |
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? |
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 |
@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. |
@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). |
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. |
Introduces a new method
getStoredPath()
onOrganisationUnit
.Note that the
path
property is mapped with the "property access" mode in Hibernate. Per the Hibernate docs:This means that Hibernate will call
getPath()
and set thepath
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, thegetStoredPath()
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.