2013-02-09 01:29:04 +03:00
|
|
|
module('Player');
|
2013-01-11 00:06:12 +03:00
|
|
|
|
|
|
|
var PlayerTest = {
|
|
|
|
makeTag: function(){
|
2012-12-11 03:40:12 +03:00
|
|
|
var videoTag = document.createElement('video');
|
|
|
|
videoTag.id = 'example_1';
|
|
|
|
videoTag.className = 'video-js vjs-default-skin';
|
2013-01-11 00:06:12 +03:00
|
|
|
return videoTag;
|
|
|
|
},
|
|
|
|
makePlayer: function(playerOptions){
|
2013-01-26 04:36:40 +03:00
|
|
|
var player;
|
2013-01-11 00:06:12 +03:00
|
|
|
var videoTag = PlayerTest.makeTag();
|
2012-12-11 03:40:12 +03:00
|
|
|
|
|
|
|
var fixture = document.getElementById('qunit-fixture');
|
|
|
|
fixture.appendChild(videoTag);
|
|
|
|
|
2013-01-26 04:36:40 +03:00
|
|
|
var opts = vjs.obj.merge({
|
2013-01-18 04:33:53 +03:00
|
|
|
'techOrder': ['mediaFaker']
|
|
|
|
}, playerOptions);
|
|
|
|
|
|
|
|
return player = new vjs.Player(videoTag, opts);
|
2012-12-11 03:40:12 +03:00
|
|
|
}
|
2013-01-11 00:06:12 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
// Compiler doesn't like using 'this' in setup/teardown.
|
|
|
|
// module("Player", {
|
|
|
|
// /**
|
|
|
|
// * @this {*}
|
|
|
|
// */
|
|
|
|
// setup: function(){
|
|
|
|
// window.player1 = true; // using window works
|
|
|
|
// },
|
|
|
|
|
|
|
|
// /**
|
|
|
|
// * @this {*}
|
|
|
|
// */
|
|
|
|
// teardown: function(){
|
|
|
|
// // if (this.player && this.player.el() !== null) {
|
|
|
|
// // this.player.dispose();
|
|
|
|
// // this.player = null;
|
|
|
|
// // }
|
|
|
|
// }
|
|
|
|
// });
|
|
|
|
|
|
|
|
// Object.size = function(obj) {
|
|
|
|
// var size = 0, key;
|
|
|
|
// for (key in obj) {
|
|
|
|
// console.log('key', key)
|
|
|
|
// if (obj.hasOwnProperty(key)) size++;
|
|
|
|
// }
|
|
|
|
// return size;
|
|
|
|
// };
|
|
|
|
|
|
|
|
|
|
|
|
test('should create player instance that inherits from component and dispose it', function(){
|
|
|
|
var player = PlayerTest.makePlayer();
|
|
|
|
|
|
|
|
ok(player.el().nodeName === 'DIV');
|
|
|
|
ok(player.on, 'component function exists');
|
|
|
|
|
|
|
|
player.dispose();
|
|
|
|
ok(player.el() === null, 'element disposed');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should accept options from multiple sources and override in correct order', function(){
|
|
|
|
// For closure compiler to work, all reference to the prop have to be the same type
|
|
|
|
// As in options['attr'] or options.attr. Compiler will minimize each separately.
|
|
|
|
// Since we're using setAttribute which requires a string, we have to use the string
|
|
|
|
// version of the key for all version.
|
|
|
|
|
|
|
|
// Set a global option
|
|
|
|
vjs.options['attr'] = 1;
|
|
|
|
|
|
|
|
var tag0 = PlayerTest.makeTag();
|
|
|
|
var player0 = new vjs.Player(tag0);
|
|
|
|
|
2013-02-09 01:29:04 +03:00
|
|
|
ok(player0.options_['attr'] === 1, 'global option was set');
|
2013-01-11 00:06:12 +03:00
|
|
|
player0.dispose();
|
|
|
|
|
|
|
|
// Set a tag level option
|
|
|
|
var tag1 = PlayerTest.makeTag();
|
|
|
|
tag1.setAttribute('attr', 'asdf'); // Attributes must be set as strings
|
|
|
|
|
|
|
|
var player1 = new vjs.Player(tag1);
|
2013-01-18 05:03:25 +03:00
|
|
|
ok(player1.options_['attr'] === 'asdf', 'Tag options overrode global options');
|
2013-01-11 00:06:12 +03:00
|
|
|
player1.dispose();
|
|
|
|
|
|
|
|
// Set a tag level option
|
|
|
|
var tag2 = PlayerTest.makeTag();
|
|
|
|
tag2.setAttribute('attr', 'asdf');
|
|
|
|
|
|
|
|
var player2 = new vjs.Player(tag2, { 'attr': 'fdsa' });
|
2013-01-18 05:03:25 +03:00
|
|
|
ok(player2.options_['attr'] === 'fdsa', 'Init options overrode tag and global options');
|
2013-01-11 00:06:12 +03:00
|
|
|
player2.dispose();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should get tag, source, and track settings', function(){
|
|
|
|
// Partially tested in lib->getAttributeValues
|
|
|
|
|
|
|
|
var fixture = document.getElementById('qunit-fixture');
|
|
|
|
|
2013-02-09 01:29:04 +03:00
|
|
|
var html = '<video id="example_1" class="video-js" autoplay preload="metadata">';
|
2013-01-11 00:06:12 +03:00
|
|
|
html += '<source src="http://google.com" type="video/mp4">';
|
|
|
|
html += '<source src="http://google.com" type="video/webm">';
|
|
|
|
html += '<track src="http://google.com" kind="captions" default>';
|
|
|
|
html += '</video>';
|
|
|
|
|
|
|
|
fixture.innerHTML += html;
|
|
|
|
|
|
|
|
var tag = document.getElementById('example_1');
|
|
|
|
var player = new vjs.Player(tag);
|
|
|
|
|
2013-01-18 05:03:25 +03:00
|
|
|
ok(player.options_['autoplay'] === true);
|
|
|
|
ok(player.options_['preload'] === 'metadata'); // No extern. Use string.
|
|
|
|
ok(player.options_['id'] === 'example_1');
|
|
|
|
ok(player.options_['sources'].length === 2);
|
|
|
|
ok(player.options_['sources'][0].src === 'http://google.com');
|
|
|
|
ok(player.options_['sources'][0].type === 'video/mp4');
|
|
|
|
ok(player.options_['sources'][1].type === 'video/webm');
|
|
|
|
ok(player.options_['tracks'].length === 1);
|
|
|
|
ok(player.options_['tracks'][0]['kind'] === 'captions'); // No extern
|
|
|
|
ok(player.options_['tracks'][0]['default'] === true);
|
2013-01-11 00:06:12 +03:00
|
|
|
|
|
|
|
ok(player.el().className.indexOf('video-js') !== -1, 'transferred class from tag to player div');
|
|
|
|
ok(player.el().id === 'example_1', 'transferred id from tag to player div');
|
|
|
|
|
2013-01-17 04:24:38 +03:00
|
|
|
ok(tag['player'] === player, 'player referenceable on original tag');
|
2013-01-11 00:06:12 +03:00
|
|
|
ok(vjs.players[player.id()] === player, 'player referenceable from global list');
|
|
|
|
ok(tag.id !== player.id, 'tag ID no longer is the same as player ID');
|
|
|
|
ok(tag.className !== player.el().className, 'tag classname updated');
|
|
|
|
|
|
|
|
player.dispose();
|
|
|
|
|
2013-02-09 01:29:04 +03:00
|
|
|
ok(tag['player'] === null, 'tag player ref killed');
|
|
|
|
ok(!vjs.players['example_1'], 'global player ref killed');
|
|
|
|
ok(player.el() === null, 'player el killed');
|
2012-12-11 03:40:12 +03:00
|
|
|
});
|
|
|
|
|
2013-01-11 00:06:12 +03:00
|
|
|
test('should set the width and height of the player', function(){
|
|
|
|
var player = PlayerTest.makePlayer({ width: 123, height: '100%' });
|
|
|
|
|
2013-02-09 01:29:04 +03:00
|
|
|
ok(player.width() === 123);
|
|
|
|
ok(player.el().style.width === '123px');
|
2013-01-11 00:06:12 +03:00
|
|
|
|
|
|
|
var fixture = document.getElementById('qunit-fixture');
|
|
|
|
var container = document.createElement('div');
|
|
|
|
fixture.appendChild(container);
|
|
|
|
|
|
|
|
// Player container needs to have height in order to have height
|
|
|
|
// Don't want to mess with the fixture itself
|
|
|
|
container.appendChild(player.el());
|
2013-02-09 01:29:04 +03:00
|
|
|
container.style.height = '1000px';
|
2013-01-11 00:06:12 +03:00
|
|
|
ok(player.height() === 1000);
|
|
|
|
|
|
|
|
player.dispose();
|
|
|
|
});
|
|
|
|
|
2013-03-09 11:39:28 +03:00
|
|
|
test('should not force width and height', function() {
|
|
|
|
var player = PlayerTest.makePlayer({ width: 'auto', height: 'auto' });
|
|
|
|
ok(player.el().style.width === '', 'Width is not forced');
|
|
|
|
ok(player.el().style.height === '', 'Height is not forced');
|
|
|
|
|
|
|
|
player.dispose();
|
|
|
|
});
|
|
|
|
|
2013-01-11 00:06:12 +03:00
|
|
|
test('should accept options from multiple sources and override in correct order', function(){
|
|
|
|
var tag = PlayerTest.makeTag();
|
|
|
|
var container = document.createElement('div');
|
|
|
|
var fixture = document.getElementById('qunit-fixture');
|
|
|
|
|
|
|
|
container.appendChild(tag);
|
|
|
|
fixture.appendChild(container);
|
|
|
|
|
|
|
|
var player = new vjs.Player(tag);
|
|
|
|
var el = player.el();
|
|
|
|
|
2013-02-09 01:29:04 +03:00
|
|
|
ok(el.parentNode === container, 'player placed at same level as tag');
|
2013-01-11 00:06:12 +03:00
|
|
|
// Tag may be placed inside the player element or it may be removed from the DOM
|
2013-02-09 01:29:04 +03:00
|
|
|
ok(tag.parentNode !== container, 'tag removed from original place');
|
2013-01-11 00:06:12 +03:00
|
|
|
|
|
|
|
player.dispose();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should load a media controller', function(){
|
|
|
|
var player = PlayerTest.makePlayer({
|
|
|
|
preload: 'none',
|
|
|
|
sources: [
|
2013-02-09 01:29:04 +03:00
|
|
|
{ src: 'http://google.com', type: 'video/mp4' },
|
|
|
|
{ src: 'http://google.com', type: 'video/webm' }
|
2013-01-11 00:06:12 +03:00
|
|
|
]
|
|
|
|
});
|
|
|
|
|
2013-02-09 01:29:04 +03:00
|
|
|
ok(player.el().children[0].className.indexOf('vjs-tech') !== -1, 'media controller loaded');
|
2013-01-11 00:06:12 +03:00
|
|
|
|
|
|
|
player.dispose();
|
|
|
|
});
|
2013-01-18 04:33:53 +03:00
|
|
|
|
|
|
|
test('should not play if firstplay event prevents default', function(){
|
|
|
|
expect(1);
|
|
|
|
var player = PlayerTest.makePlayer({
|
|
|
|
'preload': 'none',
|
|
|
|
'autoplay': false,
|
|
|
|
'sources': [
|
2013-02-09 01:29:04 +03:00
|
|
|
{ 'src': 'http://google.com', 'type': 'video/mp4' },
|
|
|
|
{ 'src': 'http://google.com', 'type': 'video/webm' }
|
2013-01-18 04:33:53 +03:00
|
|
|
]
|
|
|
|
});
|
|
|
|
|
|
|
|
player.on('firstplay', function(e){
|
|
|
|
ok(true, 'firstplay triggered');
|
|
|
|
|
|
|
|
e.preventDefault();
|
|
|
|
});
|
|
|
|
|
|
|
|
player.on('play', function(){
|
2013-02-09 01:29:04 +03:00
|
|
|
ok(false, 'play triggered anyway');
|
2013-01-18 04:33:53 +03:00
|
|
|
});
|
|
|
|
|
|
|
|
player.play();
|
|
|
|
|
|
|
|
player.dispose();
|
|
|
|
});
|