2015-04-14 13:08:32 -07:00
|
|
|
import ChaptersButton from '../../../src/js/control-bar/text-track-controls/chapters-button.js';
|
|
|
|
import SubtitlesButton from '../../../src/js/control-bar/text-track-controls/subtitles-button.js';
|
|
|
|
import CaptionsButton from '../../../src/js/control-bar/text-track-controls/captions-button.js';
|
|
|
|
|
2015-11-23 23:39:58 -08:00
|
|
|
import TextTrack from '../../../src/js/tracks/text-track.js';
|
2015-04-14 13:08:32 -07:00
|
|
|
import TextTrackDisplay from '../../../src/js/tracks/text-track-display.js';
|
|
|
|
import Html5 from '../../../src/js/tech/html5.js';
|
|
|
|
import Flash from '../../../src/js/tech/flash.js';
|
|
|
|
import Tech from '../../../src/js/tech/tech.js';
|
2015-03-25 21:43:41 -07:00
|
|
|
import Component from '../../../src/js/component.js';
|
2015-02-13 15:18:07 -08:00
|
|
|
|
2015-05-03 16:12:38 -07:00
|
|
|
import * as browser from '../../../src/js/utils/browser.js';
|
2015-03-25 21:43:41 -07:00
|
|
|
import TestHelpers from '../test-helpers.js';
|
|
|
|
import document from 'global/document';
|
2015-08-24 17:46:54 -07:00
|
|
|
import window from 'global/window';
|
2015-08-24 12:48:42 -07:00
|
|
|
import TechFaker from '../tech/tech-faker.js';
|
2015-03-25 21:43:41 -07:00
|
|
|
|
2015-12-08 11:24:51 -05:00
|
|
|
q.module('Tracks', {
|
|
|
|
'setup': function() {
|
|
|
|
this.clock = sinon.useFakeTimers();
|
|
|
|
},
|
|
|
|
'teardown': function() {
|
|
|
|
this.clock.restore();
|
|
|
|
}
|
|
|
|
});
|
2015-03-10 18:01:11 -07:00
|
|
|
|
2015-02-13 15:18:07 -08:00
|
|
|
test('should place title list item into ul', function() {
|
|
|
|
var player, chaptersButton;
|
|
|
|
|
2015-03-25 21:43:41 -07:00
|
|
|
player = TestHelpers.makePlayer();
|
2015-02-13 15:18:07 -08:00
|
|
|
|
2015-03-10 18:01:11 -07:00
|
|
|
chaptersButton = new ChaptersButton(player);
|
2015-02-13 15:18:07 -08:00
|
|
|
|
|
|
|
var menuContentElement = chaptersButton.el().getElementsByTagName('UL')[0];
|
|
|
|
var titleElement = menuContentElement.children[0];
|
|
|
|
|
|
|
|
ok(titleElement.innerHTML === 'Chapters', 'title element placed in ul');
|
|
|
|
|
|
|
|
player.dispose();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('Player track methods call the tech', function() {
|
|
|
|
var player,
|
|
|
|
calls = 0;
|
|
|
|
|
2015-03-25 21:43:41 -07:00
|
|
|
player = TestHelpers.makePlayer();
|
2015-02-13 15:18:07 -08:00
|
|
|
|
2015-09-14 17:45:14 -07:00
|
|
|
player.tech_.textTracks = function() {
|
2015-02-13 15:18:07 -08:00
|
|
|
calls++;
|
|
|
|
};
|
2015-09-14 17:45:14 -07:00
|
|
|
player.tech_.addTextTrack = function() {
|
2015-02-13 15:18:07 -08:00
|
|
|
calls++;
|
|
|
|
};
|
|
|
|
|
|
|
|
player.addTextTrack();
|
|
|
|
player.textTracks();
|
|
|
|
|
|
|
|
equal(calls, 2, 'both textTrack and addTextTrack defer to the tech');
|
2015-08-24 17:46:54 -07:00
|
|
|
|
|
|
|
player.dispose();
|
2015-02-13 15:18:07 -08:00
|
|
|
});
|
|
|
|
|
|
|
|
test('TextTrackDisplay initializes tracks on player ready', function() {
|
|
|
|
var calls = 0,
|
2015-03-25 21:43:41 -07:00
|
|
|
ttd = new TextTrackDisplay({
|
2015-02-13 15:18:07 -08:00
|
|
|
on: Function.prototype,
|
|
|
|
addTextTracks: function() {
|
|
|
|
calls--;
|
|
|
|
},
|
|
|
|
getChild: function() {
|
|
|
|
calls--;
|
|
|
|
},
|
|
|
|
ready: function() {
|
|
|
|
calls++;
|
|
|
|
}
|
|
|
|
}, {});
|
|
|
|
|
|
|
|
equal(calls, 1, 'only a player.ready call was made');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('listen to remove and add track events in native text tracks', function() {
|
2015-05-03 16:12:38 -07:00
|
|
|
var oldTestVid = Html5.TEST_VID,
|
2015-02-13 15:18:07 -08:00
|
|
|
player,
|
|
|
|
options,
|
|
|
|
oldTextTracks,
|
|
|
|
events = {},
|
|
|
|
html;
|
|
|
|
|
2015-03-25 21:43:41 -07:00
|
|
|
oldTextTracks = Html5.prototype.textTracks;
|
|
|
|
Html5.prototype.textTracks = function() {
|
2015-02-13 15:18:07 -08:00
|
|
|
return {
|
|
|
|
addEventListener: function(type, handler) {
|
|
|
|
events[type] = true;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2015-05-03 16:12:38 -07:00
|
|
|
Html5.TEST_VID = {
|
2015-02-13 15:18:07 -08:00
|
|
|
textTracks: []
|
|
|
|
};
|
|
|
|
|
|
|
|
player = {
|
|
|
|
// Function.prototype is a built-in no-op function.
|
|
|
|
controls: Function.prototype,
|
|
|
|
ready: Function.prototype,
|
|
|
|
options: function() {
|
|
|
|
return {};
|
|
|
|
},
|
|
|
|
addChild: Function.prototype,
|
|
|
|
id: Function.prototype,
|
|
|
|
el: function() {
|
|
|
|
return {
|
|
|
|
insertBefore: Function.prototype,
|
|
|
|
appendChild: Function.prototype
|
|
|
|
};
|
|
|
|
}
|
|
|
|
};
|
|
|
|
player.player_ = player;
|
|
|
|
player.options_ = options = {};
|
|
|
|
|
2015-05-06 14:01:52 -04:00
|
|
|
html = new Html5(options);
|
2015-02-13 15:18:07 -08:00
|
|
|
|
|
|
|
ok(events['removetrack'], 'removetrack listener was added');
|
|
|
|
ok(events['addtrack'], 'addtrack listener was added');
|
|
|
|
|
2015-05-03 16:12:38 -07:00
|
|
|
Html5.TEST_VID = oldTestVid;
|
2015-03-25 21:43:41 -07:00
|
|
|
Html5.prototype.textTracks = oldTextTracks;
|
2015-02-13 15:18:07 -08:00
|
|
|
});
|
|
|
|
|
|
|
|
test('update texttrack buttons on removetrack or addtrack', function() {
|
|
|
|
var update = 0,
|
|
|
|
i,
|
|
|
|
player,
|
|
|
|
tag,
|
|
|
|
track,
|
|
|
|
oldTextTracks,
|
|
|
|
events = {},
|
|
|
|
oldCaptionsUpdate,
|
|
|
|
oldSubsUpdate,
|
|
|
|
oldChaptersUpdate;
|
|
|
|
|
2015-03-25 21:43:41 -07:00
|
|
|
oldCaptionsUpdate = CaptionsButton.prototype.update;
|
|
|
|
oldSubsUpdate = SubtitlesButton.prototype.update;
|
|
|
|
oldChaptersUpdate = ChaptersButton.prototype.update;
|
|
|
|
CaptionsButton.prototype.update = function() {
|
2015-02-13 15:18:07 -08:00
|
|
|
update++;
|
|
|
|
oldCaptionsUpdate.call(this);
|
|
|
|
};
|
2015-03-25 21:43:41 -07:00
|
|
|
SubtitlesButton.prototype.update = function() {
|
2015-02-13 15:18:07 -08:00
|
|
|
update++;
|
|
|
|
oldSubsUpdate.call(this);
|
|
|
|
};
|
2015-03-25 21:43:41 -07:00
|
|
|
ChaptersButton.prototype.update = function() {
|
2015-02-13 15:18:07 -08:00
|
|
|
update++;
|
|
|
|
oldChaptersUpdate.call(this);
|
|
|
|
};
|
|
|
|
|
2015-04-14 13:08:32 -07:00
|
|
|
Tech.prototype['featuresNativeTextTracks'] = true;
|
|
|
|
oldTextTracks = Tech.prototype.textTracks;
|
|
|
|
Tech.prototype.textTracks = function() {
|
2015-02-13 15:18:07 -08:00
|
|
|
return {
|
|
|
|
length: 0,
|
|
|
|
addEventListener: function(type, handler) {
|
|
|
|
if (!events[type]) {
|
|
|
|
events[type] = [];
|
|
|
|
}
|
|
|
|
events[type].push(handler);
|
2015-08-24 17:46:54 -07:00
|
|
|
},
|
|
|
|
// Requrired in player.dispose()
|
|
|
|
removeEventListener: function(){}
|
2015-02-13 15:18:07 -08:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
tag = document.createElement('video');
|
|
|
|
track = document.createElement('track');
|
|
|
|
track.kind = 'captions';
|
|
|
|
track.label = 'en';
|
|
|
|
track.language = 'English';
|
2015-08-24 17:46:54 -07:00
|
|
|
track.src = '#en.vtt';
|
2015-02-13 15:18:07 -08:00
|
|
|
tag.appendChild(track);
|
|
|
|
track = document.createElement('track');
|
|
|
|
track.kind = 'captions';
|
|
|
|
track.label = 'es';
|
|
|
|
track.language = 'Spanish';
|
2015-08-24 17:46:54 -07:00
|
|
|
track.src = '#es.vtt';
|
2015-02-13 15:18:07 -08:00
|
|
|
tag.appendChild(track);
|
|
|
|
|
2015-03-25 21:43:41 -07:00
|
|
|
player = TestHelpers.makePlayer({}, tag);
|
2015-02-13 15:18:07 -08:00
|
|
|
|
|
|
|
player.player_ = player;
|
|
|
|
|
|
|
|
equal(update, 3, 'update was called on the three buttons during init');
|
|
|
|
|
|
|
|
for (i = 0; i < events['removetrack'].length; i++) {
|
|
|
|
events['removetrack'][i]();
|
|
|
|
}
|
|
|
|
|
|
|
|
equal(update, 6, 'update was called on the three buttons for remove track');
|
|
|
|
|
|
|
|
for (i = 0; i < events['addtrack'].length; i++) {
|
|
|
|
events['addtrack'][i]();
|
|
|
|
}
|
|
|
|
|
|
|
|
equal(update, 9, 'update was called on the three buttons for remove track');
|
|
|
|
|
2015-04-14 13:08:32 -07:00
|
|
|
Tech.prototype.textTracks = oldTextTracks;
|
|
|
|
Tech.prototype['featuresNativeTextTracks'] = false;
|
2015-03-25 21:43:41 -07:00
|
|
|
CaptionsButton.prototype.update = oldCaptionsUpdate;
|
|
|
|
SubtitlesButton.prototype.update = oldSubsUpdate;
|
|
|
|
ChaptersButton.prototype.update = oldChaptersUpdate;
|
2015-08-24 17:46:54 -07:00
|
|
|
|
|
|
|
player.dispose();
|
2015-02-13 15:18:07 -08:00
|
|
|
});
|
|
|
|
|
|
|
|
test('if native text tracks are not supported, create a texttrackdisplay', function() {
|
2015-05-03 16:12:38 -07:00
|
|
|
var oldTestVid = Html5.TEST_VID,
|
|
|
|
oldIsFirefox = browser.IS_FIREFOX,
|
2015-03-25 21:43:41 -07:00
|
|
|
oldTextTrackDisplay = Component.getComponent('TextTrackDisplay'),
|
2015-02-13 15:18:07 -08:00
|
|
|
called = false,
|
|
|
|
player,
|
|
|
|
tag,
|
|
|
|
track,
|
|
|
|
options,
|
|
|
|
html;
|
|
|
|
|
|
|
|
tag = document.createElement('video');
|
|
|
|
track = document.createElement('track');
|
|
|
|
track.kind = 'captions';
|
|
|
|
track.label = 'en';
|
|
|
|
track.language = 'English';
|
|
|
|
track.src = 'en.vtt';
|
|
|
|
tag.appendChild(track);
|
|
|
|
track = document.createElement('track');
|
|
|
|
track.kind = 'captions';
|
|
|
|
track.label = 'es';
|
|
|
|
track.language = 'Spanish';
|
|
|
|
track.src = 'es.vtt';
|
|
|
|
tag.appendChild(track);
|
|
|
|
|
2015-05-03 16:12:38 -07:00
|
|
|
Html5.TEST_VID = {
|
2015-02-13 15:18:07 -08:00
|
|
|
textTracks: []
|
|
|
|
};
|
|
|
|
|
2015-05-03 16:12:38 -07:00
|
|
|
browser.IS_FIREFOX = true;
|
2015-03-25 21:43:41 -07:00
|
|
|
Component.registerComponent('TextTrackDisplay', function() {
|
2015-02-13 15:18:07 -08:00
|
|
|
called = true;
|
2015-03-25 21:43:41 -07:00
|
|
|
});
|
2015-02-13 15:18:07 -08:00
|
|
|
|
2015-03-25 21:43:41 -07:00
|
|
|
player = TestHelpers.makePlayer({}, tag);
|
2015-02-13 15:18:07 -08:00
|
|
|
|
|
|
|
ok(called, 'text track display was created');
|
|
|
|
|
2015-05-03 16:12:38 -07:00
|
|
|
Html5.TEST_VID = oldTestVid;
|
|
|
|
browser.IS_FIREFOX = oldIsFirefox;
|
2015-03-25 21:43:41 -07:00
|
|
|
Component.registerComponent('TextTrackDisplay', oldTextTrackDisplay);
|
2015-02-13 15:18:07 -08:00
|
|
|
|
2015-08-24 17:46:54 -07:00
|
|
|
player.dispose();
|
2015-02-13 15:18:07 -08:00
|
|
|
});
|
|
|
|
|
|
|
|
test('html5 tech supports native text tracks if the video supports it, unless mode is a number', function() {
|
2015-05-03 16:12:38 -07:00
|
|
|
var oldTestVid = Html5.TEST_VID;
|
2015-02-13 15:18:07 -08:00
|
|
|
|
2015-05-03 16:12:38 -07:00
|
|
|
Html5.TEST_VID = {
|
2015-02-13 15:18:07 -08:00
|
|
|
textTracks: [{
|
|
|
|
mode: 0
|
|
|
|
}]
|
|
|
|
};
|
|
|
|
|
2015-03-25 21:43:41 -07:00
|
|
|
ok(!Html5.supportsNativeTextTracks(), 'native text tracks are not supported if mode is a number');
|
2015-02-13 15:18:07 -08:00
|
|
|
|
2015-05-03 16:12:38 -07:00
|
|
|
Html5.TEST_VID = oldTestVid;
|
2015-02-13 15:18:07 -08:00
|
|
|
});
|
|
|
|
|
|
|
|
test('html5 tech supports native text tracks if the video supports it, unless it is firefox', function() {
|
2015-05-03 16:12:38 -07:00
|
|
|
var oldTestVid = Html5.TEST_VID,
|
|
|
|
oldIsFirefox = browser.IS_FIREFOX;
|
2015-02-13 15:18:07 -08:00
|
|
|
|
2015-05-03 16:12:38 -07:00
|
|
|
Html5.TEST_VID = {
|
2015-02-13 15:18:07 -08:00
|
|
|
textTracks: []
|
|
|
|
};
|
|
|
|
|
2015-05-03 16:12:38 -07:00
|
|
|
browser.IS_FIREFOX = true;
|
2015-02-13 15:18:07 -08:00
|
|
|
|
2015-03-25 21:43:41 -07:00
|
|
|
ok(!Html5.supportsNativeTextTracks(), 'if textTracks are available on video element, native text tracks are supported');
|
2015-02-13 15:18:07 -08:00
|
|
|
|
2015-05-03 16:12:38 -07:00
|
|
|
Html5.TEST_VID = oldTestVid;
|
|
|
|
browser.IS_FIREFOX = oldIsFirefox;
|
2015-02-13 15:18:07 -08:00
|
|
|
});
|
2015-02-17 17:19:21 -05:00
|
|
|
|
|
|
|
test('when switching techs, we should not get a new text track', function() {
|
2015-08-24 12:48:42 -07:00
|
|
|
let player = TestHelpers.makePlayer();
|
2015-02-17 17:19:21 -05:00
|
|
|
|
2015-09-14 17:45:14 -07:00
|
|
|
player.loadTech_('TechFaker');
|
2015-08-24 12:48:42 -07:00
|
|
|
let firstTracks = player.textTracks();
|
2015-02-17 17:19:21 -05:00
|
|
|
|
2015-09-14 17:45:14 -07:00
|
|
|
player.loadTech_('TechFaker');
|
2015-08-24 12:48:42 -07:00
|
|
|
let secondTracks = player.textTracks();
|
2015-02-17 17:19:21 -05:00
|
|
|
|
2015-08-24 12:48:42 -07:00
|
|
|
ok(firstTracks === secondTracks, 'the tracks are equal');
|
2015-02-17 17:19:21 -05:00
|
|
|
});
|
2015-08-03 15:19:36 -04:00
|
|
|
|
|
|
|
if (Html5.supportsNativeTextTracks()) {
|
2015-08-12 16:04:31 -07:00
|
|
|
test('listen to native remove and add track events in native text tracks', function(assert) {
|
2015-08-03 15:19:36 -04:00
|
|
|
let done = assert.async();
|
|
|
|
|
|
|
|
let el = document.createElement('video');
|
|
|
|
let html = new Html5({el});
|
|
|
|
let tt = el.textTracks;
|
|
|
|
let emulatedTt = html.textTracks();
|
|
|
|
let track = document.createElement('track');
|
|
|
|
el.appendChild(track);
|
|
|
|
|
|
|
|
let addtrack = function() {
|
|
|
|
equal(emulatedTt.length, tt.length, 'we have matching tracks length');
|
|
|
|
equal(emulatedTt.length, 1, 'we have one text track');
|
|
|
|
|
|
|
|
emulatedTt.off('addtrack', addtrack);
|
|
|
|
el.removeChild(track);
|
|
|
|
};
|
|
|
|
emulatedTt.on('addtrack', addtrack);
|
|
|
|
emulatedTt.on('removetrack', function() {
|
|
|
|
equal(emulatedTt.length, tt.length, 'we have matching tracks length');
|
|
|
|
equal(emulatedTt.length, 0, 'we have no more text tracks');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should have removed tracks on dispose', function(assert) {
|
|
|
|
let done = assert.async();
|
|
|
|
|
|
|
|
let el = document.createElement('video');
|
|
|
|
let html = new Html5({el});
|
|
|
|
let tt = el.textTracks;
|
|
|
|
let emulatedTt = html.textTracks();
|
|
|
|
let track = document.createElement('track');
|
|
|
|
el.appendChild(track);
|
|
|
|
|
|
|
|
let addtrack = function() {
|
|
|
|
equal(emulatedTt.length, tt.length, 'we have matching tracks length');
|
|
|
|
equal(emulatedTt.length, 1, 'we have one text track');
|
|
|
|
|
|
|
|
emulatedTt.off('addtrack', addtrack);
|
|
|
|
html.dispose();
|
|
|
|
|
|
|
|
equal(emulatedTt.length, tt.length, 'we have matching tracks length');
|
|
|
|
equal(emulatedTt.length, 0, 'we have no more text tracks');
|
|
|
|
|
|
|
|
done();
|
|
|
|
};
|
|
|
|
emulatedTt.on('addtrack', addtrack);
|
|
|
|
});
|
|
|
|
}
|
2015-11-25 16:00:49 -05:00
|
|
|
|
|
|
|
test('should check for text track changes when emulating text tracks', function() {
|
|
|
|
let tech = new Tech();
|
|
|
|
let numTextTrackChanges = 0;
|
|
|
|
tech.on('texttrackchange', function() {
|
|
|
|
numTextTrackChanges++;
|
|
|
|
});
|
|
|
|
tech.emulateTextTracks();
|
|
|
|
equal(numTextTrackChanges, 1, 'we got a texttrackchange event');
|
|
|
|
});
|
2015-11-23 23:39:58 -08:00
|
|
|
|
|
|
|
test('removes cuechange event when text track is hidden for emulated tracks', function() {
|
|
|
|
let player = TestHelpers.makePlayer();
|
|
|
|
let tt = new TextTrack({
|
|
|
|
tech: player.tech_,
|
|
|
|
mode: 'showing'
|
|
|
|
});
|
|
|
|
tt.addCue({
|
|
|
|
id: '1',
|
|
|
|
startTime: 2,
|
|
|
|
endTime: 5
|
|
|
|
});
|
|
|
|
player.tech_.textTracks().addTrack_(tt);
|
|
|
|
player.tech_.emulateTextTracks();
|
|
|
|
|
|
|
|
let numTextTrackChanges = 0;
|
|
|
|
player.tech_.on('texttrackchange', function() {
|
|
|
|
numTextTrackChanges++;
|
|
|
|
});
|
|
|
|
|
|
|
|
tt.mode = 'showing';
|
|
|
|
equal(numTextTrackChanges, 1,
|
|
|
|
'texttrackchange should be called once for mode change');
|
|
|
|
tt.mode = 'showing';
|
|
|
|
equal(numTextTrackChanges, 2,
|
|
|
|
'texttrackchange should be called once for mode change');
|
|
|
|
|
|
|
|
player.tech_.currentTime = function() {
|
|
|
|
return 3;
|
|
|
|
};
|
|
|
|
player.tech_.trigger('timeupdate');
|
|
|
|
equal(numTextTrackChanges, 3,
|
|
|
|
'texttrackchange should be triggered once for the cuechange');
|
|
|
|
|
|
|
|
tt.mode = 'hidden';
|
|
|
|
equal(numTextTrackChanges, 4,
|
|
|
|
'texttrackchange should be called once for the mode change');
|
|
|
|
|
|
|
|
player.tech_.currentTime = function() {
|
|
|
|
return 7;
|
|
|
|
};
|
|
|
|
player.tech_.trigger('timeupdate');
|
|
|
|
equal(numTextTrackChanges, 4,
|
|
|
|
'texttrackchange should be not be called since mode is hidden');
|
|
|
|
});
|
2015-12-08 11:24:51 -05:00
|
|
|
|
|
|
|
test('should return correct remote text track values', function () {
|
|
|
|
let fixture = document.getElementById('qunit-fixture');
|
|
|
|
|
|
|
|
let html = '<video id="example_1" class="video-js" autoplay preload="none">';
|
|
|
|
html += '<source src="http://google.com" type="video/mp4">';
|
|
|
|
html += '<source src="http://google.com" type="video/webm">';
|
|
|
|
html += '<track kind="captions" label="label">';
|
|
|
|
html += '</video>';
|
|
|
|
|
|
|
|
fixture.innerHTML += html;
|
|
|
|
|
|
|
|
let tag = document.getElementById('example_1');
|
|
|
|
|
|
|
|
let player = TestHelpers.makePlayer({}, tag);
|
|
|
|
|
|
|
|
this.clock.tick(1);
|
|
|
|
|
|
|
|
equal(player.remoteTextTracks().length, 1, 'add text track via html');
|
|
|
|
equal(player.remoteTextTrackEls().length, 1, 'add html track element via html');
|
|
|
|
|
|
|
|
let htmlTrackElement = player.addRemoteTextTrack({
|
|
|
|
kind: 'captions',
|
|
|
|
label: 'label'
|
|
|
|
});
|
|
|
|
|
|
|
|
equal(player.remoteTextTracks().length, 2, 'add text track via method');
|
|
|
|
equal(player.remoteTextTrackEls().length, 2, 'add html track element via method');
|
|
|
|
|
|
|
|
player.removeRemoteTextTrack(htmlTrackElement.track);
|
|
|
|
|
|
|
|
equal(player.remoteTextTracks().length, 1, 'remove text track via method');
|
|
|
|
equal(player.remoteTextTrackEls().length, 1, 'remove html track element via method');
|
|
|
|
|
|
|
|
player.dispose();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should uniformly create html track element when adding text track', function () {
|
|
|
|
let player = TestHelpers.makePlayer();
|
|
|
|
|
|
|
|
let track = {
|
|
|
|
kind: 'kind',
|
|
|
|
src: 'src',
|
|
|
|
language: 'language',
|
|
|
|
label: 'label',
|
|
|
|
default: 'default'
|
|
|
|
};
|
|
|
|
|
|
|
|
equal(player.remoteTextTrackEls().length, 0, 'no html text tracks');
|
|
|
|
|
|
|
|
let htmlTrackElement = player.addRemoteTextTrack(track);
|
|
|
|
|
|
|
|
equal(htmlTrackElement.kind, htmlTrackElement.track.kind, 'verify html track element kind');
|
|
|
|
equal(htmlTrackElement.src, htmlTrackElement.track.src, 'verify html track element src');
|
|
|
|
equal(htmlTrackElement.srclang, htmlTrackElement.track.language, 'verify html track element language');
|
|
|
|
equal(htmlTrackElement.label, htmlTrackElement.track.label, 'verify html track element label');
|
|
|
|
equal(htmlTrackElement.default, htmlTrackElement.track.default, 'verify html track element default');
|
|
|
|
|
|
|
|
equal(player.remoteTextTrackEls().length, 1, 'html track element exist');
|
|
|
|
equal(player.remoteTextTrackEls().getTrackElementByTrack_(htmlTrackElement.track), htmlTrackElement, 'verify same html track element');
|
|
|
|
|
|
|
|
player.dispose();
|
|
|
|
});
|