2013-02-08 17:30:00 -05:00
|
|
|
module('Plugins');
|
2013-02-04 07:55:31 -08:00
|
|
|
|
|
|
|
test('Plugin should get initialized and receive options', function(){
|
|
|
|
expect(2);
|
|
|
|
|
|
|
|
vjs.plugin('myPlugin1', function(options){
|
|
|
|
ok(true, 'Plugin initialized');
|
|
|
|
ok(options['test'], 'Option passed through');
|
|
|
|
});
|
|
|
|
|
|
|
|
vjs.plugin('myPlugin2', function(options){
|
2013-02-08 17:30:00 -05:00
|
|
|
ok(false, 'Plugin initialized and should not have been');
|
2013-02-04 07:55:31 -08:00
|
|
|
});
|
|
|
|
|
|
|
|
var player = PlayerTest.makePlayer({
|
|
|
|
'plugins': {
|
|
|
|
'myPlugin1': {
|
|
|
|
'test': true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
player.dispose();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('Plugin should have the option of being initilized outside of player init', function(){
|
2013-02-04 10:31:53 -08:00
|
|
|
expect(3);
|
2013-02-04 07:55:31 -08:00
|
|
|
|
|
|
|
vjs.plugin('myPlugin3', function(options){
|
|
|
|
ok(true, 'Plugin initialized after player init');
|
|
|
|
ok(options['test'], 'Option passed through');
|
|
|
|
});
|
|
|
|
|
|
|
|
var player = PlayerTest.makePlayer({});
|
|
|
|
|
2013-02-04 10:43:16 -08:00
|
|
|
ok(player['myPlugin3'], 'Plugin has direct access on player instance');
|
2013-02-04 07:55:31 -08:00
|
|
|
|
2013-02-04 10:43:16 -08:00
|
|
|
player['myPlugin3']({
|
2013-02-04 07:55:31 -08:00
|
|
|
'test': true
|
|
|
|
});
|
|
|
|
|
|
|
|
player.dispose();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('Plugin should be able to add a UI component', function(){
|
2013-02-04 10:31:53 -08:00
|
|
|
expect(2);
|
2013-02-04 07:55:31 -08:00
|
|
|
|
|
|
|
vjs.plugin('myPlugin4', function(options){
|
2013-02-04 10:31:53 -08:00
|
|
|
ok((this instanceof vjs.Player), 'Plugin executed in player scope by default');
|
2013-02-04 07:55:31 -08:00
|
|
|
this.addChild('component');
|
|
|
|
});
|
|
|
|
|
|
|
|
var player = PlayerTest.makePlayer({});
|
2013-02-04 10:43:16 -08:00
|
|
|
player['myPlugin4']({
|
2013-02-04 07:55:31 -08:00
|
|
|
'test': true
|
|
|
|
});
|
|
|
|
|
|
|
|
var comp = player.getChild('component');
|
2013-02-04 10:31:53 -08:00
|
|
|
ok(comp, 'Plugin added a component to the player');
|
2013-02-04 07:55:31 -08:00
|
|
|
|
|
|
|
player.dispose();
|
|
|
|
});
|
|
|
|
|
2013-02-04 16:13:37 -08:00
|
|
|
test('Plugin should overwrite plugin of same name', function(){
|
2013-02-08 17:30:00 -05:00
|
|
|
var v1Called = 0,
|
|
|
|
v2Called = 0,
|
2013-02-04 16:13:37 -08:00
|
|
|
v3Called = 0;
|
|
|
|
|
|
|
|
// Create initial plugin
|
|
|
|
vjs.plugin('myPlugin5', function(options){
|
|
|
|
v1Called++;
|
|
|
|
});
|
|
|
|
var player = PlayerTest.makePlayer({});
|
|
|
|
player['myPlugin5']({});
|
|
|
|
|
|
|
|
// Overwrite and create new player
|
|
|
|
vjs.plugin('myPlugin5', function(options){
|
|
|
|
v2Called++;
|
|
|
|
});
|
|
|
|
var player2 = PlayerTest.makePlayer({});
|
|
|
|
player2['myPlugin5']({});
|
|
|
|
|
|
|
|
// Overwrite and init new version on existing player
|
|
|
|
vjs.plugin('myPlugin5', function(options){
|
|
|
|
v3Called++;
|
|
|
|
});
|
|
|
|
player2['myPlugin5']({});
|
|
|
|
|
|
|
|
var comp = player.getChild('component');
|
|
|
|
ok(v1Called === 1, 'First version of plugin called once');
|
|
|
|
ok(v2Called === 1, 'Plugin overwritten for new player');
|
|
|
|
ok(v3Called === 1, 'Plugin overwritten for existing player');
|
|
|
|
|
|
|
|
player.dispose();
|
|
|
|
player2.dispose();
|
|
|
|
});
|
|
|
|
|
2013-02-06 16:14:42 -05:00
|
|
|
|
2013-02-11 16:18:12 -05:00
|
|
|
test('Plugins should get events in registration order', function() {
|
2013-02-06 16:14:42 -05:00
|
|
|
var order = [];
|
|
|
|
var expectedOrder = [];
|
|
|
|
var pluginName = 'orderPlugin';
|
|
|
|
var i = 0;
|
|
|
|
var name;
|
|
|
|
var player = PlayerTest.makePlayer({});
|
2013-02-11 16:18:12 -05:00
|
|
|
var plugin = function (name) {
|
|
|
|
vjs.plugin(name, function (opts) {
|
|
|
|
this.on('test', function (event) {
|
|
|
|
order.push(name);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
player[name]({});
|
|
|
|
};
|
2013-02-06 16:14:42 -05:00
|
|
|
|
|
|
|
for (; i < 3; i++ ) {
|
|
|
|
name = pluginName + i;
|
|
|
|
expectedOrder.push(name);
|
2013-02-11 16:18:12 -05:00
|
|
|
plugin(name);
|
2013-02-06 16:14:42 -05:00
|
|
|
}
|
2013-04-09 10:42:41 -07:00
|
|
|
|
2013-02-11 16:18:12 -05:00
|
|
|
vjs.plugin('testerPlugin', function (opts) {
|
2013-02-06 16:14:42 -05:00
|
|
|
this.trigger('test');
|
|
|
|
});
|
|
|
|
|
|
|
|
player['testerPlugin']({});
|
|
|
|
|
2013-02-11 16:18:12 -05:00
|
|
|
deepEqual(order, expectedOrder, 'plugins should receive events in order of initialization');
|
2013-02-06 16:14:42 -05:00
|
|
|
player.dispose();
|
|
|
|
});
|
2013-02-08 13:31:15 -05:00
|
|
|
|
|
|
|
test('Plugins should not get events after stopImmediatePropagation is called', function () {
|
|
|
|
var order = [];
|
|
|
|
var expectedOrder = [];
|
|
|
|
var pluginName = 'orderPlugin';
|
|
|
|
var i = 0;
|
|
|
|
var name;
|
|
|
|
var player = PlayerTest.makePlayer({});
|
2013-02-11 16:18:12 -05:00
|
|
|
var plugin = function (name) {
|
|
|
|
vjs.plugin(name, function (opts) {
|
|
|
|
this.on('test', function (event) {
|
|
|
|
order.push(name);
|
|
|
|
event.stopImmediatePropagation();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
player[name]({});
|
|
|
|
};
|
2013-02-08 13:31:15 -05:00
|
|
|
|
|
|
|
for (; i < 3; i++ ) {
|
|
|
|
name = pluginName + i;
|
|
|
|
expectedOrder.push(name);
|
2013-02-11 16:35:43 -05:00
|
|
|
plugin(name);
|
2013-02-08 13:31:15 -05:00
|
|
|
}
|
2013-04-09 10:42:41 -07:00
|
|
|
|
2013-02-11 16:18:12 -05:00
|
|
|
vjs.plugin('testerPlugin', function (opts) {
|
2013-02-08 13:31:15 -05:00
|
|
|
this.trigger('test');
|
|
|
|
});
|
|
|
|
|
|
|
|
player['testerPlugin']({});
|
|
|
|
|
2013-02-11 16:18:12 -05:00
|
|
|
deepEqual(order, expectedOrder.slice(0, order.length), 'plugins should receive events in order of initialization, until stopImmediatePropagation');
|
2013-02-08 13:31:15 -05:00
|
|
|
|
2013-02-11 16:18:12 -05:00
|
|
|
equal(order.length, 1, 'only one event listener should have triggered');
|
2013-02-08 13:35:35 -05:00
|
|
|
player.dispose();
|
|
|
|
});
|