[英]Angular2 Jasmine SpyOn Method Does Not Exist
我已经定义了一个接口和不透明令牌,如下所示
export let AUTH_SERVICE = new OpaqueToken('auth.service');
export interface AuthService {
logIn(): void;
logOut(): void;
}
在我的测试类中,我提供了AuthService
的存根版本,即
@Injectable()
class AuthServiceStub implements AuthService {
logIn(): void {}
logOut(): void {}
}
并成立了我的测试beforeEach
如下
beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [ LoginComponent ],
providers: [
{provide: AUTH_SERVICE, useValue: AuthServiceStub}
]
});
}));
然后我开始编写测试,即
it('should call log in on AuthService', () => {
let authService = fixture.debugElement.injector.get(AUTH_SERVICE);
spyOn(authService, 'logIn');
// expect will go here
});
但是我收到以下错误
Error: <spyOn> : logIn() method does not exist
看不出我做错了什么。 有任何想法吗?
那是因为你在提供者对象中使用了useValue
属性。 这意味着注入的值将是AuthServiceStub
类本身。 你想要的是它实际拥有这些方法的实例。
要使测试有效,请将useValue
替换为useClass
。 这将使Angular的依赖注入系统在创建提供程序时实际实例化服务,并调用fixture.debugElement.injector.get(AUTH_SERVICE);
将返回一个适当的对象。
或者,您可以手动实例化该类:
it('should call log in on AuthService', () => {
let AuthService = fixture.debugElement.injector.get(AUTH_SERVICE);
let authService = new AuthService();
spyOn(authService, 'logIn');
// expect will go here
});
仍然, useClass
是一个更好的解决方案,因为它将处理AuthService
可能需要的所有未来注入。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.