mirror of
https://github.com/videojs/video.js.git
synced 2025-01-08 07:00:10 +02:00
115 lines
2.6 KiB
JavaScript
115 lines
2.6 KiB
JavaScript
import VideoTrack from '../../../src/js/tracks/video-track.js';
|
|
import Html5 from '../../../src/js/tech/html5.js';
|
|
import Tech from '../../../src/js/tech/tech.js';
|
|
import Component from '../../../src/js/component.js';
|
|
|
|
import * as browser from '../../../src/js/utils/browser.js';
|
|
import TestHelpers from '../test-helpers.js';
|
|
import document from 'global/document';
|
|
|
|
q.module('Video Tracks', {
|
|
setup() {
|
|
this.clock = sinon.useFakeTimers();
|
|
},
|
|
teardown() {
|
|
this.clock.restore();
|
|
}
|
|
});
|
|
|
|
test('Player track methods call the tech', function() {
|
|
let player;
|
|
let calls = 0;
|
|
|
|
player = TestHelpers.makePlayer();
|
|
|
|
player.tech_.videoTracks = function() {
|
|
calls++;
|
|
};
|
|
|
|
player.videoTracks();
|
|
|
|
equal(calls, 1, 'videoTrack defers to the tech');
|
|
player.dispose();
|
|
});
|
|
|
|
test('listen to remove and add track events in native video tracks', function() {
|
|
let oldTestVid = Html5.TEST_VID;
|
|
let player;
|
|
let options;
|
|
let oldVideoTracks = Html5.prototype.videoTracks;
|
|
let events = {};
|
|
let html;
|
|
|
|
Html5.prototype.videoTracks = function() {
|
|
return {
|
|
addEventListener(type, handler) {
|
|
events[type] = true;
|
|
}
|
|
};
|
|
};
|
|
|
|
Html5.TEST_VID = {
|
|
videoTracks: []
|
|
};
|
|
|
|
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_ = options = {};
|
|
|
|
html = new Html5(options);
|
|
|
|
ok(events.removetrack, 'removetrack listener was added');
|
|
ok(events.addtrack, 'addtrack listener was added');
|
|
|
|
Html5.TEST_VID = oldTestVid;
|
|
Html5.prototype.videoTracks = oldVideoTracks;
|
|
});
|
|
|
|
test('html5 tech supports native video tracks if the video supports it', function() {
|
|
let oldTestVid = Html5.TEST_VID;
|
|
|
|
Html5.TEST_VID = {
|
|
videoTracks: []
|
|
};
|
|
|
|
ok(Html5.supportsNativeVideoTracks(), 'native video tracks are supported');
|
|
|
|
Html5.TEST_VID = oldTestVid;
|
|
});
|
|
|
|
test('html5 tech does not support native video tracks if the video does not supports it', function() {
|
|
let oldTestVid = Html5.TEST_VID;
|
|
Html5.TEST_VID = {};
|
|
|
|
ok(!Html5.supportsNativeVideoTracks(), 'native video tracks are not supported');
|
|
|
|
Html5.TEST_VID = oldTestVid;
|
|
});
|
|
|
|
test('when switching techs, we should not get a new video track', function() {
|
|
let player = TestHelpers.makePlayer();
|
|
|
|
player.loadTech_('TechFaker');
|
|
let firstTracks = player.videoTracks();
|
|
|
|
player.loadTech_('TechFaker');
|
|
let secondTracks = player.videoTracks();
|
|
|
|
ok(firstTracks === secondTracks, 'the tracks are equal');
|
|
});
|