Skip to content
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

This PR fixes the issue #365: jQuery test only ever marks the first todo item as completed #366

Closed
wants to merge 1 commit into from

Conversation

rniwa
Copy link
Member

@rniwa rniwa commented Jan 27, 2024

The bug was caused by jQuery replacing the whole todo list whenever each todo item is toggled.

Fixed it by running querySelectorAll in each iteration.

…odo item as completed

The bug was caused by jQuery replacing the whole todo list whenever each todo item is toggled.

Fixed it by running querySelectorAll in each iteration.
@rniwa rniwa added non-trivial change A change that affects benchmark results v3-blocker labels Jan 27, 2024
@rniwa
Copy link
Member Author

rniwa commented Jan 27, 2024

An alternative fix is modify the jquery todo implementation so that it won't nuke the whole todo list whenever one of them is toggled but that seemed like a bigger overhaul.

@bgrins bgrins requested a review from julienw January 29, 2024 19:28
@julienw
Copy link
Contributor

julienw commented Jan 30, 2024

This produces a lot of GC due to the full rerenders... Maybe actually we should actually fix this for toggles? And maybe even for creates and destroys...

FTR I tried different approaches than the one with querySelectorAll here, but I got the same scores as a result. I tried using

querySelector(`li:nth-child(${i}) .toggle`)

and with getElementsByClassName.
If you want to try, here are the links:
with querySelectorAll
with nth-child
with getElementsByClassName

I'd like to hear other opinions.

@camillobruni
Copy link
Contributor

I probably slightly prefer getElementsByClassName, but given the little difference in score I don't have a strong opinion.

@julienw
Copy link
Contributor

julienw commented Feb 6, 2024

What do folks think then?
Should we favor #367 using :nth-child?

@bgrins
Copy link
Contributor

bgrins commented Feb 6, 2024

I think either this PR or #367 - we should close #368 since it doesn't use PageElement as-is

@bgrins
Copy link
Contributor

bgrins commented Feb 6, 2024

#367 is fine with me, if it works for @camillobruni / @flashdesignory

@julienw
Copy link
Contributor

julienw commented Feb 8, 2024

fixed by #367

@julienw julienw closed this Feb 8, 2024
@rniwa rniwa deleted the fix-jquery-complete-all-items branch February 29, 2024 05:16
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
non-trivial change A change that affects benchmark results v3-blocker
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants