-
Notifications
You must be signed in to change notification settings - Fork 63
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
Enable concurrent update for Entities #843
Enable concurrent update for Entities #843
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.
Just a one-off thought, happy to also take a closer look if @ktuite prefers.
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.
I think we need to change afterUpdate()
as well so that the OData is updated with the correct version after the update. Right now, I think it wouldn't be possible to update the same entity twice in a row.
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.
tried this (with sadiq's recent commit that makes this fix) and it works to update an entity multiple times
There's a parallel change to Backend (getodk/central-backend#832), but the Backend issue is more about the API and database and won't need testing by the QA team. I think I'll slot this PR in the project separately, then add the "needs testing" label to just this PR. Then the QA team can focus on verifying the changes here. |
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.
My only nitpick (and I'm not sure what to suggest instead) is with the styling around the conflict alert: there's a little gap above the top red border, and the X to close the alert doesn't have a useful function there's nothing to "retry" there.
data:image/s3,"s3://crabby-images/8013c/8013c8cb7144028c58f440199cdf0d60d09e61aa" alt="Screen Shot 2023-08-25 at 4 13 04 PM"
Here's the same alert in a different modal with more padding.
data:image/s3,"s3://crabby-images/ffc52/ffc52b6090bdba939b1c1630670cb6ae690e855b" alt="Screen Shot 2023-08-25 at 4 17 24 PM"
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.
tried this (with sadiq's recent commit that makes this fix) and it works to update an entity multiple times
@getodk/testers this feature can be tested on staging How to test
|
@sadiqkhoja Scenario: Now as User B I'm able to close the modal -> click on More in the "Actions" tab -> Click on Edit next to Entity Data -> Edit any information in the Entity and Update it while User A is still editing the same Entity. After that User A is unable to finish editing the Entity. Maybe it'll be better to block editing from both tabs? Because right now it's easy to take over. |
@srujner, I think your comment is somewhat related to getodk/central#476. Ideally clicking on "Edit" would immediately check the entity version. It wouldn't help with a case in which two people/tabs already had the edit modal open but it would help in the much more common case where two people have the entity list or entity detail page open at the same time. |
Tested with Success! |
What has been done to verify that this works as intended?
Automated tests and manually testes
Why is this the best possible solution? Were any other approaches considered?
NA
How does this change affect users? Describe intentional changes to behavior and behavior that could have accidentally been affected by code changes. In other words, what are the regression risks?
None
Does this change require updates to user documentation? If so, please file an issue here and include the link below.
NA
Before submitting this PR, please make sure you have:
npm run test
andnpm run lint
and confirmed all checks still pass OR confirm CircleCI build passes