Skip to content

Conversation

@issackjohn
Copy link
Contributor

@issackjohn issackjohn commented Nov 15, 2024

This pull request introduces a new experimental responsive design workload, featuring a single-page cooking website built with Lit and Tailwind CSS.

The hosted version can be found here.
Quick link to dev mode with workload selected.

Please look at the README in experimental/responsive-design for more information about the code and how it is organized.

Not included in this PR:

  • Support for different languages

@issackjohn issackjohn force-pushed the responsive-design branch 2 times, most recently from 1da5897 to 34a545e Compare November 15, 2024 19:19
@issackjohn issackjohn requested review from julienw and removed request for julienw November 15, 2024 19:22
@issackjohn issackjohn marked this pull request as ready for review November 15, 2024 19:22
@issackjohn
Copy link
Contributor Author

Adding reviewers for visibility, feel free to take a look :)

@rniwa
Copy link
Member

rniwa commented Nov 15, 2024

It seems to me that the test doesn't really take the advantage of responsive design since iframe's size is always same. Maybe we should add steps to resize iframe so that responsive design comes into play?

@issackjohn
Copy link
Contributor Author

It seems to me that the test doesn't really take the advantage of responsive design since iframe's size is always same. Maybe we should add steps to resize iframe so that responsive design comes into play?

Currently, we are resizing the the iframe with id #content-iframe in the ReduceWidthIn5Steps & IncreaseWidthIn5Steps steps. Do you mean that we should be resizing a different iframe?

@rniwa
Copy link
Member

rniwa commented Nov 15, 2024

It seems to me that the test doesn't really take the advantage of responsive design since iframe's size is always same. Maybe we should add steps to resize iframe so that responsive design comes into play?

Currently, we are resizing the the iframe with id #content-iframe in the ReduceWidthIn5Steps & IncreaseWidthIn5Steps steps. Do you mean that we should be resizing a different iframe

Oh, I see. We're resizing the inner iframe. I guess that works.

@issackjohn
Copy link
Contributor Author

Gentle ping 😄

@camillobruni
Copy link
Contributor

I still see rather short run times for individual steps (close to 1.6ms in chrome canary) which might introduce a bit too much noise in the long run.

Responsive-Design
Responsive-Design/LoadChatAndExpandRecipe	5.85	±	0.46 (7.9%)	ms
Responsive-Design/ReduceWidthIn5Steps  12.96	±	0.45 (3.5%)	ms
Responsive-Design/ScrollToChatAndSendMessage	1.68	±	0.07 (4.4%)	ms
Responsive-Design/IncreaseWidthIn5Steps	11.37	±	0.28 (2.5%)	

