मेरे पास myService
वह उपयोग है myOtherService
, जो एक दूरस्थ कॉल करता है, वादे को पूरा करता है:
angular.module('app.myService', ['app.myOtherService'])
.factory('myService', [
myOtherService,
function(myOtherService) {
function makeRemoteCall() {
return myOtherService.makeRemoteCallReturningPromise();
}
return {
makeRemoteCall: makeRemoteCall
};
}
])
myService
मुझे मॉक करने के लिए एक इकाई परीक्षण करने की आवश्यकता है myOtherService
, जैसे कि इसकी makeRemoteCallReturningPromise
विधि एक वादा वापस करती है। यह मेरा इसे करने का तरीका है:
describe('Testing remote call returning promise', function() {
var myService;
var myOtherServiceMock = {};
beforeEach(module('app.myService'));
// I have to inject mock when calling module(),
// and module() should come before any inject()
beforeEach(module(function ($provide) {
$provide.value('myOtherService', myOtherServiceMock);
}));
// However, in order to properly construct my mock
// I need $q, which can give me a promise
beforeEach(inject(function(_myService_, $q){
myService = _myService_;
myOtherServiceMock = {
makeRemoteCallReturningPromise: function() {
var deferred = $q.defer();
deferred.resolve('Remote call result');
return deferred.promise;
}
};
}
// Here the value of myOtherServiceMock is not
// updated, and it is still {}
it('can do remote call', inject(function() {
myService.makeRemoteCall() // Error: makeRemoteCall() is not defined on {}
.then(function() {
console.log('Success');
});
}));
जैसा कि आप ऊपर से देख सकते हैं, मेरी मॉक की परिभाषा इस पर निर्भर करती है $q
, जिसका उपयोग करके मुझे लोड करना है inject()
। इसके अलावा, मॉक को इंजेक्ट किया जाना चाहिए module()
, जो पहले आना चाहिए inject()
। हालाँकि, इसे बदलने के बाद मॉक के लिए वैल्यू अपडेट नहीं की जाती है।
ऐसा करने का उचित तरीका क्या है?
myService.makeRemoteCall()
? यदि हां, तो समस्या के साथ हैmyService
नहींmakeRemoteCall
, कुछ भी अपने मज़ाक उड़ाया से कोई लेना देना नहींmyOtherService
।