Closed Bug 1518999 Opened 6 years ago Closed 4 years ago

implement PerformancePaintTiming

Categories

(Core :: Performance, enhancement, P3)

66 Branch
enhancement

Tracking

()

RESOLVED FIXED
84 Branch
Performance Impact none
Tracking Status
firefox84 --- fixed

People

(Reporter: 709922234, Assigned: sefeng)

References

()

Details

(Keywords: dev-doc-complete, perf-alert, Whiteboard: , [wptsync upstream])

Attachments

(8 files, 2 obsolete files)

(deleted), text/x-phabricator-request
Details
(deleted), text/x-phabricator-request
Details
(deleted), text/x-phabricator-request
Details
(deleted), text/x-phabricator-request
Details
(deleted), text/x-phabricator-request
Details
(deleted), text/x-phabricator-request
Details
(deleted), text/x-phabricator-request
Details
(deleted), text/x-phabricator-request
Details

User Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.14; rv:66.0) Gecko/20100101 Firefox/66.0

Component: Untriaged → DOM
Product: Firefox → Core
Priority: -- → P3
Component: DOM → DOM: Core & HTML

Moving to Performance module as it's part of performance API. Feel free to reset if I got it wrong.

Type: defect → enhancement
Component: DOM: Core & HTML → Performance
Priority: P3 → --
Priority: -- → P3
Whiteboard: [qf-]
Assignee: nobody → whawkins

We're very glad to see some movement on this. Is this being worked on actively by Mozilla now? Any planned timeline for this project?

Chrome / Blink has been shipping this API for a while, and WebKit is starting its implementation in https://webkit.org/b/78011. The current plan is to just implement first contentful paint for now.

Assignee: whawkins → sefeng
Attachment #9134258 - Attachment description: Bug 1518999 - Implement PerformancePaintTiming for FirstContentfulPaint → Bug 1518999 - Implement PerformancePaintTiming for FirstContentfulPaint r=smaug
Attachment #9134258 - Attachment description: Bug 1518999 - Implement PerformancePaintTiming for FirstContentfulPaint r=smaug → Implement PerformacePaintTiming for FirstContentfulPaint

Some tests made some assumptions about the number of returned entries
by performance.getEntries, and these assumptions are not valid
anymore once we added new entries.

Depends on D66463

In this patch, we changed a lot of tests from PRECONDITION_FAILED to
timeout because we added the PerformancePaintTiming API so the
precodition is no longer failed. TIMEOUT is required because
these tests expect two performance paint entries, but we only
support one of them.

Depends on D68645

Depends on D68646

Attachment #9134258 - Attachment description: Implement PerformacePaintTiming for FirstContentfulPaint → Bug 1518999 - Implement PerformacePaintTiming for FirstContentfulPaint

The current tests workflow works as wait for three frames, then
check if the performance entry shows up. This workflow is flaky
because the three frames piece is hardcoded and there are
chances that the paint takes longer than three frames because it
really depends on the current workload of the system.

We fix it by loading the image into memory first, so that it's
decoded before the painting.

Depends on D68647

(In reply to Sean Feng [:sefeng] from comment #8)

The current tests workflow works as wait for three frames, then
check if the performance entry shows up. This workflow is flaky
because the three frames piece is hardcoded and there are
chances that the paint takes longer than three frames because it
really depends on the current workload of the system.

We fix it by loading the image into memory first, so that it's
decoded before the painting.

Can you propose it as an upstream change to WPT if you haven't already?

Changes to WPT in mozilla-central get upstreamed automatically, fwiw.

Status: UNCONFIRMED → ASSIGNED
Ever confirmed: true

(In reply to Noam Rosenthal from comment #9)

(In reply to Sean Feng [:sefeng] from comment #8)

The current tests workflow works as wait for three frames, then
check if the performance entry shows up. This workflow is flaky
because the three frames piece is hardcoded and there are
chances that the paint takes longer than three frames because it
really depends on the current workload of the system.

We fix it by loading the image into memory first, so that it's
decoded before the painting.

Can you propose it as an upstream change to WPT if you haven't already?

Yup, as what Emilio said :)

Attachment #9134258 - Attachment description: Bug 1518999 - Implement PerformacePaintTiming for FirstContentfulPaint → Bug 1518999 - Implement PerformancePaintTiming for FirstContentfulPaint

Depends on D68888

Pushed by sefeng@mozilla.com: https://hg.mozilla.org/integration/autoland/rev/1968b8ca14d7 Implement PerformancePaintTiming for FirstContentfulPaint r=smaug,mstange https://hg.mozilla.org/integration/autoland/rev/123403a14312 Refactor some performance.getEntries related tests r=mstange https://hg.mozilla.org/integration/autoland/rev/f2a6a3797ef1 Change the status of paint timing WPT tests r=mstange https://hg.mozilla.org/integration/autoland/rev/b7de245b329c Enable fcp only PerformancePaintTming tests r=mstange https://hg.mozilla.org/integration/autoland/rev/0924e0169dcb Update fcp-only tests to load image into memory first r=mstange https://hg.mozilla.org/integration/autoland/rev/eb8e5411868e Add a WPT test to make sure FCP works for iframes r=mstange
Created web-platform-tests PR https://github.com/web-platform-tests/wpt/pull/25080 for changes under testing/web-platform/tests
Whiteboard: [qf-] → [qf-], [wptsync upstream]

Backed out for marionette failures on test_refresh_firefox.py

backout: https://hg.mozilla.org/integration/autoland/rev/8ede6180a0d054f3bca8957c6bcd26d5339eeedb

push: https://treeherder.mozilla.org/#/jobs?repo=autoland&searchStr=marionette&revision=eb8e5411868e37d47035e41bd6b68a1df85bb8ab&selectedTaskRun=DZFxQADFQ92B74ZOyv_6Aw.0

failure log: https://treeherder.mozilla.org/logviewer.html#/jobs?job_id=313354842&repo=autoland&lineNumber=62370

[task 2020-08-18T20:28:00.139Z] 20:28:00 INFO - 1597782480133 Marionette DEBUG 3 <- [1,16,null,{"value":null}]
[task 2020-08-18T20:28:00.140Z] 20:28:00 ERROR - TEST-UNEXPECTED-ERROR | browser/components/migration/tests/marionette/test_refresh_firefox.py TestFirefoxRefresh.testFxANoSync | KeyError: 'keyFetchToken'
[task 2020-08-18T20:28:00.140Z] 20:28:00 INFO - Traceback (most recent call last):
[task 2020-08-18T20:28:00.140Z] 20:28:00 INFO - File "Z:\task_1597781383\build\venv\lib\site-packages\marionette_harness\marionette_test\testcases.py", line 196, in run
[task 2020-08-18T20:28:00.140Z] 20:28:00 INFO - testMethod()
[task 2020-08-18T20:28:00.141Z] 20:28:00 INFO - File "Z:\task_1597781383\build\tests\marionette\tests\browser\components\migration\tests\marionette\test_refresh_firefox.py", line 609, in testFxANoSync
[task 2020-08-18T20:28:00.141Z] 20:28:00 INFO - self.checkFxA()
[task 2020-08-18T20:28:00.141Z] 20:28:00 INFO - File "Z:\task_1597781383\build\tests\marionette\tests\browser\components\migration\tests\marionette\test_refresh_firefox.py", line 423, in checkFxA
[task 2020-08-18T20:28:00.141Z] 20:28:00 INFO - self.assertEqual(result["accountData"]["keyFetchToken"], "top-secret")
[task 2020-08-18T20:28:00.141Z] 20:28:00 INFO - TEST-INFO took 15656ms
[task 2020-08-18T20:28:00.149Z] 20:28:00 INFO - 1597782480138 Marionette DEBUG 3 -> [0,17,"Marionette:GetContext",{}]
[task 2020-08-18T20:28:00.149Z] 20:28:00 INFO - 1597782480138 Marionette DEBUG 3 <- [1,17,null,{"value":"chrome"}]
[task 2020-08-18T20:28:00.149Z] 20:28:00 INFO - 1597782480140 Marionette DEBUG 3 -> [0,18,"WebDriver:DeleteSession",{}]
[task 2020-08-18T20:28:00.150Z] 20:28:00 INFO - 1597782480142 Marionette DEBUG 3 <- [1,18,null,{"value":null}]
[task 2020-08-18T20:28:00.165Z] 20:28:00 INFO - Exiting due to channel error.
[task 2020-08-18T20:28:00.180Z] 20:28:00 INFO - [GFX1-]: Receive IPC close with reason=AbnormalShutdown
[task 2020-08-18T20:28:00.180Z] 20:28:00 INFO - Exiting due to channel error.

Flags: needinfo?(sefeng)
Upstream PR merged by moz-wptsync-bot
Pushed by sefeng@mozilla.com: https://hg.mozilla.org/integration/autoland/rev/b90cf6b54c09 Implement PerformancePaintTiming for FirstContentfulPaint r=smaug,mstange https://hg.mozilla.org/integration/autoland/rev/10f07ca7a246 Refactor some performance.getEntries related tests r=mstange https://hg.mozilla.org/integration/autoland/rev/2203a9c52afa Change the status of paint timing WPT tests r=mstange https://hg.mozilla.org/integration/autoland/rev/1bf0b02bb0e0 Enable fcp only PerformancePaintTming tests r=mstange https://hg.mozilla.org/integration/autoland/rev/e62cd63e3595 Update fcp-only tests to load image into memory first r=mstange https://hg.mozilla.org/integration/autoland/rev/10bf1552e301 Add a WPT test to make sure FCP works for iframes r=mstange

Our current code consider gradient-only backgrounds
as contentful, however they aren't contentful according
to the latest spec.

Attachment #9172058 - Attachment description: Bug 1518999 - Use a contentful gif for android scrolling test r=snorp → Bug 1518999 - Trick contentful detection in some geckoview tests
Pushed by sefeng@mozilla.com: https://hg.mozilla.org/integration/autoland/rev/ef494065b8e2 Implement PerformancePaintTiming for FirstContentfulPaint r=smaug,mstange https://hg.mozilla.org/integration/autoland/rev/9f01755d327f Refactor some performance.getEntries related tests r=mstange https://hg.mozilla.org/integration/autoland/rev/9836adcc4e83 Change the status of paint timing WPT tests r=mstange https://hg.mozilla.org/integration/autoland/rev/c9d88f3f1f5b Enable fcp only PerformancePaintTming tests r=mstange https://hg.mozilla.org/integration/autoland/rev/e28081d16e3c Update fcp-only tests to load image into memory first r=mstange https://hg.mozilla.org/integration/autoland/rev/a9715e73e862 Add a WPT test to make sure FCP works for iframes r=mstange https://hg.mozilla.org/integration/autoland/rev/d93cb254eef5 Trick contentful detection in some geckoview tests r=snorp,geckoview-reviewers,agi

Browsertime failures are caused by https://github.com/sitespeedio/browsertime/pull/1347. Will need to wait a bit for it gets fixed.

Flags: needinfo?(sefeng)

I want to take this opportunity to discuss whether we should stick with timeToContentfulPaint or switch to first-contentful-paint for browsertime after the patches are landed.

A brief background is first-contentful-paint is what this bug introduced, it's exposed to the web publicly and this is the timestamp during displayList building about when we found a contentful frame. timeToContentfulPaint is behind a pref (default is false) and this is the timestamp in the compositor level about when we composited the transactions.

If we want to stick with timeToContentful, we need to make a slight modification to https://searchfox.org/mozilla-central/rev/d54712b9644b49cec6cc90a9e0c325fdfab04e7c/testing/raptor/raptor/results.py#506-510, otherwise raptor will start to use first-contentful-paint automatically which may provide some unexpected numbers.

The reason for making them separate is because we don't want to expose accurate timestamps to the web which may inferences the complexity of the content.

Using timeToContentful is better because it's more accurate to when the frame is presented on the screen.

If we can agree on using timeToContentful, I can make the patch to fix raptor.

Thoughts sparky, Andrew?

Flags: needinfo?(gmierz2)
Flags: needinfo?(acreskey)

(In reply to Sean Feng [:sefeng] from comment #24)

The reason for making them separate is because we don't want to expose accurate timestamps to the web which may inferences the complexity of the content.

Hi Sean. I don't understand exactly why timeToContentfulPaint is disabled by default.
It's not a privacy issue, right?
Does it have a negative performance impact?

Note that by the spec, the timestamp should represent the time when "Update the rendering" occurs: https://html.spec.whatwg.org/#update-the-rendering, section 14, and not a time representing a subsequent internal operation.

This is equivalent to timing in IntersectionObservers... So when the first contentful element appears on the page, it will trigger the IntersectionObserver and the paint timing API with the exact same timestamp.

That's also what is done in WebKit.

... This was done to avoid exposing internal timestamps to the web, which can lead to all kinds of interesting timing-attacks.
For interpoerability, I would suggest to either conform to that or discuss here: https://github.com/w3c/paint-timing/issues/62

(In reply to Noam Rosenthal from comment #27)

... This was done to avoid exposing internal timestamps to the web, which can lead to all kinds of interesting timing-attacks.
For interpoerability, I would suggest to either conform to that or discuss here: https://github.com/w3c/paint-timing/issues/62

So that sounds fine from the point of view of spec compliance and interop, though at least for the purposes of intersection observer and so on that seems a bit silly as one can get the high resolution timestamp anyways via performance.now(), right? What am I missing there?

Flags: needinfo?(noam.j.rosenthal)

(In reply to Emilio Cobos Álvarez (:emilio) from comment #28)

(In reply to Noam Rosenthal from comment #27)

... This was done to avoid exposing internal timestamps to the web, which can lead to all kinds of interesting timing-attacks.
For interpoerability, I would suggest to either conform to that or discuss here: https://github.com/w3c/paint-timing/issues/62

So that sounds fine from the point of view of spec compliance and interop, though at least for the purposes of intersection observer and so on that seems a bit silly as one can get the high resolution timestamp anyways via performance.now(), right? What am I missing there?

You can only get the hires timestamp when you're in the JS event loop, but not between internal browser operations.
What I meant about intersection observers, is that conceptually they should have the same timestamp as paint timing - as the elements "intersect" for the user when they're painted.

Keeping all these timestamps aligned with the standard "update the rendering" phase is not of huge importance but makes it possible to inform the developer what the timestamp stands for in a transparent and interoperable way

Flags: needinfo?(noam.j.rosenthal)

Sean (and Greg can correct me if I'm wrong), I believe that those raptor tests will be replaced by Browsertime tests.

If the difference is small (which it was in the case that I saw), I can see the advantage of having the timestamps aligned and using first-contentful-paint.

Flags: needinfo?(acreskey)

If the difference is small (which it was in the case that I saw), I can see the advantage of having the timestamps aligned and using first-contentful-paint.

Thanks, Andrew, sounds good. I'll run some browsertime tests to more sites so that we can be confident here.

Keeping all these timestamps aligned with the standard "update the rendering" phase is not of huge importance but makes it possible to inform the developer what the timestamp stands for in a transparent and interoperable way

Thanks, Noam, and yeah agreed, I am making the change to conform that, so we will return the same time as IntersectionObservers.

Flags: needinfo?(gmierz2)

The part that :sefeng points to will be staying after the migration since it parses the results from the browsertime.json files.

As long as the difference between what we have now and what we will have is a systemic error (or negligible) across all test pages then I don't see an issue with these changes.

Attachment #9174502 - Attachment description: Bug 1518999 - Notify ContentfulPaint during update the rendering steps r=emilio → Bug 1518999 - Update ContentfulPaint algorithm to follow the spec r=emilio

I did a smoke browsertime runs to see the differences between FCP and timeToContentfulPaint. Link

Most of the sites report a 2-5% difference, some of the highest are like a 9% difference. Although the samples are small, I'd still assume that a 3% - 5% improvement to FCP is going to appear in our test result once we land the FCP patches. The 9% ones look odd though, maybe it indicates a performance issue that we can improve, the performance between displayList building to the actual paints.

To avoid confusion, I think we should also rename timeToContentfulPaint to first-contentful-composite; this will make the difference clearer. So then the question of which one we should use in browsertime really comes down to the following question: Do we want capture improvements and regressions in the graphics pipeline in the browsertime tests? If we do, then we need to use first-contentful-composite.
Or we could capture both timestamps: first-contentful-paint for comparison with Chrome, and first-contentful-composite as a Firefox-specific value to optimize against.

Bump the browsertime hash to add a fix from upstream which fixes a
firstPaint related bug when FCP is supported.

Since this bug, Firefox will start to use the same conversion as
Chrome for reporting FCP. This patch cleans our code a little bit
to adapt that.

Depends on D90108

I agree with what Markus said. I think renaming timeToContentfulPaint to first-contentful-composite, capturing both to use first-contentful-paint to compare with Chrome and keep first-contentful-composite as a Firefox-specific value for optimization is a good idea.

Pushed by sefeng@mozilla.com: https://hg.mozilla.org/integration/autoland/rev/c3bb552e76a3 Implement PerformancePaintTiming for FirstContentfulPaint r=smaug,mstange https://hg.mozilla.org/integration/autoland/rev/5a6cea5fd344 Update ContentfulPaint algorithm to follow the spec r=emilio https://hg.mozilla.org/integration/autoland/rev/13a4c749a802 Refactor some performance.getEntries related tests r=mstange https://hg.mozilla.org/integration/autoland/rev/f21b13582dad Change the status of paint timing WPT tests r=mstange https://hg.mozilla.org/integration/autoland/rev/972731762965 Enable fcp only PerformancePaintTming tests r=mstange https://hg.mozilla.org/integration/autoland/rev/3d4d84003227 Update fcp-only tests to load image into memory first r=mstange https://hg.mozilla.org/integration/autoland/rev/2a2d67ba15b8 Add a WPT test to make sure FCP works for iframes r=mstange https://hg.mozilla.org/integration/autoland/rev/c13e51e17329 Trick contentful detection in some geckoview tests r=snorp,geckoview-reviewers,agi https://hg.mozilla.org/integration/autoland/rev/401e488734dd Bump the browsertime hash to 8bf45e80ccc65237c622246b11c0739f0409e8e4 r=sparky,perftest-reviewers https://hg.mozilla.org/integration/autoland/rev/7b5bdd071d05 Use the same conversion for Chrome and Firefox for FCP r=sparky,perftest-reviewers
Created web-platform-tests PR https://github.com/web-platform-tests/wpt/pull/25578 for changes under testing/web-platform/tests

Initial commit alert:
== Change summary for alert #27073 (as of Mon, 28 Sep 2020 06:18:11 GMT) ==

Improvements:

4% espn fcp android-hw-g5-7-0-arm7-api-16-shippable opt warm 3,451.19 -> 3,299.62
4% espn fcp android-hw-g5-7-0-arm7-api-16-shippable opt warm 3,508.47 -> 3,374.33
3% google-maps FirstVisualChange android-hw-g5-7-0-arm7-api-16-shippable opt cold 1,119.12 -> 1,083.08
3% google-maps SpeedIndex android-hw-g5-7-0-arm7-api-16-shippable opt cold 1,203.33 -> 1,164.92
3% espn FirstVisualChange android-hw-g5-7-0-arm7-api-16-shippable opt warm 3,522.42 -> 3,416.58
3% espn ContentfulSpeedIndex android-hw-g5-7-0-arm7-api-16-shippable opt warm 3,536.85 -> 3,432.25
3% google-maps PerceptualSpeedIndex android-hw-g5-7-0-arm7-api-16-shippable opt cold 1,203.92 -> 1,168.42
3% google-maps android-hw-g5-7-0-arm7-api-16-shippable opt warm 967.32 -> 940.49
3% instagram loadtime android-hw-g5-7-0-arm7-api-16-shippable opt warm 2,763.48 -> 2,688.79
3% instagram SpeedIndex android-hw-g5-7-0-arm7-api-16-shippable opt warm 2,577.35 -> 2,512.58
2% instagram PerceptualSpeedIndex android-hw-g5-7-0-arm7-api-16-shippable opt warm 1,487.05 -> 1,455.58
2% instagram LastVisualChange android-hw-g5-7-0-arm7-api-16-shippable opt warm 2,807.70 -> 2,749.17

For up to date results, see: https://treeherder.mozilla.org/perf.html#/alerts?id=27073

Keywords: perf-alert
Depends on: 1669239
Upstream PR was closed without merging
Attachment #9136918 - Attachment is obsolete: true
Attachment #9168595 - Attachment is obsolete: true
Attachment #9136473 - Attachment description: Bug 1518999 - Enable fcp only PerformancePaintTming tests → Bug 1518999 - Enable fcp only PerformancePaintTming tests r=mstange
Pushed by sefeng@mozilla.com: https://hg.mozilla.org/integration/autoland/rev/e8ba13ee17f5 Implement PerformancePaintTiming for FirstContentfulPaint r=smaug,mstange https://hg.mozilla.org/integration/autoland/rev/8ac8461d7bd7 Update ContentfulPaint algorithm to follow the spec r=emilio https://hg.mozilla.org/integration/autoland/rev/4bb80556158d Refactor some performance.getEntries related tests r=mstange https://hg.mozilla.org/integration/autoland/rev/65f07ce7b39b Change the status of paint timing WPT tests r=mstange https://hg.mozilla.org/integration/autoland/rev/575748295752 Enable fcp only PerformancePaintTming tests r=mstange https://hg.mozilla.org/integration/autoland/rev/8b2ac5a6c98a Trick contentful detection in some geckoview tests r=snorp,geckoview-reviewers,agi https://hg.mozilla.org/integration/autoland/rev/13e6b92440e9 Bump the browsertime hash to 8bf45e80ccc65237c622246b11c0739f0409e8e4 r=sparky,perftest-reviewers https://hg.mozilla.org/integration/autoland/rev/807893ca8069 Use the same conversion for Chrome and Firefox for FCP r=sparky,perftest-reviewers
Upstream PR was closed without merging

Sorry about missing another junit failure. I think I found the issue and quite confident that I should get everything covered this time. Try push.

Will try to land the patches again on Monday.

Flags: needinfo?(sefeng)
Pushed by sefeng@mozilla.com: https://hg.mozilla.org/integration/autoland/rev/3fbb53f6d6ef Implement PerformancePaintTiming for FirstContentfulPaint r=smaug,mstange https://hg.mozilla.org/integration/autoland/rev/47629f89cb6a Update ContentfulPaint algorithm to follow the spec r=emilio https://hg.mozilla.org/integration/autoland/rev/18977625f8a4 Refactor some performance.getEntries related tests r=mstange https://hg.mozilla.org/integration/autoland/rev/434cacd927bf Change the status of paint timing WPT tests r=mstange https://hg.mozilla.org/integration/autoland/rev/b61d813af80d Enable fcp only PerformancePaintTming tests r=mstange https://hg.mozilla.org/integration/autoland/rev/0af7c44c8e72 Trick contentful detection in some geckoview tests r=snorp,geckoview-reviewers,agi https://hg.mozilla.org/integration/autoland/rev/412e72819153 Bump the browsertime hash to 8bf45e80ccc65237c622246b11c0739f0409e8e4 r=sparky,perftest-reviewers https://hg.mozilla.org/integration/autoland/rev/ea8ed7d8298a Use the same conversion for Chrome and Firefox for FCP r=sparky,perftest-reviewers
Pushed by malexandru@mozilla.com: https://hg.mozilla.org/integration/autoland/rev/00cc34581b34 Fix python black lint failures in webidl/moz.build and performance/moz.build
Blocks: 1674349
Regressions: 1673848

== Change summary for alert #27482 (as of Tue, 03 Nov 2020 06:07:29 GMT) ==

Improvements:

Ratio Suite Test Platform Options Absolute values (old vs new)
16% youtube fcp android-hw-g5-7-0-arm7-api-16-shippable warm 906.58 -> 762.88
16% instagram fcp android-hw-g5-7-0-arm7-api-16-shippable warm 358.10 -> 301.62
15% instagram fcp android-hw-g5-7-0-arm7-api-16-shippable cold 459.19 -> 389.46
13% youtube fcp android-hw-g5-7-0-arm7-api-16-shippable cold 1,245.27 -> 1,088.21
11% youtube fcp android-hw-g5-7-0-arm7-api-16-shippable cold 1,240.33 -> 1,098.25
6% youtube android-hw-g5-7-0-arm7-api-16-shippable warm 694.03 -> 652.98
5% instagram android-hw-g5-7-0-arm7-api-16-shippable warm 645.54 -> 610.41
5% instagram android-hw-g5-7-0-arm7-api-16-shippable cold 820.02 -> 783.07

For up to date results, see: https://treeherder.mozilla.org/perfherder/alerts?id=27482

Regressions: 1674973

Adding dev-doc-needed.

For whoever documents this — the PerformancePaintTiming interface is already documented, I believe this just requires the docs to be checked, and BCD to be updated to include Fx/FxA support information when the time comes.

Keywords: dev-doc-needed
No longer regressions: 1675543
Blocks: 1675640
Regressions: 1673844

Looks like the docs for this are pretty much done.

See https://github.com/mdn/sprints/issues/3900 for the full details.

Regressions: 1728688
No longer regressions: 1728688
Performance Impact: --- → -
Whiteboard: [qf-], [wptsync upstream] → , [wptsync upstream]
You need to log in before you can comment on or make changes to this bug.

Attachment

General

Created:
Updated:
Size: