diff options
| author | Pascal Corpet | 2012-07-04 10:07:09 +0200 |
|---|---|---|
| committer | Igor Minar | 2012-11-28 16:01:57 +0100 |
| commit | cc42c99bec6a03d6c41b8e1d29ba2b1f5c16b87d (patch) | |
| tree | ef3ebb8c2c792da08ab642492d1f347f6459aba1 /test/ngResource/resourceSpec.js | |
| parent | 3c7bfa77aad5e3f8c71bc63a7cd91c2586d8560a (diff) | |
| download | angular.js-cc42c99bec6a03d6c41b8e1d29ba2b1f5c16b87d.tar.bz2 | |
feat($resource): allow dynamic default parameters
Default resource params can now be calculated at runtime if defined
via a function.
Diffstat (limited to 'test/ngResource/resourceSpec.js')
| -rw-r--r-- | test/ngResource/resourceSpec.js | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/test/ngResource/resourceSpec.js b/test/ngResource/resourceSpec.js index 01466f1c..3d263688 100644 --- a/test/ngResource/resourceSpec.js +++ b/test/ngResource/resourceSpec.js @@ -356,6 +356,35 @@ describe("resource", function() { }); + it('should support dynamic default parameters (global)', function() { + var currentGroup = 'students', + Person = $resource('/Person/:group/:id', { group: function() { return currentGroup; }}); + + + $httpBackend.expect('GET', '/Person/students/fedor').respond({id: 'fedor', email: 'f@f.com'}); + + var fedor = Person.get({id: 'fedor'}); + $httpBackend.flush(); + + expect(fedor).toEqualData({id: 'fedor', email: 'f@f.com'}); + }); + + + it('should support dynamic default parameters (action specific)', function() { + var currentGroup = 'students', + Person = $resource('/Person/:group/:id', {}, { + fetch: {method: 'GET', params: {group: function() { return currentGroup; }}} + }); + + $httpBackend.expect('GET', '/Person/students/fedor').respond({id: 'fedor', email: 'f@f.com'}); + + var fedor = Person.fetch({id: 'fedor'}); + $httpBackend.flush(); + + expect(fedor).toEqualData({id: 'fedor', email: 'f@f.com'}); + }); + + it('should exercise full stack', function() { var Person = $resource('/Person/:id'); |