ScrollToChatAndSendMessage and (and especially it's sub-items) will show some aliasing from timer resolution which is ~ 0.1ms on chrome.
In general, i'd bump the step durations by 1.5x or 2x even to be on par with other workloads.

@issackjohn
Copy link
Contributor Author

I still see rather short run times for individual steps (close to 1.6ms in chrome canary) which might introduce a bit too much noise in the long run.

Responsive-Design
Responsive-Design/LoadChatAndExpandRecipe	5.85	±	0.46 (7.9%)	ms
Responsive-Design/ReduceWidthIn5Steps  12.96	±	0.45 (3.5%)	ms
Responsive-Design/ScrollToChatAndSendMessage	1.68	±	0.07 (4.4%)	ms
Responsive-Design/IncreaseWidthIn5Steps	11.37	±	0.28 (2.5%)	

ScrollToChatAndSendMessage and (and especially it's sub-items) will show some aliasing from timer resolution which is ~ 0.1ms on chrome. In general, i'd bump the step durations by 1.5x or 2x even to be on par with other workloads.

To bump up the step durations, I am thinking of

  1. Expanding all the recipes as part of LoadChatAndExpandRecipe
  2. Collapsing all the recipes as part of ScrollToChatAndSendMessage
    2.1 Sending a few more messages in the chat instead of just one.

currently no proposed changes for ReduceWidthIn5Steps & IncreaseWidthIn5Steps

@flashdesignory
Copy link
Contributor

Some visual questions - these might not be relevant to the tests:

Is this spacing as expected?
Screenshot 2024-12-09 at 10 08 00 PM

The collapsed grid looks fine, but once expanded, the item moves to the next row - is that expected?
collapsed
Screenshot 2024-12-09 at 10 08 09 PM

expanded
Screenshot 2024-12-09 at 10 08 15 PM

The video tiles don't work - those are just placeholders?
Screenshot 2024-12-09 at 10 08 34 PM

@issackjohn
Copy link
Contributor Author

Some visual questions - these might not be relevant to the tests:

Is this spacing as expected?

I'll add a fix for that. The webpage was designed to be viewed in 800x600, as that's how it will appear within the benchmark.

The collapsed grid looks fine, but once expanded, the item moves to the next row - is that expected? collapsed

Yes, that is expected. Do we prefer a different behavior?

The video tiles don't work - those are just placeholders?

Yes, they are just placeholders. We intended the video elements to be there but did not plan for them to play any actual videos.

@flashdesignory
Copy link
Contributor

Some visual questions - these might not be relevant to the tests:
Is this spacing as expected?

I'll add a fix for that. The webpage was designed to be viewed in 800x600, as that's how it will appear within the benchmark.

  • Thanks - I'd vote for supporting larger viewport sizes. This will ensure that the workload looks usable at larger viewports, in case we want to change what's supported in Speedometer later on.

The collapsed grid looks fine, but once expanded, the item moves to the next row - is that expected? collapsed

Yes, that is expected. Do we prefer a different behavior?

I guess it makes sense for the tests, since it shifts elements on the page. That said, it's not something you'd see on the web (hopefully). I'd expected a modal or something like that instead.

The video tiles don't work - those are just placeholders?

Yes, they are just placeholders. We intended the video elements to be there but did not plan for them to play any actual videos.

Thanks for clarifying.

@flashdesignory
Copy link
Contributor

@issackjohn - maybe rebase / merge main, to get the updated test runner in there. That should ensure the checks don't fail.

@camillobruni
Copy link
Contributor

Let's aim for > 5ms for each measured subtest (I'd still aim for roughly 10ms if possible). Does this sound reasonable?

@issackjohn
Copy link
Contributor Author

@issackjohn - maybe rebase / merge main, to get the updated test runner in there. That should ensure the checks don't fail.

Sounds good.

@issackjohn
Copy link
Contributor Author

Let's aim for > 5ms for each measured subtest (I'd still aim for roughly 10ms if possible). Does this sound reasonable?

Sounds reasonable to me, I'll add some more actions.

@camillobruni
Copy link
Contributor

Just double checked on Chrome, Firefox, Safari and the noise levels are in-sync with the rest of the workloads.
The minimum step times look good now I would say.

@issackjohn
Copy link
Contributor Author

Thanks! Looking forward to addressing anymore feedback from folks.

@netlify
Copy link

netlify bot commented Feb 11, 2025

Deploy Preview for webkit-speedometer-preview ready!

Name Link
🔨 Latest commit c7327fe
🔍 Latest deploy log https://app.netlify.com/projects/webkit-speedometer-preview/deploys/68ace84dfddca10008f2de0d
😎 Deploy Preview https://deploy-preview-453--webkit-speedometer-preview.netlify.app
📱 Preview on mobile
Toggle QR Code...

QR Code

Use your smartphone camera to open QR code link.

To edit notification comments on pull requests, go to your Netlify project configuration.

@issackjohn issackjohn force-pushed the responsive-design branch from 698c725 to 2a3113e Compare May 19, 2025 21:28

