SimpleTest.waitForExplicitFinish();
// We fill up the source buffer with audio data until the buffer is full.
// We ensure that QuotaExceededError is thrown once the buffer is full.
// We then seek to half the content. By that time, another appendBuffer must succeed
// as the auto-eviction would succeed (removing all data prior currentTime)
await must_reject(async () => {
// We are appending data repeatedly in sequence mode, there should be no gaps.
while (true) {
ok(audiosb.buffered.length <= 1, "there should be no gap in buffered ranges.");
audiosb.appendBuffer(audioBuffer);
await once(audiosb, "updateend");
}
}, "Fill up SourceBuffer by appending data until an exception is thrown.", "QuotaExceededError");
is(audiosb.buffered.end(0), el.duration, "Duration is end of buffered range");
const seekTime = audiosb.buffered.end(0) / 2;
el.currentTime = seekTime;
await once(el, "seeked");
dump("dump: seeked to " + seekTime);
is(el.currentTime, seekTime, "correctly seeked to " + seekTime);
try {
audiosb.appendBuffer(audioBuffer);
await once(audiosb, "update");
ok(true, "appendBuffer succeeded");
} catch (ex) {
ok(false, "Shouldn't throw another time when data can be evicted");
dump(JSON.stringify(await SpecialPowers.wrap(el).mozRequestDebugInfo()));
}
SimpleTest.finish();
});
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.