2015-03-25 21:43:41 -07:00
|
|
|
import TextTrack from '../../../src/js/tracks/text-track.js';
|
|
|
|
import window from 'global/window';
|
|
|
|
import TestHelpers from '../test-helpers.js';
|
2015-02-13 15:18:07 -08:00
|
|
|
|
2015-03-25 21:43:41 -07:00
|
|
|
var noop = Function.prototype;
|
2015-05-06 14:01:52 -04:00
|
|
|
var defaultTech = {
|
2015-03-25 21:43:41 -07:00
|
|
|
textTracks: noop,
|
|
|
|
on: noop,
|
|
|
|
off: noop,
|
|
|
|
currentTime: noop
|
|
|
|
};
|
2015-02-13 15:18:07 -08:00
|
|
|
|
2015-03-25 21:43:41 -07:00
|
|
|
q.module('Text Track');
|
2015-02-13 15:18:07 -08:00
|
|
|
|
2015-05-06 14:01:52 -04:00
|
|
|
test('text-track requires a tech', function() {
|
2015-02-13 15:18:07 -08:00
|
|
|
window.throws(function() {
|
2015-03-25 21:43:41 -07:00
|
|
|
new TextTrack();
|
2015-02-13 15:18:07 -08:00
|
|
|
},
|
2015-05-06 14:01:52 -04:00
|
|
|
new Error('A tech was not provided.'),
|
|
|
|
'a tech is required for text track');
|
2015-02-13 15:18:07 -08:00
|
|
|
});
|
|
|
|
|
|
|
|
test('can create a TextTrack with various properties', function() {
|
|
|
|
var kind = 'captions',
|
|
|
|
label = 'English',
|
|
|
|
language = 'en',
|
|
|
|
id = '1',
|
|
|
|
mode = 'disabled',
|
2015-03-25 21:43:41 -07:00
|
|
|
tt = new TextTrack({
|
2015-05-06 14:01:52 -04:00
|
|
|
tech: defaultTech,
|
2015-02-13 15:18:07 -08:00
|
|
|
kind: kind,
|
|
|
|
label: label,
|
|
|
|
language: language,
|
|
|
|
id: id,
|
|
|
|
mode: mode
|
|
|
|
});
|
|
|
|
|
|
|
|
equal(tt.kind, kind, 'we have a kind');
|
|
|
|
equal(tt.label, label, 'we have a label');
|
|
|
|
equal(tt.language, language, 'we have a language');
|
|
|
|
equal(tt.id, id, 'we have a id');
|
|
|
|
equal(tt.mode, mode, 'we have a mode');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('defaults when items not provided', function() {
|
2015-03-25 21:43:41 -07:00
|
|
|
var tt = new TextTrack({
|
2015-05-06 14:01:52 -04:00
|
|
|
tech: defaultTech
|
2015-02-13 15:18:07 -08:00
|
|
|
});
|
|
|
|
|
|
|
|
equal(tt.kind, 'subtitles', 'kind defaulted to subtitles');
|
|
|
|
equal(tt.mode, 'disabled', 'mode defaulted to disabled');
|
|
|
|
equal(tt.label, '', 'label defaults to empty string');
|
|
|
|
equal(tt.language, '', 'language defaults to empty string');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('kind can only be one of several options, defaults to subtitles', function() {
|
2015-03-25 21:43:41 -07:00
|
|
|
var tt = new TextTrack({
|
2015-05-06 14:01:52 -04:00
|
|
|
tech: defaultTech,
|
2015-02-13 15:18:07 -08:00
|
|
|
kind: 'foo'
|
|
|
|
});
|
|
|
|
|
|
|
|
equal(tt.kind, 'subtitles', 'the kind is set to subtitles, not foo');
|
|
|
|
notEqual(tt.kind, 'foo', 'the kind is set to subtitles, not foo');
|
|
|
|
|
2015-03-25 21:43:41 -07:00
|
|
|
tt = new TextTrack({
|
2015-05-06 14:01:52 -04:00
|
|
|
tech: defaultTech,
|
2015-02-13 15:18:07 -08:00
|
|
|
kind: 'subtitles'
|
|
|
|
});
|
|
|
|
|
|
|
|
equal(tt.kind, 'subtitles', 'the kind is set to subtitles');
|
|
|
|
|
2015-03-25 21:43:41 -07:00
|
|
|
tt = new TextTrack({
|
2015-05-06 14:01:52 -04:00
|
|
|
tech: defaultTech,
|
2015-02-13 15:18:07 -08:00
|
|
|
kind: 'captions'
|
|
|
|
});
|
|
|
|
|
|
|
|
equal(tt.kind, 'captions', 'the kind is set to captions');
|
|
|
|
|
2015-03-25 21:43:41 -07:00
|
|
|
tt = new TextTrack({
|
2015-05-06 14:01:52 -04:00
|
|
|
tech: defaultTech,
|
2015-02-13 15:18:07 -08:00
|
|
|
kind: 'descriptions'
|
|
|
|
});
|
|
|
|
|
|
|
|
equal(tt.kind, 'descriptions', 'the kind is set to descriptions');
|
|
|
|
|
2015-03-25 21:43:41 -07:00
|
|
|
tt = new TextTrack({
|
2015-05-06 14:01:52 -04:00
|
|
|
tech: defaultTech,
|
2015-02-13 15:18:07 -08:00
|
|
|
kind: 'chapters'
|
|
|
|
});
|
|
|
|
|
|
|
|
equal(tt.kind, 'chapters', 'the kind is set to chapters');
|
|
|
|
|
2015-03-25 21:43:41 -07:00
|
|
|
tt = new TextTrack({
|
2015-05-06 14:01:52 -04:00
|
|
|
tech: defaultTech,
|
2015-02-13 15:18:07 -08:00
|
|
|
kind: 'metadata'
|
|
|
|
});
|
|
|
|
|
|
|
|
equal(tt.kind, 'metadata', 'the kind is set to metadata');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('mode can only be one of several options, defaults to disabled', function() {
|
2015-03-25 21:43:41 -07:00
|
|
|
var tt = new TextTrack({
|
2015-05-06 14:01:52 -04:00
|
|
|
tech: defaultTech,
|
2015-02-13 15:18:07 -08:00
|
|
|
mode: 'foo'
|
|
|
|
});
|
|
|
|
|
|
|
|
equal(tt.mode, 'disabled', 'the mode is set to disabled, not foo');
|
|
|
|
notEqual(tt.mode, 'foo', 'the mode is set to disabld, not foo');
|
|
|
|
|
2015-03-25 21:43:41 -07:00
|
|
|
tt = new TextTrack({
|
2015-05-06 14:01:52 -04:00
|
|
|
tech: defaultTech,
|
2015-02-13 15:18:07 -08:00
|
|
|
mode: 'disabled'
|
|
|
|
});
|
|
|
|
|
|
|
|
equal(tt.mode, 'disabled', 'the mode is set to disabled');
|
|
|
|
|
2015-03-25 21:43:41 -07:00
|
|
|
tt = new TextTrack({
|
2015-05-06 14:01:52 -04:00
|
|
|
tech: defaultTech,
|
2015-02-13 15:18:07 -08:00
|
|
|
mode: 'hidden'
|
|
|
|
});
|
|
|
|
|
|
|
|
equal(tt.mode, 'hidden', 'the mode is set to hidden');
|
|
|
|
|
2015-03-25 21:43:41 -07:00
|
|
|
tt = new TextTrack({
|
2015-05-06 14:01:52 -04:00
|
|
|
tech: defaultTech,
|
2015-02-13 15:18:07 -08:00
|
|
|
mode: 'showing'
|
|
|
|
});
|
|
|
|
|
|
|
|
equal(tt.mode, 'showing', 'the mode is set to showing');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('kind, label, language, id, cue, and activeCues are read only', function() {
|
|
|
|
var kind = 'captions',
|
|
|
|
label = 'English',
|
|
|
|
language = 'en',
|
|
|
|
id = '1',
|
|
|
|
mode = 'disabled',
|
2015-03-25 21:43:41 -07:00
|
|
|
tt = new TextTrack({
|
2015-05-06 14:01:52 -04:00
|
|
|
tech: defaultTech,
|
2015-02-13 15:18:07 -08:00
|
|
|
kind: kind,
|
|
|
|
label: label,
|
|
|
|
language: language,
|
|
|
|
id: id,
|
|
|
|
mode: mode
|
|
|
|
});
|
|
|
|
|
|
|
|
tt.kind = 'subtitles';
|
|
|
|
tt.label = 'Spanish';
|
|
|
|
tt.language = 'es';
|
|
|
|
tt.id = '2';
|
|
|
|
tt.cues = 'foo';
|
|
|
|
tt.activeCues = 'bar';
|
|
|
|
|
|
|
|
equal(tt.kind, kind, 'kind is still set to captions');
|
|
|
|
equal(tt.label, label, 'label is still set to English');
|
|
|
|
equal(tt.language, language, 'language is still set to en');
|
|
|
|
equal(tt.id, id, 'id is still set to \'1\'');
|
|
|
|
notEqual(tt.cues, 'foo', 'cues is still original value');
|
|
|
|
notEqual(tt.activeCues, 'bar', 'activeCues is still original value');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('mode can only be set to a few options', function() {
|
2015-03-25 21:43:41 -07:00
|
|
|
var tt = new TextTrack({
|
2015-05-06 14:01:52 -04:00
|
|
|
tech: defaultTech,
|
2015-02-13 15:18:07 -08:00
|
|
|
});
|
|
|
|
|
|
|
|
tt.mode = 'foo';
|
|
|
|
|
|
|
|
notEqual(tt.mode, 'foo', 'the mode is still the old value, disabled');
|
|
|
|
equal(tt.mode, 'disabled', 'still on the default mode, disabled');
|
|
|
|
|
|
|
|
tt.mode = 'hidden';
|
|
|
|
equal(tt.mode, 'hidden', 'mode set to hidden');
|
|
|
|
|
|
|
|
tt.mode = 'bar';
|
|
|
|
notEqual(tt.mode, 'bar', 'the mode is still the old value, hidden');
|
|
|
|
equal(tt.mode, 'hidden', 'still on the previous mode, hidden');
|
|
|
|
|
|
|
|
tt.mode = 'showing';
|
|
|
|
equal(tt.mode, 'showing', 'mode set to showing');
|
|
|
|
|
|
|
|
tt.mode = 'baz';
|
|
|
|
notEqual(tt.mode, 'baz', 'the mode is still the old value, showing');
|
|
|
|
equal(tt.mode, 'showing', 'still on the previous mode, showing');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('cues and activeCues return a TextTrackCueList', function() {
|
2015-03-25 21:43:41 -07:00
|
|
|
var tt = new TextTrack({
|
2015-05-06 14:01:52 -04:00
|
|
|
tech: defaultTech,
|
2015-02-13 15:18:07 -08:00
|
|
|
});
|
|
|
|
|
|
|
|
ok(tt.cues.getCueById, 'cues are a TextTrackCueList');
|
|
|
|
ok(tt.activeCues.getCueById, 'activeCues are a TextTrackCueList');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('cues can be added and removed from a TextTrack', function() {
|
2015-03-25 21:43:41 -07:00
|
|
|
var tt = new TextTrack({
|
2015-05-06 14:01:52 -04:00
|
|
|
tech: defaultTech,
|
2015-02-13 15:18:07 -08:00
|
|
|
}),
|
|
|
|
cues;
|
|
|
|
|
|
|
|
cues = tt.cues;
|
|
|
|
|
|
|
|
|
|
|
|
equal(cues.length, 0, 'start with zero cues');
|
|
|
|
|
|
|
|
tt.addCue({id: '1'});
|
|
|
|
|
|
|
|
equal(cues.length, 1, 'we have one cue');
|
|
|
|
|
|
|
|
tt.removeCue(cues.getCueById('1'));
|
|
|
|
|
|
|
|
equal(cues.length, 0, 'we have removed our one cue');
|
|
|
|
|
|
|
|
tt.addCue({id: '1'});
|
|
|
|
tt.addCue({id: '2'});
|
|
|
|
tt.addCue({id: '3'});
|
|
|
|
|
|
|
|
equal(cues.length, 3, 'we now have 3 cues');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('fires cuechange when cues become active and inactive', function() {
|
2015-03-25 21:43:41 -07:00
|
|
|
var player = TestHelpers.makePlayer(),
|
2015-02-13 15:18:07 -08:00
|
|
|
changes = 0,
|
|
|
|
cuechangeHandler,
|
2015-03-25 21:43:41 -07:00
|
|
|
tt = new TextTrack({
|
2015-05-06 14:01:52 -04:00
|
|
|
tech: player.tech,
|
2015-02-13 15:18:07 -08:00
|
|
|
mode: 'showing'
|
|
|
|
});
|
|
|
|
|
|
|
|
cuechangeHandler = function() {
|
|
|
|
changes++;
|
|
|
|
};
|
|
|
|
|
|
|
|
tt.addCue({
|
|
|
|
id: '1',
|
|
|
|
startTime: 1,
|
|
|
|
endTime: 5
|
|
|
|
});
|
|
|
|
|
|
|
|
tt.oncuechange = cuechangeHandler;
|
|
|
|
tt.addEventListener('cuechange', cuechangeHandler);
|
|
|
|
|
2015-05-06 14:01:52 -04:00
|
|
|
player.tech.currentTime = function() {
|
2015-02-13 15:18:07 -08:00
|
|
|
return 2;
|
|
|
|
};
|
|
|
|
|
2015-05-06 14:01:52 -04:00
|
|
|
player.tech.trigger('timeupdate');
|
2015-02-13 15:18:07 -08:00
|
|
|
|
|
|
|
equal(changes, 2, 'a cuechange event trigger addEventListener and oncuechange');
|
|
|
|
|
2015-05-06 14:01:52 -04:00
|
|
|
player.tech.currentTime = function() {
|
2015-02-13 15:18:07 -08:00
|
|
|
return 7;
|
|
|
|
};
|
|
|
|
|
2015-05-06 14:01:52 -04:00
|
|
|
player.tech.trigger('timeupdate');
|
2015-02-13 15:18:07 -08:00
|
|
|
|
|
|
|
equal(changes, 4, 'a cuechange event trigger addEventListener and oncuechange');
|
|
|
|
});
|