mirror of
https://github.com/jquery/jquery-ui.git
synced 2025-01-07 20:34:24 +00:00
7d96a0d096
Partial fix for #5064 - Widget: make multiple instantiation more useful.
169 lines
4.3 KiB
JavaScript
169 lines
4.3 KiB
JavaScript
/*
|
|
* widget unit tests
|
|
*/
|
|
(function($) {
|
|
|
|
module('widget factory', {
|
|
teardown: function() {
|
|
delete $.ui.testWidget;
|
|
}
|
|
});
|
|
|
|
test('widget creation', function() {
|
|
var myPrototype = {
|
|
_create: function() {},
|
|
creationTest: function() {}
|
|
};
|
|
|
|
$.widget('ui.testWidget', myPrototype);
|
|
ok($.isFunction($.ui.testWidget), 'constructor was created');
|
|
equals('object', typeof $.ui.testWidget.prototype, 'prototype was created');
|
|
equals($.ui.testWidget.prototype._create, myPrototype._create, 'create function is copied over');
|
|
equals($.ui.testWidget.prototype.creationTest, myPrototype.creationTest, 'random function is copied over');
|
|
equals($.ui.testWidget.prototype.option, $.Widget.prototype.option, 'option method copied over from base widget');
|
|
});
|
|
|
|
test('jQuery usage', function() {
|
|
expect(10);
|
|
|
|
var shouldInit = false;
|
|
|
|
$.widget('ui.testWidget', {
|
|
getterSetterVal: 5,
|
|
_create: function() {
|
|
ok(shouldInit, 'init called on instantiation');
|
|
},
|
|
methodWithParams: function(param1, param2) {
|
|
ok(true, 'method called via .pluginName(methodName)');
|
|
equals(param1, 'value1', 'parameter passed via .pluginName(methodName, param)');
|
|
equals(param2, 'value2', 'multiple parameter passed via .pluginName(methodName, param, param)');
|
|
|
|
return this;
|
|
},
|
|
getterSetterMethod: function(val) {
|
|
if (val) {
|
|
this.getterSetterVal = val;
|
|
} else {
|
|
return this.getterSetterVal;
|
|
}
|
|
}
|
|
});
|
|
|
|
shouldInit = true;
|
|
var elem = $('<div></div>').testWidget();
|
|
shouldInit = false;
|
|
|
|
var instance = elem.data('testWidget');
|
|
equals(typeof instance, 'object', 'instance stored in .data(pluginName)');
|
|
equals(instance.element[0], elem[0], 'element stored on widget');
|
|
var ret = elem.testWidget('methodWithParams', 'value1', 'value2');
|
|
equals(ret, elem, 'jQuery object returned from method call');
|
|
|
|
ret = elem.testWidget('getterSetterMethod');
|
|
equals(ret, 5, 'getter/setter can act as getter');
|
|
ret = elem.testWidget('getterSetterMethod', 30);
|
|
equals(ret, elem, 'getter/setter method can be chainable');
|
|
equals(instance.getterSetterVal, 30, 'getter/setter can act as setter');
|
|
});
|
|
|
|
test('direct usage', function() {
|
|
expect(9);
|
|
|
|
var shouldInit = false;
|
|
|
|
$.widget('ui.testWidget', {
|
|
getterSetterVal: 5,
|
|
_create: function() {
|
|
ok(shouldInit, 'init called on instantiation');
|
|
},
|
|
methodWithParams: function(param1, param2) {
|
|
ok(true, 'method called via .pluginName(methodName)');
|
|
equals(param1, 'value1', 'parameter passed via .pluginName(methodName, param)');
|
|
equals(param2, 'value2', 'multiple parameter passed via .pluginName(methodName, param, param)');
|
|
|
|
return this;
|
|
},
|
|
getterSetterMethod: function(val) {
|
|
if (val) {
|
|
this.getterSetterVal = val;
|
|
} else {
|
|
return this.getterSetterVal;
|
|
}
|
|
}
|
|
});
|
|
|
|
var elem = $('<div></div>')[0];
|
|
|
|
shouldInit = true;
|
|
var instance = new $.ui.testWidget({}, elem);
|
|
shouldInit = false;
|
|
|
|
equals($(elem).data('testWidget'), instance, 'instance stored in .data(pluginName)');
|
|
equals(instance.element[0], elem, 'element stored on widget');
|
|
|
|
var ret = instance.methodWithParams('value1', 'value2');
|
|
equals(ret, instance, 'plugin returned from method call');
|
|
|
|
ret = instance.getterSetterMethod();
|
|
equals(ret, 5, 'getter/setter can act as getter');
|
|
instance.getterSetterMethod(30);
|
|
equals(instance.getterSetterVal, 30, 'getter/setter can act as setter');
|
|
});
|
|
|
|
test('merge multiple option arguments', function() {
|
|
expect(1);
|
|
$.widget("ui.testWidget", {
|
|
_create: function() {
|
|
same(this.options, {
|
|
disabled: false,
|
|
option1: "value1",
|
|
option2: "value2",
|
|
option3: "value3",
|
|
option4: {
|
|
option4a: "valuea",
|
|
option4b: "valueb"
|
|
}
|
|
});
|
|
}
|
|
});
|
|
$("<div></div>").testWidget({
|
|
option1: "valuex",
|
|
option2: "valuex",
|
|
option3: "value3",
|
|
option4: {
|
|
option4a: "valuex"
|
|
}
|
|
}, {
|
|
option1: "value1",
|
|
option2: "value2",
|
|
option4: {
|
|
option4b: "valueb"
|
|
}
|
|
}, {
|
|
option4: {
|
|
option4a: "valuea"
|
|
}
|
|
});
|
|
});
|
|
|
|
test(".widget() - base", function() {
|
|
$.widget("ui.testWidget", {
|
|
_create: function() {}
|
|
});
|
|
var div = $("<div></div>").testWidget()
|
|
same(div[0], div.testWidget("widget")[0]);
|
|
});
|
|
|
|
test(".widget() - overriden", function() {
|
|
var wrapper = $("<div></div>");
|
|
$.widget("ui.testWidget", {
|
|
_create: function() {},
|
|
widget: function() {
|
|
return wrapper;
|
|
}
|
|
});
|
|
same(wrapper[0], $("<div></div>").testWidget().testWidget("widget")[0]);
|
|
});
|
|
|
|
})(jQuery);
|