2011-02-24 10:03:38 +13:00
|
|
|
describe( 'Entwine', function() {
|
|
|
|
|
|
|
|
beforeEach(function() {
|
|
|
|
$.entwine.warningLevel = $.entwine.WARN_LEVEL_BESTPRACTISE;
|
|
|
|
$('body').append('<div id="dom_test"></div>');
|
|
|
|
});
|
2009-11-21 02:33:06 +00:00
|
|
|
|
2011-02-24 10:03:38 +13:00
|
|
|
afterEach(function() {
|
|
|
|
$('#dom_test').remove();
|
|
|
|
});
|
|
|
|
|
|
|
|
describe( 'Basics', function() {
|
|
|
|
|
|
|
|
beforeEach(function() {
|
2010-04-13 05:45:29 +00:00
|
|
|
$.entwine.clear_all_rules();
|
|
|
|
$('#dom_test').html('<div id="a" class="a b c" data-fieldtype="foo"></div><div id="b" class="c d e"></div>');
|
2011-02-24 10:03:38 +13:00
|
|
|
});
|
2009-11-21 02:33:06 +00:00
|
|
|
|
2011-02-24 10:03:38 +13:00
|
|
|
it( 'can attach and call a base function', function() {
|
2010-04-13 05:45:29 +00:00
|
|
|
$('#a').entwine({
|
|
|
|
foo: function(){return this.attr('id');}
|
|
|
|
});
|
2011-02-24 10:03:38 +13:00
|
|
|
expect($('.a').foo()).toEqual('a');
|
|
|
|
});
|
2010-04-13 05:45:29 +00:00
|
|
|
|
2011-02-24 10:03:38 +13:00
|
|
|
it( 'can attach and call a base function on a selector using a data attribute selection', function() {
|
2010-04-13 05:45:29 +00:00
|
|
|
$('[data-fieldtype=foo]').entwine({
|
2009-11-21 02:33:06 +00:00
|
|
|
foo: function(){return this.attr('id');}
|
|
|
|
});
|
2011-02-24 10:03:38 +13:00
|
|
|
expect($('.a').foo()).toEqual('a') ;
|
|
|
|
});
|
|
|
|
|
|
|
|
it( 'can attach and call several base functions', function() {
|
2010-04-13 05:45:29 +00:00
|
|
|
$('#a').entwine({
|
2009-11-21 02:33:06 +00:00
|
|
|
foo: function(){return 'foo_' + this.attr('id');},
|
|
|
|
bar: function(){return 'bar_' + this.attr('id');}
|
2009-11-21 02:33:26 +00:00
|
|
|
});
|
2011-02-24 10:03:38 +13:00
|
|
|
expect($('.a').foo()).toEqual( 'foo_a');
|
|
|
|
expect($('.a').bar()).toEqual( 'bar_a');
|
|
|
|
});
|
|
|
|
|
|
|
|
it( 'can attach and call a namespaced function', function() {
|
2010-04-13 05:45:29 +00:00
|
|
|
$.entwine('bar', function($){
|
|
|
|
$('#a').entwine({
|
2009-11-21 02:33:26 +00:00
|
|
|
foo: function(){return this.attr('id');}
|
|
|
|
});
|
|
|
|
});
|
2011-02-24 10:03:38 +13:00
|
|
|
expect($('.a').entwine('bar').foo()).toEqual( 'a');
|
|
|
|
});
|
|
|
|
|
|
|
|
it( 'can attach and call a nested namespaced function', function() {
|
2010-04-13 05:45:29 +00:00
|
|
|
$.entwine('qux.baz.bar', function($){
|
|
|
|
$('#a').entwine({
|
2009-11-21 02:33:26 +00:00
|
|
|
foo: function(){return this.attr('id');}
|
|
|
|
});
|
|
|
|
});
|
2011-02-24 10:03:38 +13:00
|
|
|
expect($('.a').entwine('qux.baz.bar').foo()).toEqual( 'a');
|
|
|
|
});
|
|
|
|
|
|
|
|
it( 'can call two functions on two elements', function() {
|
2009-11-21 02:33:06 +00:00
|
|
|
var res = []
|
2010-04-13 05:45:29 +00:00
|
|
|
$('#a').entwine({
|
2009-11-21 02:33:26 +00:00
|
|
|
foo: function(){res.push(this.attr('id'));}
|
|
|
|
});
|
2010-04-13 05:45:29 +00:00
|
|
|
$('#b.c').entwine({
|
2009-11-21 02:33:26 +00:00
|
|
|
foo: function(){res.push(this.attr('id'));}
|
|
|
|
});
|
2009-11-21 02:33:06 +00:00
|
|
|
$('#dom_test div').foo();
|
2011-02-24 10:03:38 +13:00
|
|
|
expect(res).toEqual( ['b', 'a']);
|
|
|
|
});
|
|
|
|
|
|
|
|
it( 'can call two namespaced functions on two elements', function() {
|
2009-11-21 02:33:06 +00:00
|
|
|
var res = []
|
2010-04-13 05:45:29 +00:00
|
|
|
$.entwine('bar', function($){
|
|
|
|
$('#a').entwine({
|
2009-11-21 02:33:26 +00:00
|
|
|
foo: function(){res.push(this.attr('id'));}
|
|
|
|
});
|
2010-04-13 05:45:29 +00:00
|
|
|
$('#b.c').entwine({
|
2009-11-21 02:33:26 +00:00
|
|
|
foo: function(){res.push(this.attr('id'));}
|
|
|
|
});
|
|
|
|
});
|
2010-04-13 05:45:29 +00:00
|
|
|
$('#dom_test div').entwine('bar').foo();
|
2011-02-24 10:03:38 +13:00
|
|
|
expect(res).toEqual( ['b', 'a']);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|