447 lines
No EOL
13 KiB
JavaScript
447 lines
No EOL
13 KiB
JavaScript
/*
|
|
This file is part of Ext JS 3.4
|
|
|
|
Copyright (c) 2011-2013 Sencha Inc
|
|
|
|
Contact: http://www.sencha.com/contact
|
|
|
|
GNU General Public License Usage
|
|
This file may be used under the terms of the GNU General Public License version 3.0 as
|
|
published by the Free Software Foundation and appearing in the file LICENSE included in the
|
|
packaging of this file.
|
|
|
|
Please review the following information to ensure the GNU General Public License version 3.0
|
|
requirements will be met: http://www.gnu.org/copyleft/gpl.html.
|
|
|
|
If you are unsure which license is appropriate for your use, please contact the sales department
|
|
at http://www.sencha.com/contact.
|
|
|
|
Build date: 2013-04-03 15:07:25
|
|
*/
|
|
/**
|
|
* Tests Ext.data.Store functionality
|
|
* @author Ed Spencer
|
|
*/
|
|
(function() {
|
|
var suite = Ext.test.session.getSuite('Ext.form.BasicForm'),
|
|
assert = Y.Assert;
|
|
|
|
function buildForm(config) {
|
|
config = config || {};
|
|
|
|
Ext.applyIf(config, {
|
|
|
|
});
|
|
|
|
return new Ext.form.BasicForm(null, config);
|
|
};
|
|
|
|
var itemIdCount = 0;
|
|
//creates a duck object simulating a form field
|
|
function buildFormItem(options) {
|
|
itemIdCount ++;
|
|
|
|
options = options || {};
|
|
|
|
Ext.applyIf(options, {
|
|
valid: true,
|
|
dirty: false,
|
|
id : itemIdCount
|
|
});
|
|
|
|
return (function(itemId, config) {
|
|
return Ext.apply(config || {}, {
|
|
isFormField: true,
|
|
itemId : itemId,
|
|
|
|
getName: function() {
|
|
return config.name || config.id;
|
|
},
|
|
|
|
getItemId: function() {
|
|
return itemId;
|
|
},
|
|
|
|
validate: function() {
|
|
return config.valid;
|
|
},
|
|
|
|
isDirty: function() {
|
|
return config.dirty;
|
|
},
|
|
|
|
setValue: function() {
|
|
return true;
|
|
}
|
|
});
|
|
})(itemIdCount, options);
|
|
};
|
|
|
|
suite.add(new Y.Test.Case({
|
|
name: 'initialization with an element',
|
|
|
|
setUp: function() {
|
|
//create a fake form element to test that initEl is called
|
|
this.el = Ext.getBody().createChild({tag: 'form'});
|
|
},
|
|
|
|
tearDown: function() {
|
|
Ext.destroy(this.el);
|
|
},
|
|
|
|
testItemsCreated: function() {
|
|
var form = buildForm();
|
|
|
|
assert.isTrue(form.items instanceof Ext.util.MixedCollection);
|
|
},
|
|
|
|
testInitsEl: function() {
|
|
var BasicForm = Ext.form.BasicForm,
|
|
proto = BasicForm.prototype;
|
|
|
|
var wasCalled = false,
|
|
oldInitEl = proto.initEl;
|
|
|
|
proto.initEl = function() {
|
|
wasCalled = true;
|
|
};
|
|
|
|
var form = new BasicForm(this.el, {});
|
|
|
|
assert.isTrue(wasCalled);
|
|
|
|
//cleanup
|
|
proto.initEl = oldInitEl;
|
|
},
|
|
|
|
testGetEL: function() {
|
|
var form = new Ext.form.BasicForm(this.el, {});
|
|
|
|
assert.areEqual(this.el, form.getEl());
|
|
},
|
|
|
|
testGetsFormClass: function() {
|
|
var form = new Ext.form.BasicForm(this.el, {});
|
|
|
|
assert.isTrue(this.el.hasClass('x-form'));
|
|
}
|
|
}));
|
|
|
|
suite.add(new Y.Test.Case({
|
|
name: 'validations',
|
|
|
|
setUp: function() {
|
|
this.form = buildForm();
|
|
|
|
this.validItem = buildFormItem({valid: true});
|
|
this.invalidItem = buildFormItem({valid: false});
|
|
},
|
|
|
|
testAllValid: function() {
|
|
this.form.add(this.validItem);
|
|
|
|
assert.isTrue(this.form.isValid());
|
|
},
|
|
|
|
testSomeInvalid: function() {
|
|
this.form.add(this.validItem, this.invalidItem);
|
|
|
|
assert.isFalse(this.form.isValid());
|
|
}
|
|
}));
|
|
|
|
suite.add(new Y.Test.Case({
|
|
name: 'dirtiness',
|
|
|
|
setUp: function() {
|
|
this.form = buildForm();
|
|
|
|
this.cleanItem = buildFormItem({dirty: false});
|
|
this.dirtyItem = buildFormItem({dirty: true});
|
|
},
|
|
|
|
testAllClean: function() {
|
|
this.form.add(this.cleanItem);
|
|
|
|
assert.isFalse(this.form.isDirty());
|
|
},
|
|
|
|
testSomeDirty: function() {
|
|
this.form.add(this.cleanItem, this.dirtyItem);
|
|
|
|
assert.isTrue(this.form.isDirty());
|
|
}
|
|
}));
|
|
|
|
suite.add(new Y.Test.Case({
|
|
name: 'performing actions'
|
|
}));
|
|
|
|
suite.add(new Y.Test.Case({
|
|
name: 'submission'
|
|
}));
|
|
|
|
suite.add(new Y.Test.Case({
|
|
name: 'loading, resetting and updating records',
|
|
|
|
setUp: function() {
|
|
this.form = buildForm();
|
|
|
|
this.item1 = buildFormItem({id: 'name'});
|
|
this.item2 = buildFormItem({id: 'email'});
|
|
this.item3 = buildFormItem({id: 'phone'});
|
|
|
|
this.form.add(this.item1, this.item2, this.item3);
|
|
},
|
|
|
|
testReset: function() {
|
|
var resetCount = 0;
|
|
var reset = function() {
|
|
resetCount ++;
|
|
};
|
|
|
|
this.item1.reset = reset;
|
|
this.item2.reset = reset;
|
|
this.item3.reset = reset;
|
|
|
|
this.form.reset();
|
|
assert.areEqual(3, resetCount);
|
|
}
|
|
}));
|
|
|
|
suite.add(new Y.Test.Case({
|
|
name: 'finding fields',
|
|
|
|
setUp: function() {
|
|
this.form = buildForm();
|
|
|
|
this.item1 = buildFormItem({id: 'name', dataIndex: 'someDataIndex'});
|
|
this.item2 = buildFormItem({id: 'email'});
|
|
this.item3 = buildFormItem({id: 'phone', name: 'phone number'});
|
|
|
|
this.form.add(this.item1, this.item2, this.item3);
|
|
},
|
|
|
|
testfindByItemId: function() {
|
|
assert.areEqual(this.item3, this.form.findField(this.item3.itemId));
|
|
},
|
|
|
|
testFindById: function() {
|
|
assert.areEqual(this.item2, this.form.findField('email'));
|
|
},
|
|
|
|
testFindByDataIndex: function() {
|
|
assert.areEqual(this.item1, this.form.findField('someDataIndex'));
|
|
},
|
|
|
|
testFindByName: function() {
|
|
assert.areEqual(this.item3, this.form.findField('phone number'));
|
|
}
|
|
}));
|
|
|
|
suite.add(new Y.Test.Case({
|
|
name: 'marking invalid',
|
|
|
|
setUp: function() {
|
|
this.form = buildForm();
|
|
|
|
this.item1 = buildFormItem({id: 'name'});
|
|
this.item2 = buildFormItem({id: 'email'});
|
|
this.item3 = buildFormItem({id: 'phone'});
|
|
|
|
this.form.add(this.item1, this.item2, this.item3);
|
|
},
|
|
|
|
testMarkInvalidWithObject: function() {
|
|
var wasCalled = false, message;
|
|
|
|
this.item1.markInvalid = function(msg) {
|
|
wasCalled = true;
|
|
message = msg;
|
|
};
|
|
|
|
this.form.markInvalid({
|
|
name: 'is a bad name'
|
|
});
|
|
|
|
assert.isTrue(wasCalled);
|
|
assert.areEqual('is a bad name', message);
|
|
},
|
|
|
|
testMarkInvalidWithArray: function() {
|
|
var wasCalled = false, message;
|
|
|
|
this.item2.markInvalid = function(msg) {
|
|
wasCalled = true;
|
|
message = msg;
|
|
};
|
|
|
|
this.form.markInvalid([{id: 'email', msg: 'is the wrong format'}]);
|
|
|
|
assert.isTrue(wasCalled);
|
|
assert.areEqual('is the wrong format', message);
|
|
},
|
|
|
|
testClearInvalid: function() {
|
|
var clearCount = 0;
|
|
var clearInvalid = function() {
|
|
clearCount ++;
|
|
};
|
|
|
|
this.item1.clearInvalid = clearInvalid;
|
|
this.item2.clearInvalid = clearInvalid;
|
|
this.item3.clearInvalid = clearInvalid;
|
|
|
|
this.form.clearInvalid();
|
|
assert.areEqual(3, clearCount);
|
|
}
|
|
}));
|
|
|
|
suite.add(new Y.Test.Case({
|
|
name: 'setting values',
|
|
|
|
setUp: function() {
|
|
this.form = buildForm({
|
|
trackResetOnLoad: true
|
|
});
|
|
|
|
this.item1 = buildFormItem({name: 'name', getValue: function() {return 'ed'; }});
|
|
this.item2 = buildFormItem({name: 'email'});
|
|
this.item3 = buildFormItem({name: 'phone', getValue: function() {return '333';}});
|
|
|
|
this.form.add(this.item1, this.item2, this.item3);
|
|
},
|
|
|
|
testSetByObject: function() {
|
|
var called = false, value;
|
|
|
|
this.item1.setValue = function(val) {
|
|
wasCalled = true;
|
|
value = val;
|
|
};
|
|
|
|
this.form.setValues({name: 'my name'});
|
|
|
|
assert.isTrue(wasCalled);
|
|
assert.areEqual('my name', value);
|
|
},
|
|
|
|
testSetByArray: function() {
|
|
var called = false, value;
|
|
|
|
this.item1.setValue = function(val) {
|
|
wasCalled = true;
|
|
value = val;
|
|
};
|
|
|
|
this.form.setValues([{id: 'name', value: 'my name'}]);
|
|
|
|
assert.isTrue(wasCalled);
|
|
assert.areEqual('my name', value);
|
|
},
|
|
|
|
testSavesOriginalValue: function() {
|
|
this.form.setValues({'phone': '444'});
|
|
|
|
assert.areEqual('333', this.item3.originalValue);
|
|
}
|
|
}));
|
|
|
|
suite.add(new Y.Test.Case({
|
|
name: 'getting values',
|
|
|
|
setUp: function() {
|
|
this.form = buildForm();
|
|
|
|
this.item1 = buildFormItem({name: 'name', getValue: function() {return 'Edward';}});
|
|
this.item2 = buildFormItem({name: 'email', getValue: function() {return 'ed@extjs.com';}});
|
|
this.item3 = buildFormItem({name: 'phone', getValue: function() {return '333';}});
|
|
|
|
this.form.add(this.item1, this.item2, this.item3);
|
|
},
|
|
|
|
testGetFieldValues: function() {
|
|
var values = this.form.getFieldValues();
|
|
|
|
assert.areEqual('Edward', values.name);
|
|
assert.areEqual('ed@extjs.com', values.email);
|
|
assert.areEqual('333', values.phone);
|
|
},
|
|
|
|
testGetFieldValuesWithArray: function() {
|
|
//adding a second item with the same name should result in an array being returned
|
|
this.item4 = buildFormItem({
|
|
name : 'name',
|
|
getValue: function() {return 200;}
|
|
});
|
|
|
|
this.form.add(this.item4);
|
|
|
|
var values = this.form.getFieldValues();
|
|
|
|
assert.areEqual(2, values.name.length);
|
|
assert.areEqual('Edward', values.name[0]);
|
|
assert.areEqual(200, values.name[1]);
|
|
},
|
|
|
|
testGetDirtyFieldValues: function() {
|
|
this.item1.isDirty = function() {return true;};
|
|
|
|
var values = this.form.getFieldValues(true);
|
|
|
|
assert.areEqual('Edward', values.name);
|
|
assert.isUndefined(values.email);
|
|
assert.isUndefined(values.phone);
|
|
},
|
|
|
|
testGetValuesForSubmission: function() {
|
|
//pending
|
|
}
|
|
}));
|
|
|
|
suite.add(new Y.Test.Case({
|
|
name: 'adding and removing',
|
|
|
|
setUp: function() {
|
|
this.form = buildForm();
|
|
|
|
this.item1 = buildFormItem({id: 'name'});
|
|
this.item2 = buildFormItem({id: 'email'});
|
|
this.item3 = buildFormItem({id: 'phone'});
|
|
|
|
this.form.add(this.item1);
|
|
},
|
|
|
|
testAddField: function() {
|
|
var count = this.form.items.getCount();
|
|
|
|
this.form.add(this.item2);
|
|
|
|
assert.areEqual(count + 1, this.form.items.getCount());
|
|
},
|
|
|
|
testAddMultipleFields: function() {
|
|
var count = this.form.items.getCount();
|
|
|
|
this.form.add(this.item2, this.item3);
|
|
|
|
assert.areEqual(count + 2, this.form.items.getCount());
|
|
},
|
|
|
|
testAddReturnsForm: function() {
|
|
assert.areEqual(this.form, this.form.add(this.item2));
|
|
},
|
|
|
|
testRemoveField: function() {
|
|
var count = this.form.items.getCount();
|
|
|
|
this.form.remove(this.item1);
|
|
|
|
assert.areEqual(count - 1, this.form.items.getCount());
|
|
},
|
|
|
|
testRemoveReturnsForm: function() {
|
|
assert.areEqual(this.form, this.form.remove(this.item1));
|
|
}
|
|
}));
|
|
})(); |