mirror of
https://github.com/videojs/video.js.git
synced 2024-12-04 10:34:51 +02:00
e9e894ffa0
Some live streams with a 30s live window can actually fluctuate between below and above the 30s threshold we have. Instead, we should have a slightly lower default to have those streams get the liveui.
93 lines
3.3 KiB
JavaScript
93 lines
3.3 KiB
JavaScript
/* eslint-env qunit */
|
|
import TestHelpers from './test-helpers.js';
|
|
import sinon from 'sinon';
|
|
import computedStyle from '../../src/js/utils/computed-style.js';
|
|
import { createTimeRange } from '../../src/js/utils/time-ranges.js';
|
|
|
|
QUnit.module('SeekToLive', {
|
|
beforeEach() {
|
|
this.clock = sinon.useFakeTimers();
|
|
this.player = TestHelpers.makePlayer();
|
|
this.seekToLive = this.player.controlBar.seekToLive;
|
|
this.getComputedDisplay = () => {
|
|
return computedStyle(this.seekToLive.el(), 'display');
|
|
};
|
|
|
|
this.mockLiveui = () => {
|
|
this.player.paused = () => false;
|
|
this.player.hasStarted = () => true;
|
|
this.player.options_.liveui = true;
|
|
this.player.seekable = () => createTimeRange(0, 45);
|
|
this.player.currentTime = () => this.player.liveTracker.liveCurrentTime();
|
|
this.player.duration(Infinity);
|
|
};
|
|
},
|
|
afterEach() {
|
|
this.player.dispose();
|
|
this.clock.restore();
|
|
}
|
|
});
|
|
|
|
QUnit.test('liveui enabled, can switch between at and behind live edge ', function(assert) {
|
|
this.mockLiveui();
|
|
|
|
assert.notEqual(this.getComputedDisplay(), 'none', 'is not hidden');
|
|
assert.ok(this.seekToLive.hasClass('vjs-at-live-edge'), 'has at live edge class');
|
|
|
|
this.player.currentTime = () => 0;
|
|
this.player.seekable = () => createTimeRange(0, 38);
|
|
this.clock.tick(30);
|
|
|
|
assert.notOk(this.seekToLive.hasClass('vjs-at-live-edge'), 'does not have at live edge class');
|
|
});
|
|
|
|
QUnit.test('liveui enabled can show/hide on durationchange', function(assert) {
|
|
// start out non-live
|
|
assert.equal(this.getComputedDisplay(), 'none', 'is hidden');
|
|
assert.notOk(this.seekToLive.hasClass('vjs-at-live-edge'), 'does not have at live edge class');
|
|
|
|
// switch to live
|
|
this.mockLiveui();
|
|
|
|
assert.notEqual(this.getComputedDisplay(), 'none', 'is not hidden');
|
|
assert.ok(this.seekToLive.hasClass('vjs-at-live-edge'), 'has at live edge class');
|
|
|
|
// switch to non-live
|
|
this.player.duration(20);
|
|
|
|
assert.equal(this.getComputedDisplay(), 'none', 'is hidden');
|
|
assert.notOk(this.seekToLive.hasClass('vjs-at-live-edge'), 'does not have at live edge class');
|
|
|
|
// back to live again.
|
|
this.mockLiveui();
|
|
|
|
assert.notEqual(this.getComputedDisplay(), 'none', 'is not hidden');
|
|
assert.ok(this.seekToLive.hasClass('vjs-at-live-edge'), 'has at live edge class');
|
|
});
|
|
|
|
QUnit.test('liveui disabled live window is never shown', function(assert) {
|
|
assert.equal(this.getComputedDisplay(), 'none', 'is hidden');
|
|
assert.notOk(this.seekToLive.hasClass('vjs-at-live-edge'), 'does not have at live edge class');
|
|
|
|
this.player.paused = () => false;
|
|
this.player.hasStarted = () => true;
|
|
this.player.currentTime = () => this.player.liveTracker.liveCurrentTime();
|
|
|
|
// liveui false, seekable range is good though
|
|
this.player.options_.liveui = false;
|
|
this.player.duration(Infinity);
|
|
|
|
assert.equal(this.getComputedDisplay(), 'none', 'is hidden');
|
|
assert.notOk(this.seekToLive.hasClass('vjs-at-live-edge'), 'does not have at live edge class');
|
|
|
|
this.player.duration(10);
|
|
|
|
// liveui false
|
|
this.player.options_.liveui = false;
|
|
this.player.seekable = () => createTimeRange(0, 19);
|
|
this.player.duration(Infinity);
|
|
|
|
assert.equal(this.getComputedDisplay(), 'none', 'is hidden');
|
|
assert.notOk(this.seekToLive.hasClass('vjs-at-live-edge'), 'does not have at live edge class');
|
|
});
|