- Issue created by @tedbow
- Merge request !712Resolve #3509037 Jscomponent examples and enums should response prop type β (Merged) created by tedbow
- πΊπΈUnited States tedbow Ithaca, NY, USA
got it started. add comment about needed test coverage. It seems like `\Drupal\experience_builder\Entity\JavaScriptComponent::normalizeForClientSide` is the right place but maybe we want to refactor that into another method.
Do we need to validate that only integers and numbers are sent in the request if that matches the type?
- π§πͺBelgium wim leers Ghent π§πͺπͺπΊ
This can actually be seen in
\Drupal\Tests\experience_builder\Functional\XbConfigEntityHttpApiTest::testJavaScriptComponent
Great catch!
Another missed defect in β¨ HTTP API for code component config entities Active (actually even before that, in β¨ Config entity for storing code components Active , but there it was less obvious than the literally incorrect example in the test that @tedbow quoted in the issue summary π).
Looking at your analysis so far, I wonder if this is actually a pure config schema problem π€
- π§πͺBelgium wim leers Ghent π§πͺπͺπΊ
Yep, confirmed: this is a pure config schema problem. It's quite interesting, really: we need to describe in config schema , for the subset of it that XB supports. π€π€―π
Tests + fixes incoming.
- π§πͺBelgium wim leers Ghent π§πͺπͺπΊ
- Test coverage complete (functional + kernel), and it revealed quite a list of broken things: https://git.drupalcode.org/project/experience_builder/-/jobs/4484811
- One of the wildest things I've ever done: expressing the supported subset of JSON Schema in Drupal's Config Schema: https://git.drupalcode.org/project/experience_builder/-/merge_requests/7... π€― π€ This automatically fixes the problem reported here, but also provides much more precise validation errors, and removes the need to perform manual typecasting.
The stricter validation this introduces even uncovered multiple test coverage bugs that @f.mazeikis and I missed in β¨ Allow adding image properties in the code editor Active yesterday! π±π₯³
P.S.: This is what I was hoping/expecting to see on β¨ Config entity for storing code components Active , but didn't ask for/block it on because it'd have delayed all of π± [Meta] Plan for code components Active .
- π§πͺBelgium wim leers Ghent π§πͺπͺπΊ
CI agrees! (
component-operations.cy.js
fails on CI, but passes locally. It's been a known fairly frequent random failure for a while.)I'd like @tedbow to do final sign-off given he started this MR and I took it in a very different direction.
Also, I bet that @tedbow's π Javascript code components props, examples and description should be optional Active (which just landed) conflicts with this.
- π³π±Netherlands balintbrews Amsterdam, NL
I also tested this, and the problem it caused its gone. I'll leave it up to you if this is ready to be merged.
- π§πͺBelgium wim leers Ghent π§πͺπͺπΊ
All addressed π Some nice catches, @tedbow β thanks!
@balintbrews Thanks for explicitly testing this indeed fixes the consequences in the UI! ππ
-
wim leers β
committed c3f33038 on 0.x authored by
tedbow β
Issue #3509037 by wim leers, tedbow, balintbrews: JavaScriptComponent...
-
wim leers β
committed c3f33038 on 0.x authored by
tedbow β
Automatically closed - issue fixed for 2 weeks with no activity.