要创建可重用的类存根,您可以使用Jest提供的mock功能和AngularFireDatabase提供的AngularFireDatabaseStub。
下面是一个示例解决方案:
// database-stub.ts
export class AngularFireDatabaseStub {
// 定义需要的方法和属性,并提供默认的实现
object(path: string) {
return {
valueChanges: jest.fn().mockReturnValue({}),
set: jest.fn(),
update: jest.fn(),
remove: jest.fn()
// 可根据需要添加其他方法
};
}
}
// app.component.spec.ts
import { TestBed } from '@angular/core/testing';
import { AngularFireDatabase } from '@angular/fire/database';
import { AngularFireDatabaseStub } from './database-stub';
describe('AppComponent', () => {
beforeEach(async () => {
await TestBed.configureTestingModule({
declarations: [AppComponent],
providers: [
// 使用 AngularFireDatabaseStub 替代 AngularFireDatabase
{ provide: AngularFireDatabase, useClass: AngularFireDatabaseStub }
]
}).compileComponents();
});
it('should create the app', () => {
const fixture = TestBed.createComponent(AppComponent);
const app = fixture.componentInstance;
expect(app).toBeTruthy();
});
// 添加其他测试用例
});
在上面的示例中,我们使用AngularFireDatabaseStub替代了AngularFireDatabase。在这个存根中,我们定义了需要的方法,并使用Jest的mock函数提供了默认的实现。
在单元测试中,我们通过提供AngularFireDatabaseStub来替代AngularFireDatabase。这样,在测试期间,对AngularFireDatabase的调用将被重定向到AngularFireDatabaseStub中定义的方法。
这样,您就可以在单元测试中使用可重用的类存根,并对其进行自定义以满足不同的测试需求。