// META: script=../../constants.sub.js
// META: script=resources/url-constants.js
// META: global=window,worker
// META: timeout=long
// META: variant=?wss
// META: variant=?wpt_flags=h2
// Allow for this much timer jitter.
const JITTER_ALLOWANCE_MS = 200;
const LARGE_MESSAGE_COUNT = 16;
// This test works by using a server WebSocket handler which sends a large
// message, and then sends a second message with the time it measured the first
// message taking. On the browser side, we wait 2 seconds before reading from
// the socket. This should ensure it takes at least 2 seconds to finish sending
// the large message.
promise_test(async t => {
const wss = new WebSocketStream(`${BASEURL}/send-backpressure`);
const { readable } = await wss.opened;
const reader = readable.getReader();
// Create backpressure for 2 seconds.
await new Promise(resolve => t.step_timeout(resolve, 2000));
// Skip the empty message used to fill the readable queue.
await reader.read();
// Skip the large messages.
for (let i = 0; i < LARGE_MESSAGE_COUNT; ++i) {
await reader.read();
}
// Read the time it took.
const { value, done } = await reader.read();
// A browser can pass this test simply by being slow. This may be a source of
// flakiness for browsers that do not implement backpressure properly.
assert_greater_than_equal(Number(value), 2 - JITTER_ALLOWANCE_MS / 1000,
'data send should have taken at least 2 seconds');
}, 'backpressure should be applied to received messages');