You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Where /alwayserror is an endpoint which returns an error status code and a response body containing one byte.
In Blink, WebKit and Gecko, they produce a resource timing entry, but they all have a race condition of when it becomes available. In my testing on macOS 15.3.1:
For WebKit, it's a coin flip if the resource timing entry is available in the promise job reaction for the second then
For Gecko, I had to wait until at least the next task (e.g. a setTimeout(() => {}, 0) for the entry to be available.
In Blink, I had to wait for at least a 51ms timeout for the resource entry to start appearing, but it's hit and miss if it's available at that timeout.
Reading the body to the end (e.g. removing the if (!resp.ok) path in the above example) produces a resource timing entry straight away in all three, available in the second then callback.
On the live web, this is encountered by Cloudflare Turnstile.
This is caused by processResponseEndOfBody being called as the flush algorithm when reading the body through a TransformStream in fetch response handover. If the end of the stream is not reached, flushAlgorithm is not called, and thus a resource timing entry is not created.
The text was updated successfully, but these errors were encountered:
What is the issue with the Fetch Standard?
For example, the given code will not produce a resource timing entry:
Where
/alwayserror
is an endpoint which returns an error status code and a response body containing one byte.In Blink, WebKit and Gecko, they produce a resource timing entry, but they all have a race condition of when it becomes available. In my testing on macOS 15.3.1:
then
setTimeout(() => {}, 0
) for the entry to be available.if (!resp.ok)
path in the above example) produces a resource timing entry straight away in all three, available in the secondthen
callback.On the live web, this is encountered by Cloudflare Turnstile.
This is caused by
processResponseEndOfBody
being called as the flush algorithm when reading the body through a TransformStream in fetch response handover. If the end of the stream is not reached, flushAlgorithm is not called, and thus a resource timing entry is not created.The text was updated successfully, but these errors were encountered: