package.test.delegate.js Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of delegate Show documentation
Show all versions of delegate Show documentation
Lightweight event delegation
The newest version!
var delegate = require('../src/delegate');
var simulant = require('simulant');
describe('delegate', function() {
before(function() {
var html = '';
document.body.innerHTML += html;
global.container = document.querySelector('ul');
global.anchor = document.querySelector('a');
global.spy = sinon.spy(global.container, 'removeEventListener');
});
after(function() {
global.spy.restore();
document.body.innerHTML = '';
});
it('should add an event listener', function(done) {
delegate(global.container, 'a', 'click', function() {
done();
});
simulant.fire(global.anchor, simulant('click'));
});
it('should remove an event listener', function() {
var delegation = delegate(global.container, 'a', 'click', function() {});
delegation.destroy();
assert.ok(global.spy.calledOnce);
});
it('should use `document` if the element is unspecified', function(done) {
delegate('a', 'click', function() {
done();
});
simulant.fire(global.anchor, simulant('click'));
});
it('should remove an event listener the unspecified base (`document`)', function() {
var delegation = delegate('a', 'click', function() {});
var spy = sinon.spy(document, 'removeEventListener');
delegation.destroy();
assert.ok(spy.calledOnce);
spy.restore();
});
it('should add event listeners to all the elements in a base selector', function() {
var spy = sinon.spy();
delegate('li', 'a', 'click', spy);
var anchors = document.querySelectorAll('a');
simulant.fire(anchors[0], simulant('click'));
simulant.fire(anchors[1], simulant('click'));
assert.ok(spy.calledTwice);
});
it('should remove the event listeners from all the elements in a base selector', function() {
var items = document.querySelectorAll('li')
var spies = Array.prototype.map.call(items, function (li) {
return sinon.spy(li, 'removeEventListener');
});
var delegations = delegate('li', 'a', 'click', function() {});
delegations.forEach(function (delegation) {
delegation.destroy();
});
spies.every(function (spy) {
var success = spy.calledOnce;
spy.restore();
return success;
});
});
it('should add event listeners to all the elements in a base array', function() {
var spy = sinon.spy();
var items = document.querySelectorAll('li')
delegate(items, 'a', 'click', spy);
var anchors = document.querySelectorAll('a')
simulant.fire(anchors[0], simulant('click'));
simulant.fire(anchors[1], simulant('click'));
assert.ok(spy.calledTwice);
});
it('should remove the event listeners from all the elements in a base array', function() {
var items = document.querySelectorAll('li')
var spies = Array.prototype.map.call(items, function (li) {
return sinon.spy(li, 'removeEventListener');
});
var delegations = delegate(items, 'a', 'click', function() {});
delegations.forEach(function (delegation) {
delegation.destroy();
});
spies.every(function (spy) {
var success = spy.calledOnce;
spy.restore();
return success;
});
});
});