1
0
mirror of https://github.com/videojs/video.js.git synced 2025-01-10 23:30:03 +02:00
video.js/test/unit/tracks/video-tracks.test.js
2019-03-18 15:49:48 -04:00

113 lines
2.6 KiB
JavaScript

/* eslint-env qunit */
import Html5 from '../../../src/js/tech/html5.js';
import TestHelpers from '../test-helpers.js';
import sinon from 'sinon';
QUnit.module('Video Tracks', {
beforeEach(assert) {
this.clock = sinon.useFakeTimers();
},
afterEach(assert) {
this.clock.restore();
}
});
QUnit.test('Player track methods call the tech', function(assert) {
let calls = 0;
const player = TestHelpers.makePlayer();
player.tech_.videoTracks = function() {
calls++;
};
player.videoTracks();
assert.equal(calls, 1, 'videoTrack defers to the tech');
player.dispose();
});
QUnit.test('listen to remove and add track events in native video tracks', function(assert) {
const oldTestVid = Html5.TEST_VID;
const oldVideoTracks = Html5.prototype.videoTracks;
const events = {};
Html5.prototype.videoTracks = function() {
return {
removeEventListener() {},
addEventListener(type, handler) {
events[type] = true;
}
};
};
Html5.TEST_VID = {
videoTracks: []
};
const player = {
// Function.prototype is a built-in no-op function.
controls() {},
ready() {},
options() {
return {};
},
addChild() {},
id() {},
el() {
return {
insertBefore() {},
appendChild() {}
};
}
};
player.player_ = player;
player.options_ = {};
const html = new Html5({});
assert.ok(events.removetrack, 'removetrack listener was added');
assert.ok(events.addtrack, 'addtrack listener was added');
Html5.TEST_VID = oldTestVid;
Html5.prototype.videoTracks = oldVideoTracks;
html.dispose();
});
QUnit.test('html5 tech supports native video tracks if the video supports it', function(assert) {
const oldTestVid = Html5.TEST_VID;
Html5.TEST_VID = {
videoTracks: []
};
assert.ok(Html5.supportsNativeVideoTracks(), 'native video tracks are supported');
Html5.TEST_VID = oldTestVid;
});
QUnit.test('html5 tech does not support native video tracks if the video does not supports it', function(assert) {
const oldTestVid = Html5.TEST_VID;
Html5.TEST_VID = {};
assert.ok(!Html5.supportsNativeVideoTracks(), 'native video tracks are not supported');
Html5.TEST_VID = oldTestVid;
});
QUnit.test('when switching techs, we should not get a new video track', function(assert) {
const player = TestHelpers.makePlayer();
player.loadTech_('TechFaker');
const firstTracks = player.videoTracks();
player.loadTech_('TechFaker');
const secondTracks = player.videoTracks();
assert.ok(firstTracks === secondTracks, 'the tracks are equal');
player.dispose();
});