有谁知道如何使用angular 2进行基本的单元测试来测试基本的firebase添加项。
我在代码中使用打字稿而不是基本的JavaScript
这是我正在测试的内容:
export class AppComponent {
ref: Firebase;
refUsers: Firebase;
refProfiles: Firebase;
constructor(){
this.ref = new Firebase("https://markng2.firebaseio.com");
this.refUsers = new Firebase("https://markng2.firebaseio.com/users");
this.refProfiles = new Firebase("https://markng2.firebaseio.com/profiles");
}
public addUser(newUser: Object): void{
this.refUsers.push(newUser, ()=>{
});
}
}
这是我目前的测试:
import {it, iit, describe, expect, inject, injectAsync, beforeEachProviders, fakeAsync, tick } from 'angular2/testing';
import { AppComponent } from '../app/app';
describe('AppComponent', () => {
it('saves an item to Firebase', () => {
let refUsers = new Firebase('');
let service = new AppComponent();
spyOn(service.refUsers, 'push');
service.addUser({ item: true });
expect(service.refUsers.push).toHaveBeenCalled();
})
});
这是我运行该测试时遇到的错误:
开始测试的三个步骤。
假设您创建了一个名为的类DataService
:
/// <reference path="typings/firebase/firebase.d.ts" />
export class DataService {
ref: Firebase;
constructor(theRef: Firebase) {
this.ref = theRef;
}
add(object: any) {
this.ref.push(object);
}
}
要对其进行测试,可以导入DataService
并使用Jasmine方法来测试add方法。
import {DataService} from './data-service';
describe('DataService', () => {
it('saves an item to Firebase', () => {
let ref = new Firebase('');
let service = new DataService(ref);
// create a spy to use if push is called
spyOn(service.ref, 'push');
service.add({ item: true });
// expect that push was called
expect(service.ref.push).toHaveBeenCalled();
})
});
测试Firebase方法的关键只是监视它们。您无需测试Firebase是否正常运行,仅需代码正确调用Firebase即可。
这里的问题是,您在单元测试中使用了完整的Firebase SDK。理想情况下,您想使用模拟库,因此可以为Firebase SDK中所需的任何功能创建一个模拟。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句