@layer utilities {
.content-auto {
content-visibility: auto;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is content-visibility widely supported across browsers and used on popular sites?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

My understanding is that it is newly baseline as of September 2024. https://developer.mozilla.org/en-US/docs/Web/CSS/content-visibility. I see conflicting information here though, it may also be limited availability?

It is also used on 4.65% of page loads on chrome according to https://chromestatus.com/metrics/css/timeline/popularity/662

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

content-visibility: auto (that specific value) doesn't seem supported in Safari according to MDN

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actually it seems supported partially in Safari.

From the chromestatus page, can we see which different values are used and not just the property?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Took a look and it seems like you can.
image
image

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

"auto" seems to be supported as of Safari 26 (2025-09-15⁩) so it's pretty new. Do we want to keep it?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We prefer to keep it. I'll let others comment as well. @rniwa

@issackjohn
Copy link
Contributor Author

Then I have a few more minor comments here and there. I haven't looked very closely at the tailwind code because I'm not familiar with it. Also I wonder if we could include matchMedia somewhere.

Sounds good. I can look into incorporating matchMedia as a follow-up and see where it might make sense to add.

@camillobruni
Copy link
Contributor

I see some lazy recalc-style happening outside the measured scope in chrome. (around 3ms) I'm not sure how we'd fully control this. From Devtools it clearly looks like work that was scheduled in the async phase.
I've tried to see whether this happens in Firefox as well, but couldn't spot this immediately.
Might be worthwhile checking on Safari as well.

Screenshot 2025-07-01 at 14 28 55

@julienw julienw removed their request for review July 11, 2025 15:22
@issackjohn
Copy link
Contributor Author

issackjohn commented Jul 21, 2025

I see some lazy recalc-style happening outside the measured scope in chrome. (around 3ms) I'm not sure how we'd fully control this. From Devtools it clearly looks like work that was scheduled in the async phase. I've tried to see whether this happens in Firefox as well, but couldn't spot this immediately. Might be worthwhile checking on Safari as well.

Screenshot 2025-07-01 at 14 28 55

Now capturing in measured time on edge/chrome

  • ReduceWidthIn5Steps and IncreaseWidthIn5Steps when using getBoundingRectAndElementFromPoint
  • LoadChatAndExpandRecipes when using getBoundingClientRect.

Working on properly capturing the other steps when using getBoundingClientRect.

@issackjohn
Copy link
Contributor Author

I see some lazy recalc-style happening outside the measured scope in chrome. (around 3ms) I'm not sure how we'd fully control this. From Devtools it clearly looks like work that was scheduled in the async phase. I've tried to see whether this happens in Firefox as well, but couldn't spot this immediately. Might be worthwhile checking on Safari as well.
Screenshot 2025-07-01 at 14 28 55

Now capturing in measured time on edge/chrome

  • ReduceWidthIn5Steps and IncreaseWidthIn5Steps when using getBoundingRectAndElementFromPoint
  • LoadChatAndExpandRecipes when using getBoundingClientRect.

Working on properly capturing the other steps when using getBoundingClientRect.

All steps should now be properly captured.

I've observed that some work occasionally occurs outside the measured time following the ScrollToChatAndSendMessages step. From my understanding, this shouldn't be an issue. However, do we believe this activity should be included in the measured time? If we decide it's worth tracking, do you have any ideas of how we could capture that work?
image

@issackjohn
Copy link
Contributor Author

@bgrins, @camillobruni, @rniwa, Could I get someone to take a look at the matchMedia implementation? Most of it is in experimental/responsive-design/src/lib/components/recipe-grid.js and used to switch the recipe cards to a compact version.

I'm still working on correctly capturing the other work caused by things like ResizeObserver within the measured time.

@issackjohn
Copy link
Contributor Author

Gentle Ping. :)

issackjohn and others added 10 commits August 25, 2025 15:33
* Write dev files to different location.
* Using root code style.
* Remove unused Prettier and ESLint configuration files from responsive design directory
* Update scrollIntoView method to accept options parameter for better control
* change scroll behavior to instant
* Refactor Responsive-Design tests to use async functions
* Rename output directory from dev-dist to build-dev in configuration files
* Re-install resize observer
* Refactor iteration methods to use for...of loops
* add matchMedia support
* build dist
* add disconnectedCallback
* Move to connectedCallback
Properly capturing layout work in steps ReduceWidthIn5Steps and IncreaseWidthIn5Steps.
* Refactor layout method to accept target element for improved flexibility
* refactor: simplify layout method by using logical OR for body assignment
* refactor: replace magic numbers with named constants for media query breakpoints
* refactor: replace repeated calls to getContentDocument with a variable for improved readability
* Remove iframe and integrate cooking-app directly into index.html
* Remove querySelectorAllInShadowRoot method from PageElement class
* move setWidth method to Page class
* remove extra changes
* Add content visibility change handlers for video grid
@issackjohn
Copy link
Contributor Author

Created #525 for safari CI run end2end Test failure.

@issackjohn
Copy link
Contributor Author

Gentle ping :)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

5 participants