2015-09-02 15:47:10 -07:00
|
|
|
import registerPlugin from '../../src/js/plugins.js';
|
2015-03-25 21:43:41 -07:00
|
|
|
import Player from '../../src/js/player.js';
|
|
|
|
import TestHelpers from './test-helpers.js';
|
2015-03-06 01:53:00 +01:00
|
|
|
import window from 'global/window';
|
2015-03-25 21:43:41 -07:00
|
|
|
|
|
|
|
q.module('Plugins');
|
2013-02-04 07:55:31 -08:00
|
|
|
|
|
|
|
test('Plugin should get initialized and receive options', function(){
|
|
|
|
expect(2);
|
|
|
|
|
2015-09-02 15:47:10 -07:00
|
|
|
registerPlugin('myPlugin1', function(options){
|
2013-02-04 07:55:31 -08:00
|
|
|
ok(true, 'Plugin initialized');
|
|
|
|
ok(options['test'], 'Option passed through');
|
|
|
|
});
|
|
|
|
|
2015-09-02 15:47:10 -07:00
|
|
|
registerPlugin('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
|
|
|
});
|
|
|
|
|
2015-03-25 21:43:41 -07:00
|
|
|
var player = TestHelpers.makePlayer({
|
2013-02-04 07:55:31 -08:00
|
|
|
'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
|
|
|
|
2015-09-02 15:47:10 -07:00
|
|
|
registerPlugin('myPlugin3', function(options){
|
2013-02-04 07:55:31 -08:00
|
|
|
ok(true, 'Plugin initialized after player init');
|
|
|
|
ok(options['test'], 'Option passed through');
|
|
|
|
});
|
|
|
|
|
2015-03-25 21:43:41 -07:00
|
|
|
var player = TestHelpers.makePlayer({});
|
2013-02-04 07:55:31 -08:00
|
|
|
|
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
|
|
|
|
2015-09-02 15:47:10 -07:00
|
|
|
registerPlugin('myPlugin4', function(options){
|
2015-03-25 21:43:41 -07:00
|
|
|
ok((this instanceof Player), 'Plugin executed in player scope by default');
|
2013-02-04 07:55:31 -08:00
|
|
|
this.addChild('component');
|
|
|
|
});
|
|
|
|
|
2015-03-25 21:43:41 -07:00
|
|
|
var player = TestHelpers.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
|
2015-09-02 15:47:10 -07:00
|
|
|
registerPlugin('myPlugin5', function(options){
|
2013-02-04 16:13:37 -08:00
|
|
|
v1Called++;
|
|
|
|
});
|
2015-03-25 21:43:41 -07:00
|
|
|
var player = TestHelpers.makePlayer({});
|
2013-02-04 16:13:37 -08:00
|
|
|
player['myPlugin5']({});
|
|
|
|
|
|
|
|
// Overwrite and create new player
|
2015-09-02 15:47:10 -07:00
|
|
|
registerPlugin('myPlugin5', function(options){
|
2013-02-04 16:13:37 -08:00
|
|
|
v2Called++;
|
|
|
|
});
|
2015-03-25 21:43:41 -07:00
|
|
|
var player2 = TestHelpers.makePlayer({});
|
2013-02-04 16:13:37 -08:00
|
|
|
player2['myPlugin5']({});
|
|
|
|
|
|
|
|
// Overwrite and init new version on existing player
|
2015-09-02 15:47:10 -07:00
|
|
|
registerPlugin('myPlugin5', function(options){
|
2013-02-04 16:13:37 -08:00
|
|
|
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;
|
2015-03-25 21:43:41 -07:00
|
|
|
var player = TestHelpers.makePlayer({});
|
2013-02-11 16:18:12 -05:00
|
|
|
var plugin = function (name) {
|
2015-09-02 15:47:10 -07:00
|
|
|
registerPlugin(name, function (opts) {
|
2013-02-11 16:18:12 -05:00
|
|
|
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
|
|
|
|
2015-09-02 15:47:10 -07:00
|
|
|
registerPlugin('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;
|
2015-03-25 21:43:41 -07:00
|
|
|
var player = TestHelpers.makePlayer({});
|
2013-02-11 16:18:12 -05:00
|
|
|
var plugin = function (name) {
|
2015-09-02 15:47:10 -07:00
|
|
|
registerPlugin(name, function (opts) {
|
2013-02-11 16:18:12 -05:00
|
|
|
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
|
|
|
|
2015-09-02 15:47:10 -07:00
|
|
|
registerPlugin('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();
|
|
|
|
});
|
2015-03-06 01:53:00 +01:00
|
|
|
|
|
|
|
test('Plugin that does not exist logs an error', function() {
|
|
|
|
// stub the global log functions
|
|
|
|
var console, log, error, origConsole;
|
|
|
|
origConsole = window['console'];
|
|
|
|
console = window['console'] = {
|
|
|
|
log: function(){},
|
|
|
|
warn: function(){},
|
|
|
|
error: function(){}
|
|
|
|
};
|
|
|
|
log = sinon.stub(console, 'log');
|
|
|
|
error = sinon.stub(console, 'error');
|
|
|
|
|
|
|
|
// enable a non-existing plugin
|
|
|
|
TestHelpers.makePlayer({
|
|
|
|
plugins: {
|
|
|
|
'nonExistingPlugin': {
|
|
|
|
'foo': 'bar'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
ok(error.called, 'error was called');
|
|
|
|
equal(error.firstCall.args[2], 'Unable to find plugin:');
|
|
|
|
equal(error.firstCall.args[3], 'nonExistingPlugin');
|
|
|
|
|
|
|
|
// tear down logging stubs
|
|
|
|
log.restore();
|
|
|
|
error.restore();
|
|
|
|
window['console'] = origConsole;
|
|
|
|
});
|