-
Notifications
You must be signed in to change notification settings - Fork 9.3k
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
M2.3.2 : Nullable getters in Service Contracts will throw a reflection error when used in the web API #25656
Comments
Hi @kanduvisla. Thank you for your report.
Please make sure that the issue is reproducible on the vanilla Magento instance following Steps to reproduce. To deploy vanilla Magento instance on our environment, please, add a comment to the issue:
For more details, please, review the Magento Contributor Assistant documentation. @kanduvisla do you confirm that you were able to reproduce the issue on vanilla Magento instance following steps to reproduce?
|
Hi @engcom-Charlie. Thank you for working on this issue.
|
✅ Confirmed by @engcom-Charlie Issue Available: @engcom-Charlie, You will be automatically unassigned. Contributors/Maintainers can claim this issue to continue. To reclaim and continue work, reassign the ticket to yourself. |
Hi @Parakoopa. Thank you for working on this issue.
|
A related issue, which must also be fixed:
|
…first type in return type
- phpcs:ignore added because this line was not actually touched
Hi @kanduvisla. Thank you for your report.
The fix will be available with the upcoming 2.4.0 release. |
Preconditions
Steps to reproduce
Create an interface with a nullable getter. In our scenario it was a method that could return an array of instances of another object, or
null
:Expected result
When properly configured and used as a web API, the object should be serialized using Reflection and it's nested objects as well.
Actual result
The following error is thrown:
Possible cause
My guess is that when determinating the type of return class, something goes wrong when a return type can be nullable. See also the workaround:
Workaround
The current woraround that will not trigger this error and make the web API work as expected is to flip the arguments, so instead of:
I use:
Now everything works as expected, but it seems to me that this should be considered a bug.
The text was updated successfully, but these errors were encountered: