मेरे पास 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।