Dri*_*bel 3 unit-testing mocking jasmine angularjs
嗨,我有一个有角度的服务。
...
return {
setMixpanel: function(searchObject){
searchObject["referrer"] ? mixpanel.register({"$referrer":searchObject["referrer"]}) : mixpanel.register({"$referrer":""});
}
}
Run Code Online (Sandbox Code Playgroud)
在我的单元测试中,我可能必须spyOn mixpanel与register. 但我需要以某种方式模拟 mixpanel.register。
我如何mixpanel.register正确嘲笑?代码去哪里了。
我嘲笑它如下:
var mixpanel={
register : function(object){
return object
}
};
Run Code Online (Sandbox Code Playgroud)
但我该把这段代码放在哪里呢?这是对的吗?
我希望有人能在这里帮助我?
编辑:测试本身可能看起来像这样
it('should test', function(){
spyOn(mixpanel,'register');
redirectService.setMixpanel(search);
expect(mixpanel.register).toHaveBeenCalledWith('...');
})
Run Code Online (Sandbox Code Playgroud)
但为了做到这一点,我需要模拟 mixpanel。如果我只是监视 mixpanel,我会收到错误。
您需要首先创建一个间谍对象。没有必要嘲笑你的服务
beforeEach(function () {
myServiceSpy = jasmine.createSpyObj('myService');
module(function ($provide) {
$provide.value('myService', myServiceSpy);
});
});
Run Code Online (Sandbox Code Playgroud)
测试
describe("myService", function() {
it("calls the getUser() function", function() {
/* Maybe this line unnecessary, cant try it atm */
spyOn(service, "getUser");
expect(service.getUser).toHaveBeenCalled();
});
});
Run Code Online (Sandbox Code Playgroud)
如果您想测试是否mixpanel.register被调用,您需要创建 mixpanel 的间谍对象。使用 $provide 您可以告诉测试使用间谍而不是真正的服务。
describe('mixPanel', function () {
mixPanelSpy = jasmine.createSpyObj('mixPanel');
beforeEach(module(function($provide) {
$provide.value("mixpanel", mixPanelSpy);
}));
beforeEach(inject(function (_mixpanelService_) {
mixpanelService = _mixpanelService_;
}));
it('should set mixpanel', function() {
mixpanelService.setMixPanel('test');
expect(mixpanel.register).toBeCalled();
});
});
Run Code Online (Sandbox Code Playgroud)
写出我的想法,也许有一些冲突需要解决
| 归档时间: |
|
| 查看次数: |
10782 次 |
| 最近记录: |