Commit 76407e18 authored by Guido Urdaneta's avatar Guido Urdaneta Committed by Commit Bot

[RTCInsertableStreams] Add test for video frame type

This test verifies that both key and delta frames are sent
and received.

Bug: 1068468
Change-Id: Idef4a4769de436504eef0e3e1709f6b6f7787a37
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/2142266Reviewed-by: default avatarHarald Alvestrand <hta@chromium.org>
Commit-Queue: Guido Urdaneta <guidou@chromium.org>
Cr-Commit-Position: refs/heads/master@{#757557}
parent 6c9a955f
......@@ -285,6 +285,66 @@ promise_test(t => {
return testNormalDataFlowWithInsertableStreamsForOtherKind(t, 'video');
}, 'Video flows when insertable streams is enabled for audio and disabled for audio.');
promise_test(async t => {
const caller = new RTCPeerConnection({forceEncodedVideoInsertableStreams:true});
t.add_cleanup(() => caller.close());
const callee = new RTCPeerConnection({forceEncodedVideoInsertableStreams:true});
t.add_cleanup(() => callee.close());
const stream = await navigator.mediaDevices.getUserMedia({video:true});
const track = stream.getTracks()[0];
t.add_cleanup(() => track.stop());
const sender = caller.addTrack(track)
const senderStreams = sender.createEncodedVideoStreams();
const senderReader = senderStreams.readableStream.getReader();
const senderWriter = senderStreams.writableStream.getWriter();
const numFramesToSend = 20;
const ontrackPromise = new Promise((resolve, reject) => {
callee.ontrack = async e => {
const receiverStreams = e.receiver.createEncodedVideoStreams();
const receiverReader = receiverStreams.readableStream.getReader();
let numReceivedKeyFrames = 0;
let numReceivedDeltaFrames = 0;
for (let i = 0; i < numFramesToSend; i++) {
const result = await receiverReader.read();
if (result.value.type == 'key')
numReceivedKeyFrames++;
else if (result.value.type == 'delta')
numReceivedDeltaFrames++;
if (numReceivedKeyFrames > 0 && numReceivedDeltaFrames > 0)
resolve();
else if (numReceivedKeyFrames + numReceivedDeltaFrames >= numFramesToSend)
reject();
}
}
});
exchangeIceCandidates(caller, callee);
await doSignalingHandshake(caller, callee);
let numSentKeyFrames = 0;
let numSentDeltaFrames = 0;
// Pass frames as they come from the encoder.
for (let i = 0; i < numFramesToSend; i++) {
const result = await senderReader.read()
if (result.value.type == 'key')
numSentKeyFrames++;
else
numSentDeltaFrames++;
senderWriter.write(result.value);
}
assert_greater_than(numSentKeyFrames, 0);
assert_greater_than(numSentDeltaFrames, 0);
return ontrackPromise;
}, 'Key and Delta frames are sent and received');
</script>
</body>
</html>
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment