147 lines
3.3 KiB
JavaScript

describe('Entwine', function(){
beforeEach(function(){
$('body').append('<div id="dom_test"></div>');
});
afterEach(function(){
$('#dom_test').remove();
});
describe('Ctors', function(){
beforeEach(function(){
$.entwine.synchronous_mode();
$.entwine.clear_all_rules();
$('#dom_test').html('<div id="a" class="a b c"></div>');
});
it('calls onmatch when new element created', function(){
var a = false;
$('#b').entwine({
onmatch: function(){a = true;}
});
expect(a).toBeFalsy();
$('#a').after('<div id="b"></div>');
expect(a).toBeTruthy();
});
it('calls onunmatch when new element deleted', function(){
var a = 0;
$('#b').entwine({
onmatch: function(){a = 1;},
onunmatch: function(){a = 2;}
});
expect(a).toEqual(0);
$('#a').after('<div id="b"></div>');
expect(a).toEqual(1);
$('#b').remove();
expect(a).toEqual(2);
});
it('calls onmatch when ruleset matches after class added', function(){
var a = 0;
$('#a.foo').entwine({
onmatch: function(){a = 1;}
});
expect(a).toEqual(0);
$('#a').addClass('foo');
expect(a).toEqual(1);
});
it('calls onmatch in both direct and namespaced onmatch, does not call less specific onmatch', function(){
var a = 0, b = 0, c = 0, d = 0;
$('.foo').entwine({
onmatch: function(){a = 1;}
});
$('.foo').entwine('bar', function($){return{
onmatch: function(){b = 1;}
};});
$('#a.foo').entwine({
onmatch: function(){c = 1;}
});
$('#a.foo').entwine('bar', function($){return{
onmatch: function(){d = 1;}
};});
expect([a, b, c, d]).toEqual([0, 0, 0, 0]);
$('#a').addClass('foo');
expect([a, b, c, d]).toEqual([0, 0, 1, 1]);
});
it('calls onmatch in both direct and namespaced onmatch, super works as expected', function(){
var a = 0, b = 0, c = 0, d = 0;
$('.foo').entwine({
onmatch: function(){a += 1;}
});
$('.foo').entwine('bar', function($){return{
onmatch: function(){b += 1;}
};});
$('#a.foo').entwine({
onmatch: function(){this._super(); c = 1; this._super();}
});
$('#a.foo').entwine('bar', function($){return{
onmatch: function(){this._super(); d = 1; this._super();}
};});
expect([a, b, c, d]).toEqual([0, 0, 0, 0]);
$('#a').addClass('foo');
expect([a, b, c, d]).toEqual([2, 2, 1, 1]);
});
it('handles onmatch rules being added post document.onready', function(){
var a = 0, b = 0;
$('#a').entwine({
onmatch: function(){a += 1;}
});
$('#a.a').entwine({
onmatch: function(){b += 1;}
});
// Rules are new, and no DOM change, so no triggers yet
expect([a, b]).toEqual([0, 0]);
// New #a.a rule thinks it matches no nodes, and so removing .a would normally not release it. Check we handle
$('#a').removeClass('a');
expect([a, b]).toEqual([1, 0]);
});
it('calls onmatch in less specific rule when more specific rule no longer matches', function(){
var a = 0, b = 0, c = 0;
$('#a').entwine({
onmatch: function(){a += 1;}
});
$('#a.a').entwine({
onmatch: function(){b += 1;}
});
$('#a.a.b').entwine({
onmatch: function(){c += 1;}
});
$.entwine.triggerMatching();
expect([a, b, c]).toEqual([0, 0, 1]);
$('#a').removeClass('b');
expect([a, b, c]).toEqual([0, 1, 1]);
$('#a').removeClass('a');
expect([a, b, c]).toEqual([1, 1, 1]);
});
});
});