所以,我在测试我的角度2服务时遇到了一些麻烦。我的测试标记为通过,但我在控制台中收到此错误:
context.js:243未处理的承诺拒绝:'expect'用于何时 没有当前的规范,这可能是因为异步测试 时间到 ;区域:ProxyZone;任务:Promise.then;值:错误: 'expect'是在没有当前规格时使用的,可能是 因为异步测试超时
我的服务使用PouchDB并返回一个promise。
这是我的服务:
import { Injectable } from '@angular/core';
import { Project } from './project';
declare var PouchDB:any;
@Injectable()
export class ProjectService {
db: any;
constructor() {
if(navigator.vendor && navigator.vendor.indexOf('Apple') > -1){
this.db = new PouchDB('projects', {adapter: 'fruitdown'});
}else{
this.db = new PouchDB('projects');
}
}
saveProject(project:Project): Promise<any>{
return this.db.put(project);
}
getProjects(limit:number,skip:number): Promise<any> {
return this.db.allDocs({
include_docs: true,
attachments: false,
descending: true,
limit: limit,
skip: skip
});
}
}
这是我的规格
import { TestBed, inject, async } from '@angular/core/testing';
import { Project, ProjectService } from './index';
describe('ProjectService', () => {
let project: Project;
let service: ProjectService;
let createFakeProject = function() {
let project = new Project;
project._id = 'iwhxu27i';
project.name = 'foo bar';
project.email = 'foo@b.ar';
return project;
}
beforeEach(() => {
const injector = TestBed.configureTestingModule({
providers: [ProjectService]
});
service = injector.get(ProjectService);
project = createFakeProject();
});
it('should be able to CREATE a new project (async)',
async( (done) => {
service.saveProject(project).then(
response => {
expect(response).toEqual(project);
done();
} );
}));
});
...好吧,所以我一直在摆弄这个问题。我可能需要使用fakeAsync和tick()?? fakeAsync感觉不对,你。看起来我应该在.finally()块中调用done()但是.finally()不是方法。我是用Jasmine测试Promise的新手,所以也许我错过了一些明显的东西?如果你知道使用angular2,jasmine和promises的任何代码(或示例代码);这会有所帮助。
我不想模仿PouchDB并返回我自己的存根Promise。
此测试应该失败,因为响应!=项目;它没有,但我在我的控制台中收到错误。帮助!
答案 0 :(得分:1)
不等待service.saveProject(project).then(
返回的承诺,要么从方法中删除async
,要么从测试中返回此承诺,要么等待测试中的承诺结果。
it('should be able to CREATE a new project (async)',
async (done) => {
let response = await service.saveProject(project)
expect(response).toEqual(project);
});