- Issue created by @roderik
- 🇦🇹Austria fago Vienna
I second that, the parent issue also triggered that thinking for me.
We should make one test that covers all cases that are relevant for serialiation, what I can think of is:
CE with attributes, no children
CE with attributes, single slot, single CE child
CE with attributes, single slot, multiple CE children
CE with attributes, single slot, markup cotnent
CE with attributes, single slot with multiple entries, one single child, one multiple CE children. adding markup in this case is unusual, so not something we have to cover imo.then, we should serialize this in those formats:
markup with vue2/standard CE syntax
markup with vue3 syntax
jsonThis is not a release blocker, but I'd love to get it done soon to ensure we are good and stay good here. We should make this one or multiple dedicated kernel tests, so we can easily add them to 2.x and 3.x and compare results.
- 🇳🇱Netherlands roderik Amsterdam,NL / Budapest,HU
For reference to whomever:
Markup:
SeerenderCustomElement()
in existing tests.JSON:
$this->getCustomElementNormalizer()->normalize($custom_element)
. (There is no place in custom_elements module that does JSON serialization, but the building blocks - i.e.getCustomElementNormalizer()
are here so the test should be here. One module that has the above line of code, is lupus_ce_renderer.) - First commit to issue fork.
- 🇹🇳Tunisia benellefimostfa
@roderik First iteration of the test is pushed, which is failing when having multiple slots after normalizing.
- 🇳🇱Netherlands roderik Amsterdam,NL / Budapest,HU
This looks good, and I also learned things about CE in the process. (The outdated issue summary is a sign of how little I knew about CustomElement basics back in September -- I likely won't bother updating it.)
I have some requests for additions though; see MR comments.
Please change ticket status to "Needs review" when I should review.
Also: I will want to have a larger comment on the class (to say that it is not only testing CustomElements but also rendering) and possibly rename it. But I think I'll just do that myself afterwards, and not bother you with that.
adding markup in this case is unusual, so not something we have to cover imo.
I actually think we'll need to cover this because it will become more important. But we can add that coverage in ✨ Create a HTML-to-CE parser Active after merging this.
- Status changed to Needs work
2 months ago 5:50pm 27 January 2025 - 🇳🇱Netherlands roderik Amsterdam,NL / Budapest,HU
Reviewed. This is good. But done:
- In https://git.drupalcode.org/project/custom_elements/-/merge_requests/109#..., when I said "single setSlot() call" and "above", I meant the test above my comment that contained a single setSlot() call. Because that would test/document an isolated addSlot() call. You have extended a more complicated test, so... I now added this myself. I respected/took the code setup that you used in other tests.
- testSlotOperationsWithMultipleChildren() did not contain the Vue3 version yet, so I added it for consistency - and changed the test comments a bit.
- I renamed the class, and commented that it actually tests the combination of CustomElement + CustomElementsNormalizer.
I don't usually merge issues that are still set to Needs Work, but review was requested elsewhere and we can continue in ✨ Create a HTML-to-CE parser Active if needed.
-
roderik →
committed bca11271 on 3.x authored by
benellefimostfa →
Issue #3473955 by benellefimostfa, roderik, fago: Test coverage for...
-
roderik →
committed bca11271 on 3.x authored by
benellefimostfa →
Automatically closed - issue fixed for 2 weeks with no activity.