123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333 |
- import Ranges from '../src/ranges';
- import {createTimeRanges} from 'video.js';
- import QUnit from 'qunit';
- let rangesEqual = (rangeOne, rangeTwo) => {
- if (!rangeOne || !rangeTwo) {
- return false;
- }
- if (rangeOne.length !== rangeTwo.length) {
- return false;
- }
- for (let i = 0; i < rangeOne.length; i++) {
- if (rangeOne.start(i) !== rangeTwo.start(i) ||
- rangeOne.end(i) !== rangeTwo.end(i)) {
- return false;
- }
- }
- return true;
- };
- QUnit.module('TimeRanges Utilities');
- QUnit.test('finds the overlapping time range', function(assert) {
- let range = Ranges.findRange(createTimeRanges([[0, 5], [6, 12]]), 3);
- assert.equal(range.length, 1, 'found one range');
- assert.equal(range.end(0), 5, 'inside the first buffered region');
- range = Ranges.findRange(createTimeRanges([[0, 5], [6, 12]]), 6);
- assert.equal(range.length, 1, 'found one range');
- assert.equal(range.end(0), 12, 'inside the second buffered region');
- });
- QUnit.module('Buffer Inpsection');
- QUnit.test('detects time range end-point changed by updates', function(assert) {
- let edge;
- // Single-range changes
- edge = Ranges.findSoleUncommonTimeRangesEnd(createTimeRanges([[0, 10]]),
- createTimeRanges([[0, 11]]));
- assert.strictEqual(edge, 11, 'detected a forward addition');
- edge = Ranges.findSoleUncommonTimeRangesEnd(createTimeRanges([[5, 10]]),
- createTimeRanges([[0, 10]]));
- assert.strictEqual(edge, null, 'ignores backward addition');
- edge = Ranges.findSoleUncommonTimeRangesEnd(createTimeRanges([[5, 10]]),
- createTimeRanges([[0, 11]]));
- assert.strictEqual(edge, 11,
- 'detected a forward addition & ignores a backward addition');
- edge = Ranges.findSoleUncommonTimeRangesEnd(createTimeRanges([[0, 10]]),
- createTimeRanges([[0, 9]]));
- assert.strictEqual(edge, null,
- 'ignores a backwards addition resulting from a shrinking range');
- edge = Ranges.findSoleUncommonTimeRangesEnd(createTimeRanges([[0, 10]]),
- createTimeRanges([[2, 7]]));
- assert.strictEqual(edge, null,
- 'ignores a forward & backwards addition resulting from a shrinking ' +
- 'range');
- edge = Ranges.findSoleUncommonTimeRangesEnd(createTimeRanges([[2, 10]]),
- createTimeRanges([[0, 7]]));
- assert.strictEqual(
- edge,
- null,
- 'ignores a forward & backwards addition resulting from a range shifted backward'
- );
- edge = Ranges.findSoleUncommonTimeRangesEnd(createTimeRanges([[2, 10]]),
- createTimeRanges([[5, 15]]));
- assert.strictEqual(edge, 15,
- 'detected a forwards addition resulting from a range shifted foward');
- // Multiple-range changes
- edge = Ranges.findSoleUncommonTimeRangesEnd(createTimeRanges([[0, 10]]),
- createTimeRanges([[0, 11], [12, 15]]));
- assert.strictEqual(edge, null, 'ignores multiple new forward additions');
- edge = Ranges.findSoleUncommonTimeRangesEnd(createTimeRanges([[0, 10], [20, 40]]),
- createTimeRanges([[20, 50]]));
- assert.strictEqual(edge, 50, 'detected a forward addition & ignores range removal');
- edge = Ranges.findSoleUncommonTimeRangesEnd(createTimeRanges([[0, 10], [20, 40]]),
- createTimeRanges([[0, 50]]));
- assert.strictEqual(edge, 50, 'detected a forward addition & ignores merges');
- edge = Ranges.findSoleUncommonTimeRangesEnd(createTimeRanges([[0, 10], [20, 40]]),
- createTimeRanges([[0, 40]]));
- assert.strictEqual(edge, null, 'ignores merges');
- // Empty input
- edge = Ranges.findSoleUncommonTimeRangesEnd(createTimeRanges(),
- createTimeRanges([[0, 11]]));
- assert.strictEqual(edge, 11, 'handle an empty original TimeRanges object');
- edge = Ranges.findSoleUncommonTimeRangesEnd(createTimeRanges([[0, 11]]),
- createTimeRanges());
- assert.strictEqual(edge, null, 'handle an empty update TimeRanges object');
- // Null input
- edge = Ranges.findSoleUncommonTimeRangesEnd(null, createTimeRanges([[0, 11]]));
- assert.strictEqual(edge,
- 11,
- 'treat null original buffer as an empty TimeRanges object');
- edge = Ranges.findSoleUncommonTimeRangesEnd(createTimeRanges([[0, 11]]), null);
- assert.strictEqual(edge,
- null,
- 'treat null update buffer as an empty TimeRanges object');
- });
- QUnit.test('properly calculates time left until player rebuffers', function(assert) {
- let buffered = createTimeRanges([]);
- let currentTime = 0;
- let playbackRate = 1;
- let time = Ranges.timeUntilRebuffer(buffered, currentTime, playbackRate);
- assert.equal(time, 0, 'calculates no time until rebuffer with empty buffer');
- buffered = createTimeRanges([[0, 30]]);
- currentTime = 15;
- time = Ranges.timeUntilRebuffer(buffered, currentTime, playbackRate);
- assert.equal(time, 15, 'calculates time until rebuffer');
- playbackRate = 0.5;
- time = Ranges.timeUntilRebuffer(buffered, currentTime, playbackRate);
- assert.equal(time, 30, 'takes into account playback rate');
- });
- QUnit.module('Segment Percent Buffered Calculations');
- QUnit.test('calculates the percent buffered for segments in the simple case',
- function(assert) {
- let segmentStart = 10;
- let segmentDuration = 10;
- let currentTime = 0;
- let buffered = createTimeRanges([[15, 19]]);
- let percentBuffered = Ranges.getSegmentBufferedPercent(
- segmentStart,
- segmentDuration,
- currentTime,
- buffered);
- assert.equal(percentBuffered, 40, 'calculated the buffered amount correctly');
- });
- QUnit.test('consider the buffer before currentTime to be filled if the ' +
- 'segement begins at or before the currentTime', function(assert) {
- let segmentStart = 10;
- let segmentDuration = 10;
- let currentTime = 15;
- let buffered = createTimeRanges([[15, 19]]);
- let percentBuffered = Ranges.getSegmentBufferedPercent(
- segmentStart,
- segmentDuration,
- currentTime,
- buffered);
- assert.equal(percentBuffered, 90, 'calculated the buffered amount correctly');
- });
- QUnit.test('does not consider the buffer before currentTime as filled if the segment ' +
- 'begins after the currentTime', function(assert) {
- let segmentStart = 10;
- let segmentDuration = 10;
- let currentTime = 18;
- let buffered = createTimeRanges([[19, 30]]);
- let percentBuffered = Ranges.getSegmentBufferedPercent(
- segmentStart,
- segmentDuration,
- currentTime,
- buffered);
- assert.equal(percentBuffered, 10, 'calculated the buffered amount correctly');
- });
- QUnit.test('calculates the percent buffered for segments with multiple buffered ' +
- 'regions', function(assert) {
- let segmentStart = 10;
- let segmentDuration = 10;
- let currentTime = 0;
- let buffered = createTimeRanges([[0, 11], [12, 19]]);
- let percentBuffered = Ranges.getSegmentBufferedPercent(
- segmentStart,
- segmentDuration,
- currentTime,
- buffered);
- assert.equal(percentBuffered, 80, 'calculated the buffered amount correctly');
- });
- QUnit.test('calculates the percent buffered for segments with multiple buffered ' +
- 'regions taking into account currentTime', function(assert) {
- let segmentStart = 10;
- let segmentDuration = 10;
- let currentTime = 12;
- let buffered = createTimeRanges([[0, 11], [12, 19]]);
- let percentBuffered = Ranges.getSegmentBufferedPercent(
- segmentStart,
- segmentDuration,
- currentTime,
- buffered);
- assert.equal(percentBuffered, 90, 'calculated the buffered amount correctly');
- });
- QUnit.test('calculates the percent buffered as 0 for zero-length segments',
- function(assert) {
- let segmentStart = 10;
- let segmentDuration = 0;
- let currentTime = 0;
- let buffered = createTimeRanges([[0, 19]]);
- let percentBuffered = Ranges.getSegmentBufferedPercent(
- segmentStart,
- segmentDuration,
- currentTime,
- buffered);
- assert.equal(percentBuffered, 0, 'calculated the buffered amount correctly');
- });
- QUnit.test('calculates the percent buffered as 0 for segments that do not overlap ' +
- 'buffered regions taking into account currentTime', function(assert) {
- let segmentStart = 10;
- let segmentDuration = 10;
- let currentTime = 19;
- let buffered = createTimeRanges([[20, 30]]);
- let percentBuffered = Ranges.getSegmentBufferedPercent(
- segmentStart,
- segmentDuration,
- currentTime,
- buffered);
- assert.equal(percentBuffered, 0, 'calculated the buffered amount correctly');
- });
- QUnit.test('calculates the percent buffered for segments ' +
- 'that end before currentTime', function(assert) {
- let segmentStart = 10;
- let segmentDuration = 10;
- let currentTime = 19.6;
- let buffered = createTimeRanges([[0, 19.5]]);
- let percentBuffered = Ranges.getSegmentBufferedPercent(
- segmentStart,
- segmentDuration,
- currentTime,
- buffered);
- assert.equal(percentBuffered, 95, 'calculated the buffered amount correctly');
- });
- QUnit.test('finds next range', function(assert) {
- assert.equal(Ranges.findNextRange(createTimeRanges(), 10).length,
- 0,
- 'does not find next range in empty buffer');
- assert.equal(Ranges.findNextRange(createTimeRanges([[0, 20]]), 10).length,
- 0,
- 'does not find next range when no next ranges');
- assert.equal(Ranges.findNextRange(createTimeRanges([[0, 20]]), 30).length,
- 0,
- 'does not find next range when current time later than buffer');
- assert.equal(Ranges.findNextRange(createTimeRanges([[10, 20]]), 10).length,
- 0,
- 'does not find next range when current time is at beginning of buffer');
- assert.equal(Ranges.findNextRange(createTimeRanges([[10, 20]]), 11).length,
- 0,
- 'does not find next range when current time in middle of buffer');
- assert.equal(Ranges.findNextRange(createTimeRanges([[10, 20]]), 20).length,
- 0,
- 'does not find next range when current time is at end of buffer');
- assert.ok(rangesEqual(Ranges.findNextRange(createTimeRanges([[10, 20]]), 0),
- createTimeRanges([[10, 20]])),
- 'finds next range when buffer comes after time');
- assert.ok(rangesEqual(Ranges.findNextRange(createTimeRanges([[10, 20], [25, 35]]), 22),
- createTimeRanges([[25, 35]])),
- 'finds next range when time between buffers');
- assert.ok(rangesEqual(Ranges.findNextRange(createTimeRanges([[10, 20], [25, 35]]), 15),
- createTimeRanges([[25, 35]])),
- 'finds next range when time in previous buffer');
- });
- QUnit.test('finds gaps within ranges', function(assert) {
- assert.equal(Ranges.findGaps(createTimeRanges()).length,
- 0,
- 'does not find gap in empty buffer');
- assert.equal(Ranges.findGaps(createTimeRanges([[0, 10]])).length,
- 0,
- 'does not find gap in single buffer');
- assert.equal(Ranges.findGaps(createTimeRanges([[1, 10]])).length,
- 0,
- 'does not find gap at start of buffer');
- assert.ok(rangesEqual(Ranges.findGaps(createTimeRanges([[0, 10], [11, 20]])),
- createTimeRanges([[10, 11]])),
- 'finds a single gap');
- assert.ok(rangesEqual(Ranges.findGaps(createTimeRanges([[0, 10], [11, 20], [22, 30]])),
- createTimeRanges([[10, 11], [20, 22]])),
- 'finds multiple gaps');
- });
- QUnit.test('creates printable ranges', function(assert) {
- assert.equal(Ranges.printableRange(createTimeRanges()), '', 'empty range empty string');
- assert.equal(Ranges.printableRange(createTimeRanges([[0, 0]])),
- '0 => 0',
- 'formats range correctly');
- assert.equal(Ranges.printableRange(createTimeRanges([[0, 1]])),
- '0 => 1',
- 'formats range correctly');
- assert.equal(Ranges.printableRange(createTimeRanges([[1, -1]])),
- '1 => -1',
- 'formats range correctly');
- assert.equal(Ranges.printableRange(createTimeRanges([[10.2, 25.2]])),
- '10.2 => 25.2',
- 'formats range correctly');
- assert.equal(Ranges.printableRange(createTimeRanges([[10, 20], [30, 40]])),
- '10 => 20, 30 => 40',
- 'formats ranges correctly');
- assert.equal(Ranges.printableRange(createTimeRanges([[10, 25], [20, 40], [-1, -2]])),
- '10 => 25, 20 => 40, -1 => -2',
- 'formats ranges correctly');
- });
|