1
0
mirror of https://github.com/videojs/video.js.git synced 2025-01-08 07:00:10 +02:00
video.js/test/unit/events.test.js

242 lines
6.6 KiB
JavaScript
Raw Normal View History

Broke up Lib and Util into smaller libraries of functions Broke out bind, guid, and element data functions from Lib Separated out more dom functions in to dom.js Broke out URL functions into url.js Removed setLocalStorage since it wasn't being used Moved browser tests out of lib Moved log functions into their own file Removed trim() since it wasn't being used Moved formatTime into its own file Moved round into its own file and renamed roundFloat() Moved capitalize into its own file and renamed as toTitleCase() Moved createTimeRange into its own file Removed Lib.arr.forEach infavor of the native forEach Removed Lib.obj.create in favor of native Object.create (ES6-sham) Removed obj.each in favor of native Object.getOwnPropertyNames().forEach() Removed obj.merge and copy. Using lodash.assign instead. Replaced Lib.obj.isPlain with lodash.isPlainObject Removed Lib.obj.isArray in favor of the native Array.isArray Also removed the lib.js tests file as all tests have been moved or removed. Removed Lib.isEmpty in favor of !Object.getOwnPropertyNames().length Switched Util.mergeOptions and deepMerge to use new mergeOptions() Moved Lib.TEST_VID to Html5.TEST_VID Removed Lib references everywhere. Woo! Attempting to fix sourcemap test errors by setting grunt-browserify version Switched to object.assign from lodash.assign Removed unused 'inherits' dependency Reorganzied test files and added '.test' to file names Combined js/core.js and js/video.js Moved events.js into the utils directory
2015-05-04 01:12:38 +02:00
import * as Events from '../../src/js/utils/events.js';
import document from 'global/document';
q.module('Events');
test('should add and remove an event listener to an element', function(){
expect(1);
var el = document.createElement('div');
var listener = function(){
ok(true, 'Click Triggered');
};
Events.on(el, 'click', listener);
Events.trigger(el, 'click'); // 1 click
Events.off(el, 'click', listener);
Events.trigger(el, 'click'); // No click should happen.
});
test('should add and remove multiple event listeners to an element with a single call', function(){
expect(6);
var el = document.createElement('div');
var listener = function(){
ok(true, 'Callback triggered');
};
Events.on(el, ['click', 'event1', 'event2'], listener);
Events.trigger(el, 'click');
Events.trigger(el, 'click');
Events.off(el, 'click', listener);
Events.trigger(el, 'click'); // No click should happen.
Events.trigger(el, 'event1');
Events.trigger(el, 'event1');
Events.off(el, 'event1', listener);
Events.trigger(el, 'event1'); // No event1 should happen.
Events.trigger(el, 'event2');
Events.trigger(el, 'event2');
Events.off(el, 'event2', listener);
Events.trigger(el, 'event2'); // No event2 should happen.
});
test('should be possible to pass data when you trigger an event', function () {
expect(6);
var el = document.createElement('div');
var fakeData1 = 'Fake Data 1';
var fakeData2 = {txt: 'Fake Data 2'};
var listener = function(evt, hash){
ok(true, 'Callback triggered');
deepEqual(fakeData1, hash.d1, 'Shoulbe be passed to the handler');
deepEqual(fakeData2, hash.d2, 'Shoulbe be passed to the handler');
};
Events.on(el, ['event1', 'event2'], listener);
Events.trigger(el, 'event1', { d1: fakeData1, d2:fakeData2});
Events.trigger(el, 'event2', { d1: fakeData1, d2:fakeData2});
});
test('should remove all listeners of a type', function(){
var el = document.createElement('div');
var clicks = 0;
var listener = function(){
clicks++;
};
var listener2 = function(){
clicks++;
};
Events.on(el, 'click', listener);
Events.on(el, 'click', listener2);
Events.trigger(el, 'click'); // 2 clicks
ok(clicks === 2, 'both click listeners fired');
Events.off(el, 'click');
Events.trigger(el, 'click'); // No click should happen.
ok(clicks === 2, 'no click listeners fired');
});
test('should remove all listeners of an array of types', function(){
var el = document.createElement('div');
var calls = 0;
var listener = function(){
calls++;
};
var listener2 = function(){
calls++;
};
Events.on(el, ['click', 'event1'], listener);
Events.on(el, ['click', 'event1'], listener2);
Events.trigger(el, 'click'); // 2 calls
Events.trigger(el, 'event1'); // 2 calls
ok(calls === 4, 'both click listeners fired');
Events.off(el, ['click', 'event1']);
Events.trigger(el, 'click'); // No click should happen.
Events.trigger(el, 'event1'); // No event1 should happen.
ok(calls === 4, 'no event listeners fired');
});
test('should remove all listeners from an element', function(){
expect(2);
var el = document.createElement('div');
var listener = function(){
ok(true, 'Fake1 Triggered');
};
var listener2 = function(){
ok(true, 'Fake2 Triggered');
};
Events.on(el, 'fake1', listener);
Events.on(el, 'fake2', listener2);
Events.trigger(el, 'fake1');
Events.trigger(el, 'fake2');
Events.off(el);
// No listener should happen.
Events.trigger(el, 'fake1');
Events.trigger(el, 'fake2');
});
test('should listen only once', function(){
expect(1);
var el = document.createElement('div');
var listener = function(){
ok(true, 'Click Triggered');
};
Events.one(el, 'click', listener);
Events.trigger(el, 'click'); // 1 click
Events.trigger(el, 'click'); // No click should happen.
});
test( 'should listen only once in multiple events from a single call', function(){
expect(3);
var el = document.createElement('div');
var listener = function(){
ok(true, 'Callback Triggered');
};
Events.one(el, ['click', 'event1', 'event2'], listener);
Events.trigger(el, 'click'); // 1 click
Events.trigger(el, 'click'); // No click should happen.
Events.trigger(el, 'event1'); // event1 must be handled.
Events.trigger(el, 'event1'); // No event1 should be handled.
Events.trigger(el, 'event2'); // event2 must be handled.
Events.trigger(el, 'event2'); // No event2 should be handled.
});
test('should stop immediate propagtion', function(){
expect(1);
var el = document.createElement('div');
Events.on(el, 'test', function(e){
ok(true, 'First listener fired');
e.stopImmediatePropagation();
});
Events.on(el, 'test', function(e){
ok(false, 'Second listener fired');
});
Events.trigger(el, 'test');
});
2013-09-04 23:33:27 +03:00
test('should bubble up DOM unless bubbles == false', function(){
expect(3);
var outer = document.createElement('div');
var inner = outer.appendChild(document.createElement('div'));
// Verify that if bubbles === true, event bubbles up dom.
Events.on(inner, 'bubbles', function(e){
2013-09-04 23:33:27 +03:00
ok(true, 'Inner listener fired');
});
Events.on(outer, 'bubbles', function(e){
2013-09-04 23:33:27 +03:00
ok(true, 'Outer listener fired');
});
Events.trigger(inner, { type:'bubbles', target:inner, bubbles:true });
2013-09-04 23:33:27 +03:00
// Only change 'bubbles' to false, and verify only inner handler is called.
Events.on(inner, 'nobub', function(e){
2013-09-04 23:33:27 +03:00
ok(true, 'Inner listener fired');
});
Events.on(outer, 'nobub', function(e){
2013-09-04 23:33:27 +03:00
ok(false, 'Outer listener fired');
});
Events.trigger(inner, { type:'nobub', target:inner, bubbles:false });
2013-09-04 23:33:27 +03:00
});
2014-03-25 00:56:02 +03:00
test('should have a defaultPrevented property on an event that was prevent from doing default action', function() {
expect(2);
var el = document.createElement('div');
Events.on(el, 'test', function(e){
2014-03-25 00:56:02 +03:00
ok(true, 'First listener fired');
e.preventDefault();
});
Events.on(el, 'test', function(e){
2014-03-25 00:56:02 +03:00
ok(e.defaultPrevented, 'Should have `defaultPrevented` to signify preventDefault being called');
});
Events.trigger(el, 'test');
2014-03-25 00:56:02 +03:00
});
test('should have relatedTarget correctly set on the event', function() {
expect(2);
var el1 = document.createElement('div'),
el2 = document.createElement('div'),
relatedEl = document.createElement('div');
Events.on(el1, 'click', function(e){
equal(e.relatedTarget, relatedEl, 'relatedTarget is set for all browsers when related element is set on the event');
});
Events.trigger(el1, { type:'click', relatedTarget:relatedEl });
Events.on(el2, 'click', function(e) {
equal(e.relatedTarget, null, 'relatedTarget is null when none is provided');
});
Events.trigger(el2, { type:'click', relatedTarget:undefined });
});