-
Notifications
You must be signed in to change notification settings - Fork 26
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
✨ [#4993] Implement fetching select(boxes) options from Referentielijsten #4996
base: master
Are you sure you want to change the base?
✨ [#4993] Implement fetching select(boxes) options from Referentielijsten #4996
Conversation
Codecov ReportAll modified and coverable lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## master #4996 +/- ##
=======================================
Coverage 96.67% 96.68%
=======================================
Files 765 767 +2
Lines 26131 26202 +71
Branches 3407 3414 +7
=======================================
+ Hits 25262 25333 +71
Misses 606 606
Partials 263 263 ☔ View full report in Codecov by Sentry. |
dbb75e3
to
b82f2ab
Compare
adc42bb
to
9881217
Compare
45ea58b
to
99217fa
Compare
except Exception as e: | ||
if detail := getattr(e, "detail", None): | ||
raise APIException(detail) | ||
raise e |
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.
This is in preparation to display a proper error message to the user in case the referentielijsten options can't be fetched. I'm not sure if this is the right approach to get a specific message though, it currently looks like this:
Preferably I think the "detail" message should be displayed in the error block, which would require changes in the SDK
99217fa
to
5b99dc0
Compare
# invoke the configured form logic to dynamically update the Formio.js configuration | ||
new_configuration = evaluate_form_logic( | ||
instance.submission, | ||
instance, | ||
instance.submission.data, | ||
**self.context, | ||
) | ||
try: | ||
new_configuration = evaluate_form_logic( | ||
instance.submission, | ||
instance, | ||
instance.submission.data, | ||
**self.context, | ||
) | ||
except Exception as e: | ||
if detail := getattr(e, "detail", None): | ||
raise APIException(detail) | ||
raise e # pragma: no cover |
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.
Currently the philosophy of OF is "continue at all costs" and this breaks. Let's discuss with Joeri what the expected behaviour is here.
I'm also out of the loop now what the service fetch behaviour is 🤔
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.
In the issue this was mentioned:
If the API is unavailable or returns an error, Open Forms must display a user-friendly error message to the end user.
My assumption was to let the form crash, because the user won't be able to select a valid option (because they could not be fetched), which means that they cannot fill out the form. But it might be good to discuss this indeed 👍
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'm also out of the loop now what the service fetch behaviour is 🤔
Double checked this, with service fetch set up to fetch options from referentielijsten it does indeed continue and show no available options (Geen opties om te kiezen
)
0743288
to
a8710d5
Compare
@sergei-maertens I've changed the code to raise a 503 if the options could not be fetched I do think this needs some changes in the SDK to display the unavailability message I've also added a task to raise 503 in case of service fetch failures to the service fetch epic #4965 |
a8710d5
to
30efbb4
Compare
I recently stumbled on https://github.com/open-formulieren/open-forms-sdk/blob/da9810bef07411f6adb9e13958c2f8aa08195f13/src/components/RequireSubmission.jsx#L32 and I know that https://github.com/open-formulieren/open-forms-sdk/blob/da9810bef07411f6adb9e13958c2f8aa08195f13/src/components/Errors/ErrorBoundary.jsx#L161 also seems to handle a particular case, looks like the code above decides about generic error vs. specific :) |
…sten this was previously possible with logic and service fetch, but this functionality provides a shortcut to more easily integrate with Re ferentielijsten API
to be used for unittests with VCR and local development
30efbb4
to
ff370db
Compare
Closes #4993
Changes
Checklist
Check off the items that are completed or not relevant.
Impact on features
Release management
I have updated the translations assets (you do NOT need to provide translations)
./bin/makemessages_js.sh
./bin/compilemessages_js.sh
Dockerfile/scripts
./bin
folderCommit hygiene