Create test for checking markup serialization

Created on 12 September 2024, 7 months ago

See parent task.

TODO ON ME: check if tests for JSON serialization can be easily added to this module or if e.g. lupus_ce_renderer is a better place.

📌 Task
Status

Active

Version

3.0

Component

Code

Created by

🇳🇱Netherlands roderik Amsterdam,NL / Budapest,HU

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Merge Requests

Comments & Activities

  • 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
    json

    This 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:
    See renderCustomElement() 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.
  • Merge request !109Add test coverage for CustomElement Class → (Merged) created by benellefimostfa
  • 🇹🇳Tunisia benellefimostfa

    @roderik First iteration of the test is pushed, which is failing when having multiple slots after normalizing.

  • Pipeline finished with Failed
    3 months ago
    Total: 214s
    #395299
  • Pipeline finished with Failed
    2 months ago
    Total: 197s
    #401868
  • 🇳🇱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.

  • Pipeline finished with Success
    2 months ago
    Total: 421s
    #406605
  • Status changed to Needs work 2 months ago
  • 🇳🇱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.

  • Pipeline finished with Skipped
    2 months ago
    #407525
  • Pipeline finished with Skipped
    2 months ago
    #407526
  • 🇳🇱Netherlands roderik Amsterdam,NL / Budapest,HU
  • Pipeline finished with Success
    2 months ago
    Total: 191s
    #407585
  • Pipeline finished with Success
    2 months ago
    Total: 581s
    #407608
  • Pipeline finished with Success
    2 months ago
    Total: 193s
    #407614
    • roderik committed 0a475bf8 on 8.x-2.x
      Issue #3473955 by benellefimostfa, roderik, fago: Test coverage for...
  • Automatically closed - issue fixed for 2 weeks with no activity.

Production build 0.71.5 2024