2016-08-03 15:27:47 -04:00
|
|
|
/* eslint-env qunit */
|
2015-04-14 13:08:32 -07:00
|
|
|
import TextTrackMenuItem from '../../../src/js/control-bar/text-track-controls/text-track-menu-item.js';
|
2015-03-25 21:43:41 -07:00
|
|
|
import TestHelpers from '../test-helpers.js';
|
2015-05-03 16:12:38 -07:00
|
|
|
import * as browser from '../../../src/js/utils/browser.js';
|
2016-08-03 15:27:47 -04:00
|
|
|
import sinon from 'sinon';
|
2015-03-25 21:43:41 -07:00
|
|
|
|
2016-08-03 15:27:47 -04:00
|
|
|
QUnit.module('Text Track Controls', {
|
2016-08-12 13:51:31 -04:00
|
|
|
beforeEach(assert) {
|
2015-05-21 21:46:36 -07:00
|
|
|
this.clock = sinon.useFakeTimers();
|
|
|
|
},
|
2016-08-12 13:51:31 -04:00
|
|
|
afterEach(assert) {
|
2015-05-21 21:46:36 -07:00
|
|
|
this.clock.restore();
|
|
|
|
}
|
|
|
|
});
|
2015-02-13 15:18:07 -08:00
|
|
|
|
2016-03-07 14:54:32 -05:00
|
|
|
const track = {
|
2015-02-13 15:18:07 -08:00
|
|
|
kind: 'captions',
|
|
|
|
label: 'test'
|
|
|
|
};
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
QUnit.test('should be displayed when text tracks list is not empty', function(assert) {
|
2016-08-03 15:27:47 -04:00
|
|
|
const player = TestHelpers.makePlayer({
|
2015-02-13 15:18:07 -08:00
|
|
|
tracks: [track]
|
|
|
|
});
|
|
|
|
|
2015-05-21 21:46:36 -07:00
|
|
|
this.clock.tick(1000);
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.ok(!player.controlBar.captionsButton.hasClass('vjs-hidden'),
|
2016-08-03 15:27:47 -04:00
|
|
|
'control is displayed');
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.equal(player.textTracks().length, 1, 'textTracks contains one item');
|
2015-08-24 17:46:54 -07:00
|
|
|
|
|
|
|
player.dispose();
|
2015-02-13 15:18:07 -08:00
|
|
|
});
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
QUnit.test('should be displayed when a text track is added to an empty track list', function(assert) {
|
2016-08-03 15:27:47 -04:00
|
|
|
const player = TestHelpers.makePlayer();
|
2015-02-13 15:18:07 -08:00
|
|
|
|
|
|
|
player.addRemoteTextTrack(track);
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.ok(!player.controlBar.captionsButton.hasClass('vjs-hidden'),
|
2016-08-03 15:27:47 -04:00
|
|
|
'control is displayed');
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.equal(player.textTracks().length, 1, 'textTracks contains one item');
|
2015-08-24 17:46:54 -07:00
|
|
|
|
|
|
|
player.dispose();
|
2015-02-13 15:18:07 -08:00
|
|
|
});
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
QUnit.test('should not be displayed when text tracks list is empty', function(assert) {
|
2016-08-03 15:27:47 -04:00
|
|
|
const player = TestHelpers.makePlayer();
|
2015-02-13 15:18:07 -08:00
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.ok(player.controlBar.captionsButton.hasClass('vjs-hidden'),
|
2016-08-03 15:27:47 -04:00
|
|
|
'control is not displayed');
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.equal(player.textTracks().length, 0, 'textTracks is empty');
|
2015-08-24 17:46:54 -07:00
|
|
|
|
|
|
|
player.dispose();
|
2015-02-13 15:18:07 -08:00
|
|
|
});
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
QUnit.test('should not be displayed when last text track is removed', function(assert) {
|
2016-08-03 15:27:47 -04:00
|
|
|
const player = TestHelpers.makePlayer({
|
2015-02-13 15:18:07 -08:00
|
|
|
tracks: [track]
|
|
|
|
});
|
|
|
|
|
|
|
|
player.removeRemoteTextTrack(player.textTracks()[0]);
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.ok(player.controlBar.captionsButton.hasClass('vjs-hidden'),
|
2016-08-03 15:27:47 -04:00
|
|
|
'control is not displayed');
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.equal(player.textTracks().length, 0, 'textTracks is empty');
|
2015-08-24 17:46:54 -07:00
|
|
|
|
|
|
|
player.dispose();
|
2015-02-13 15:18:07 -08:00
|
|
|
});
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
QUnit.test('menu should contain "Settings", "Off" and one track', function(assert) {
|
2016-08-03 15:27:47 -04:00
|
|
|
const player = TestHelpers.makePlayer({
|
2016-03-07 14:54:32 -05:00
|
|
|
tracks: [track]
|
|
|
|
});
|
2015-05-21 21:46:36 -07:00
|
|
|
|
|
|
|
this.clock.tick(1000);
|
|
|
|
|
2016-08-03 15:27:47 -04:00
|
|
|
const menuItems = player.controlBar.captionsButton.items;
|
2015-02-13 15:18:07 -08:00
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.equal(menuItems.length, 3, 'menu contains three items');
|
|
|
|
assert.equal(menuItems[0].track.label,
|
2016-08-03 15:27:47 -04:00
|
|
|
'captions settings',
|
|
|
|
'menu contains "captions settings"');
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.equal(menuItems[1].track.label, 'captions off', 'menu contains "captions off"');
|
|
|
|
assert.equal(menuItems[2].track.label, 'test', 'menu contains "test" track');
|
2015-08-24 17:46:54 -07:00
|
|
|
|
|
|
|
player.dispose();
|
2015-02-13 15:18:07 -08:00
|
|
|
});
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
QUnit.test('menu should update with addRemoteTextTrack', function(assert) {
|
2016-08-03 15:27:47 -04:00
|
|
|
const player = TestHelpers.makePlayer({
|
2015-02-13 15:18:07 -08:00
|
|
|
tracks: [track]
|
|
|
|
});
|
|
|
|
|
2015-05-21 21:46:36 -07:00
|
|
|
this.clock.tick(1000);
|
|
|
|
|
2015-02-13 15:18:07 -08:00
|
|
|
player.addRemoteTextTrack(track);
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.equal(player.controlBar.captionsButton.items.length,
|
2016-08-03 15:27:47 -04:00
|
|
|
4,
|
|
|
|
'menu does contain added track');
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.equal(player.textTracks().length, 2, 'textTracks contains two items');
|
2015-08-24 17:46:54 -07:00
|
|
|
|
|
|
|
player.dispose();
|
2015-02-13 15:18:07 -08:00
|
|
|
});
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
QUnit.test('menu should update with removeRemoteTextTrack', function(assert) {
|
2016-08-03 15:27:47 -04:00
|
|
|
const player = TestHelpers.makePlayer({
|
2015-02-13 15:18:07 -08:00
|
|
|
tracks: [track, track]
|
|
|
|
});
|
|
|
|
|
2015-05-21 21:46:36 -07:00
|
|
|
this.clock.tick(1000);
|
|
|
|
|
2015-02-13 15:18:07 -08:00
|
|
|
player.removeRemoteTextTrack(player.textTracks()[0]);
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.equal(player.controlBar.captionsButton.items.length,
|
2016-08-03 15:27:47 -04:00
|
|
|
3,
|
|
|
|
'menu does not contain removed track');
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.equal(player.textTracks().length, 1, 'textTracks contains one item');
|
2015-08-24 17:46:54 -07:00
|
|
|
|
|
|
|
player.dispose();
|
2015-02-13 15:18:07 -08:00
|
|
|
});
|
|
|
|
|
2016-08-03 15:27:47 -04:00
|
|
|
const descriptionstrack = {
|
2016-03-25 14:16:56 -04:00
|
|
|
kind: 'descriptions',
|
|
|
|
label: 'desc'
|
|
|
|
};
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
QUnit.test('descriptions should be displayed when text tracks list is not empty', function(assert) {
|
2016-08-03 15:27:47 -04:00
|
|
|
const player = TestHelpers.makePlayer({
|
2016-03-25 14:16:56 -04:00
|
|
|
tracks: [descriptionstrack]
|
|
|
|
});
|
|
|
|
|
|
|
|
this.clock.tick(1000);
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.ok(!player.controlBar.descriptionsButton.hasClass('vjs-hidden'),
|
2016-08-03 15:27:47 -04:00
|
|
|
'descriptions control is displayed');
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.equal(player.textTracks().length, 1, 'textTracks contains one item');
|
2016-03-25 14:16:56 -04:00
|
|
|
|
|
|
|
player.dispose();
|
|
|
|
});
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
QUnit.test('descriptions should be displayed when a text track is added to an empty track list', function(assert) {
|
2016-08-03 15:27:47 -04:00
|
|
|
const player = TestHelpers.makePlayer();
|
2016-03-25 14:16:56 -04:00
|
|
|
|
|
|
|
player.addRemoteTextTrack(descriptionstrack);
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.ok(!player.controlBar.descriptionsButton.hasClass('vjs-hidden'),
|
2016-08-03 15:27:47 -04:00
|
|
|
'control is displayed');
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.equal(player.textTracks().length, 1, 'textTracks contains one item');
|
2016-03-25 14:16:56 -04:00
|
|
|
|
|
|
|
player.dispose();
|
|
|
|
});
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
QUnit.test('descriptions should not be displayed when text tracks list is empty', function(assert) {
|
2016-08-03 15:27:47 -04:00
|
|
|
const player = TestHelpers.makePlayer();
|
2016-03-25 14:16:56 -04:00
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.ok(player.controlBar.descriptionsButton.hasClass('vjs-hidden'),
|
2016-08-03 15:27:47 -04:00
|
|
|
'control is not displayed');
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.equal(player.textTracks().length, 0, 'textTracks is empty');
|
2016-03-25 14:16:56 -04:00
|
|
|
|
|
|
|
player.dispose();
|
|
|
|
});
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
QUnit.test('descriptions should not be displayed when last text track is removed', function(assert) {
|
2016-08-03 15:27:47 -04:00
|
|
|
const player = TestHelpers.makePlayer({
|
2016-03-25 14:16:56 -04:00
|
|
|
tracks: [descriptionstrack]
|
|
|
|
});
|
|
|
|
|
|
|
|
player.removeRemoteTextTrack(player.textTracks()[0]);
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.ok(player.controlBar.descriptionsButton.hasClass('vjs-hidden'),
|
2016-08-03 15:27:47 -04:00
|
|
|
'control is not displayed');
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.equal(player.textTracks().length, 0, 'textTracks is empty');
|
2016-03-25 14:16:56 -04:00
|
|
|
|
|
|
|
player.dispose();
|
|
|
|
});
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
QUnit.test('descriptions menu should contain "Off" and one track', function(assert) {
|
2016-08-03 15:27:47 -04:00
|
|
|
const player = TestHelpers.makePlayer({
|
|
|
|
tracks: [descriptionstrack]
|
|
|
|
});
|
2016-03-25 14:16:56 -04:00
|
|
|
|
|
|
|
this.clock.tick(1000);
|
|
|
|
|
2016-08-03 15:27:47 -04:00
|
|
|
const menuItems = player.controlBar.descriptionsButton.items;
|
2016-03-25 14:16:56 -04:00
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.equal(menuItems.length, 2, 'descriptions menu contains two items');
|
|
|
|
assert.equal(menuItems[0].track.label,
|
2016-08-03 15:27:47 -04:00
|
|
|
'descriptions off',
|
|
|
|
'menu contains "descriptions off"');
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.equal(menuItems[1].track.label, 'desc', 'menu contains "desc" track');
|
2016-03-25 14:16:56 -04:00
|
|
|
|
|
|
|
player.dispose();
|
|
|
|
});
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
QUnit.test('enabling a captions track should disable the descriptions menu button', function(assert) {
|
|
|
|
assert.expect(14);
|
2016-03-25 14:16:56 -04:00
|
|
|
|
2016-08-03 15:27:47 -04:00
|
|
|
const player = TestHelpers.makePlayer({
|
2016-03-25 14:16:56 -04:00
|
|
|
tracks: [track, descriptionstrack]
|
|
|
|
});
|
|
|
|
|
|
|
|
this.clock.tick(1000);
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.ok(!player.controlBar.captionsButton.hasClass('vjs-hidden'),
|
2016-08-03 15:27:47 -04:00
|
|
|
'captions control is displayed');
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.ok(!player.controlBar.descriptionsButton.hasClass('vjs-hidden'),
|
2016-08-03 15:27:47 -04:00
|
|
|
'descriptions control is displayed');
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.equal(player.textTracks().length, 2, 'textTracks contains two items');
|
2016-03-25 14:16:56 -04:00
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.ok(!player.controlBar.captionsButton.hasClass('vjs-disabled'),
|
2016-08-03 15:27:47 -04:00
|
|
|
'captions control is NOT disabled');
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.ok(!player.controlBar.descriptionsButton.hasClass('vjs-disabled'),
|
2016-08-03 15:27:47 -04:00
|
|
|
'descriptions control is NOT disabled');
|
2016-03-25 14:16:56 -04:00
|
|
|
|
|
|
|
for (let i = 0; i < player.textTracks().length; i++) {
|
|
|
|
if (player.textTracks()[i].kind === 'descriptions') {
|
|
|
|
player.textTracks()[i].mode = 'showing';
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.ok(player.textTracks()[i].kind === 'descriptions' &&
|
2016-08-03 15:27:47 -04:00
|
|
|
player.textTracks()[i].mode === 'showing',
|
|
|
|
'descriptions mode set to showing');
|
2016-03-25 14:16:56 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
this.clock.tick(1000);
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.ok(!player.controlBar.captionsButton.hasClass('vjs-disabled'),
|
2016-08-03 15:27:47 -04:00
|
|
|
'captions control is NOT disabled');
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.ok(!player.controlBar.descriptionsButton.hasClass('vjs-disabled'),
|
2016-08-03 15:27:47 -04:00
|
|
|
'descriptions control is NOT disabled');
|
2016-03-25 14:16:56 -04:00
|
|
|
|
|
|
|
for (let i = 0; i < player.textTracks().length; i++) {
|
|
|
|
if (player.textTracks()[i].kind === 'captions') {
|
|
|
|
player.textTracks()[i].mode = 'showing';
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.ok(player.textTracks()[i].kind === 'captions' &&
|
2016-08-03 15:27:47 -04:00
|
|
|
player.textTracks()[i].mode === 'showing',
|
|
|
|
'captions mode set to showing');
|
2016-03-25 14:16:56 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
this.clock.tick(1000);
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.ok(!player.controlBar.captionsButton.hasClass('vjs-disabled'),
|
2016-08-03 15:27:47 -04:00
|
|
|
'captions control is NOT disabled');
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.ok(player.controlBar.descriptionsButton.hasClass('vjs-disabled'),
|
2016-08-03 15:27:47 -04:00
|
|
|
'descriptions control IS disabled');
|
2016-03-25 14:16:56 -04:00
|
|
|
|
|
|
|
for (let i = 0; i < player.textTracks().length; i++) {
|
|
|
|
if (player.textTracks()[i].kind === 'captions') {
|
|
|
|
player.textTracks()[i].mode = 'disabled';
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.ok(player.textTracks()[i].kind === 'captions' &&
|
2016-08-03 15:27:47 -04:00
|
|
|
player.textTracks()[i].mode === 'disabled',
|
|
|
|
'captions mode set to disabled');
|
2016-03-25 14:16:56 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
this.clock.tick(1000);
|
|
|
|
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.ok(!player.controlBar.captionsButton.hasClass('vjs-disabled'),
|
2016-08-03 15:27:47 -04:00
|
|
|
'captions control is NOT disabled');
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.ok(!player.controlBar.descriptionsButton.hasClass('vjs-disabled'),
|
2016-08-03 15:27:47 -04:00
|
|
|
'descriptions control is NOT disabled');
|
2016-03-25 14:16:56 -04:00
|
|
|
|
|
|
|
player.dispose();
|
|
|
|
});
|
|
|
|
|
2015-05-03 16:12:38 -07:00
|
|
|
if (!browser.IS_IE8) {
|
2015-02-13 15:18:07 -08:00
|
|
|
// This test doesn't work on IE8.
|
2016-08-03 15:27:47 -04:00
|
|
|
// However, this test tests a specific with iOS7 where
|
|
|
|
// the TextTrackList doesn't report track mode changes.
|
2015-02-13 15:18:07 -08:00
|
|
|
// TODO: figure out why this test doens't work on IE8. https://github.com/videojs/video.js/issues/1861
|
2016-08-12 13:51:31 -04:00
|
|
|
QUnit.test('menu items should polyfill mode change events', function(assert) {
|
2016-08-03 15:27:47 -04:00
|
|
|
const player = TestHelpers.makePlayer({});
|
2016-03-07 14:54:32 -05:00
|
|
|
let changes;
|
2015-02-13 15:18:07 -08:00
|
|
|
|
|
|
|
// emulate a TextTrackList that doesn't report track mode changes,
|
|
|
|
// like iOS7
|
|
|
|
player.textTracks().onchange = undefined;
|
2016-08-03 15:27:47 -04:00
|
|
|
const trackMenuItem = new TextTrackMenuItem(player, {
|
2016-03-07 14:54:32 -05:00
|
|
|
track
|
2015-02-13 15:18:07 -08:00
|
|
|
});
|
|
|
|
|
|
|
|
player.textTracks().on('change', function() {
|
|
|
|
changes++;
|
|
|
|
});
|
|
|
|
changes = 0;
|
|
|
|
trackMenuItem.trigger('tap');
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.equal(changes, 1, 'taps trigger change events');
|
2015-02-13 15:18:07 -08:00
|
|
|
|
|
|
|
trackMenuItem.trigger('click');
|
2016-08-12 13:51:31 -04:00
|
|
|
assert.equal(changes, 2, 'clicks trigger change events');
|
2015-08-24 17:46:54 -07:00
|
|
|
|
|
|
|
player.dispose();
|
2015-02-13 15:18:07 -08:00
|
|
|
});
|
|
|
|
}
|