blob: 3c64e590c44728b75a68c852ee9967a3da36ceef (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
|
// META: title=MediaStreamTrackProcessor maxBufferSize
importScripts("/resources/testharness.js");
function makeVideoFrame(timestamp) {
const canvas = new OffscreenCanvas(100, 100);
const ctx = canvas.getContext('2d');
return new VideoFrame(canvas, {timestamp});
}
promise_test(async t => {
// The generator will be used as the source for the processor to
// produce frames in a controlled manner.
const generator = new VideoTrackGenerator();
t.add_cleanup(() => generator.track.stop());
// Use a larger maxBufferSize than the default to ensure no frames
// will be dropped.
const processor = new MediaStreamTrackProcessor({track: generator.track, maxBufferSize:10});
const reader = processor.readable.getReader();
const writer = generator.writable.getWriter();
let numReads = 0;
let resolve = null;
const promise = new Promise(r => resolve = r);
const numOperations = 4;
// Issue reads without waiting for the frames to arrive.
for (let i = 0; i < numOperations; i++) {
reader.read().then(dv=> {
dv.value.close();
if (++numReads == numOperations)
resolve();
});
}
// Write video frames in different tasks to "slowly" settle the pending read
// requests.
for (let i = 0; i<numOperations; i++) {
await writer.write(makeVideoFrame(i));
await new Promise(r=>t.step_timeout(r, 0));
}
return promise;
}, "Tests that multiple read requests are eventually settled");
promise_test(async t => {
// The generator will be used as the source for the processor to
// produce frames in a controlled manner.
const generator = new VideoTrackGenerator();
t.add_cleanup(() => generator.track.stop());
// Use a larger maxBufferSize than the default to ensure no frames
// will be dropped.
const processor = new MediaStreamTrackProcessor({track: generator.track, maxBufferSize:10});
const reader = processor.readable.getReader();
const writer = generator.writable.getWriter();
const numOperations = 4;
// Write video frames as fast as we can with "slower" reads.
// requests.
for (let i = 0; i<numOperations; i++) {
await writer.write(makeVideoFrame(i));
}
let numReads = 0;
let resolve = null;
const promise = new Promise(r => resolve = r);
// Issue reads without waiting for the frames to arrive.
for (let i = 0; i < numOperations; i++) {
await new Promise(r=>t.step_timeout(r, 50));
reader.read().then(dv=> {
dv.value.close();
if (++numReads == numOperations)
resolve();
});
}
return promise;
}, "Tests that multiple write requests are buffered");
done();
|