2016-08-03 15:27:47 -04:00
|
|
|
/* eslint-env qunit */
|
2015-12-08 11:24:51 -05:00
|
|
|
import HTMLTrackElement from '../../../src/js/tracks/html-track-element.js';
|
|
|
|
import window from 'global/window';
|
|
|
|
|
2016-03-07 14:54:32 -05:00
|
|
|
const defaultTech = {
|
|
|
|
textTracks() {},
|
|
|
|
on() {},
|
|
|
|
off() {},
|
|
|
|
currentTime() {}
|
2015-12-08 11:24:51 -05:00
|
|
|
};
|
|
|
|
|
2016-08-03 15:27:47 -04:00
|
|
|
QUnit.module('HTML Track Element');
|
2015-12-08 11:24:51 -05:00
|
|
|
|
2016-08-03 15:27:47 -04:00
|
|
|
QUnit.test('html track element requires a tech', function() {
|
2015-12-08 11:24:51 -05:00
|
|
|
window.throws(
|
|
|
|
function() {
|
2016-08-03 15:27:47 -04:00
|
|
|
return new HTMLTrackElement();
|
2015-12-08 11:24:51 -05:00
|
|
|
},
|
|
|
|
new Error('A tech was not provided.'),
|
|
|
|
'a tech is required for html track element'
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
2016-08-03 15:27:47 -04:00
|
|
|
QUnit.test('can create a html track element with various properties', function() {
|
|
|
|
const kind = 'chapters';
|
|
|
|
const label = 'English';
|
|
|
|
const language = 'en';
|
|
|
|
const src = 'http://www.example.com';
|
2015-12-08 11:24:51 -05:00
|
|
|
|
2016-08-03 15:27:47 -04:00
|
|
|
const htmlTrackElement = new HTMLTrackElement({
|
2015-12-08 11:24:51 -05:00
|
|
|
kind,
|
|
|
|
label,
|
|
|
|
language,
|
|
|
|
src,
|
|
|
|
tech: defaultTech
|
|
|
|
});
|
|
|
|
|
2016-08-03 15:27:47 -04:00
|
|
|
QUnit.equal(typeof htmlTrackElement.default, 'undefined', 'we have a default');
|
|
|
|
QUnit.equal(htmlTrackElement.kind, kind, 'we have a kind');
|
|
|
|
QUnit.equal(htmlTrackElement.label, label, 'we have a label');
|
|
|
|
QUnit.equal(htmlTrackElement.readyState, 0, 'we have a readyState');
|
|
|
|
QUnit.equal(htmlTrackElement.src, src, 'we have a src');
|
|
|
|
QUnit.equal(htmlTrackElement.srclang, language, 'we have a srclang');
|
|
|
|
QUnit.equal(htmlTrackElement.track.cues, null, 'we have a track');
|
2015-12-08 11:24:51 -05:00
|
|
|
});
|
|
|
|
|
2016-08-03 15:27:47 -04:00
|
|
|
QUnit.test('defaults when items not provided', function() {
|
|
|
|
const htmlTrackElement = new HTMLTrackElement({
|
2015-12-08 11:24:51 -05:00
|
|
|
tech: defaultTech
|
|
|
|
});
|
|
|
|
|
2016-08-03 15:27:47 -04:00
|
|
|
QUnit.equal(typeof htmlTrackElement.default, 'undefined', 'we have a default');
|
|
|
|
QUnit.equal(htmlTrackElement.kind, 'subtitles', 'we have a kind');
|
|
|
|
QUnit.equal(htmlTrackElement.label, '', 'we have a label');
|
|
|
|
QUnit.equal(htmlTrackElement.readyState, 0, 'we have a readyState');
|
|
|
|
QUnit.equal(typeof htmlTrackElement.src, 'undefined', 'we have a src');
|
|
|
|
QUnit.equal(htmlTrackElement.srclang, '', 'we have a srclang');
|
|
|
|
QUnit.equal(htmlTrackElement.track.cues.length, 0, 'we have a track');
|
2015-12-08 11:24:51 -05:00
|
|
|
});
|
|
|
|
|
2016-08-03 15:27:47 -04:00
|
|
|
QUnit.test('fires loadeddata when track cues become populated', function() {
|
2016-03-07 14:54:32 -05:00
|
|
|
let changes = 0;
|
2016-08-03 15:27:47 -04:00
|
|
|
const loadHandler = function() {
|
2015-12-08 11:24:51 -05:00
|
|
|
changes++;
|
|
|
|
};
|
2016-08-03 15:27:47 -04:00
|
|
|
const htmlTrackElement = new HTMLTrackElement({
|
2016-03-07 14:54:32 -05:00
|
|
|
tech() {}
|
2015-12-08 11:24:51 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
htmlTrackElement.addEventListener('load', loadHandler);
|
|
|
|
|
|
|
|
// trigger loaded cues event
|
|
|
|
htmlTrackElement.track.trigger('loadeddata');
|
|
|
|
|
2016-08-03 15:27:47 -04:00
|
|
|
QUnit.equal(changes, 1, 'a loadeddata event trigger addEventListener');
|
|
|
|
QUnit.equal(htmlTrackElement.readyState, 2, 'readyState is loaded');
|
2015-12-08 11:24:51 -05:00
|
|
|
});
|