aboutsummaryrefslogtreecommitdiffstats
path: root/test/widgetsSpec.js
diff options
context:
space:
mode:
authorMisko Hevery2011-07-14 13:54:34 -0700
committerMisko Hevery2011-07-26 09:41:44 -0700
commit3237f8b9950ab0dbf3c80f6bef40217ea7cf96ae (patch)
treec04e4c6ae97a2e6fbfd4b9e47c7ba993c3561afc /test/widgetsSpec.js
parent7802c90e139a36d37b9d3c8cd6b6fcfee042dd71 (diff)
downloadangular.js-3237f8b9950ab0dbf3c80f6bef40217ea7cf96ae.tar.bz2
fix(directive): ng:options to support ng:change
Closes #463
Diffstat (limited to 'test/widgetsSpec.js')
-rw-r--r--test/widgetsSpec.js21
1 files changed, 21 insertions, 0 deletions
diff --git a/test/widgetsSpec.js b/test/widgetsSpec.js
index 422ca86b..e2a070c4 100644
--- a/test/widgetsSpec.js
+++ b/test/widgetsSpec.js
@@ -859,6 +859,27 @@ describe("widget", function(){
expect(scope.selected).toEqual(scope.values[1]);
});
+ it('should fire ng:change if present', function(){
+ createSelect({
+ name:'selected',
+ 'ng:options':'value for value in values',
+ 'ng:change':'count = count + 1'});
+ scope.values = [{name:'A'}, {name:'B'}];
+ scope.selected = scope.values[0];
+ scope.count = 0;
+ scope.$eval();
+ expect(scope.count).toEqual(0);
+
+ select.val('1');
+ browserTrigger(select, 'change');
+ expect(scope.count).toEqual(1);
+ expect(scope.selected).toEqual(scope.values[1]);
+
+ browserTrigger(select, 'change');
+ expect(scope.count).toEqual(1);
+ expect(scope.selected).toEqual(scope.values[1]);
+ });
+
it('should update model on change through expression', function(){
createSelect({name:'selected', 'ng:options':'item.id as item.name for item in values'});
scope.values = [{id:10, name:'A'}, {id:20, name:'B'}];