AngularFire2を使用している私のAngular2アプリでは、AuthService
がFirebaseで匿名で認証しようとしています。ジャスミンで拒否された約束事のテスト
私はAngularFireAuth
のsignInAnonymously
が拒否された約束を返すことを期待するテストを書こうとしています。 authState
はnull
であり、エラーがスローされます。
私はジャスミンの新機能と一般的なテストですが、私は非同期テストを使用する必要があるかもしれないと思っていますが、かなり固まってしまいます。ここで
は簡略化AuthService
次のとおりです。
import { Injectable } from '@angular/core';
import { AngularFireAuth } from 'angularfire2/auth';
import * as firebase from 'firebase/app';
import { Observable } from 'rxjs/Rx';
@Injectable()
export class AuthService {
private authState: firebase.User;
constructor(private afAuth: AngularFireAuth) { this.init(); }
private init(): void {
this.afAuth.authState.subscribe((authState: firebase.User) => {
if (authState === null) {
this.afAuth.auth.signInAnonymously()
.then((authState) => {
this.authState = authState;
})
.catch((error) => {
throw new Error(error.message);
});
} else {
this.authState = authState;
}
}, (error) => {
throw new Error(error.message);
});
}
}
そしてここでは、私のテストの仕様です:
import { TestBed, inject } from '@angular/core/testing';
import { AngularFireAuth } from 'angularfire2/auth';
import 'rxjs/add/observable/of';
import { Observable } from 'rxjs/Rx';
import { AuthService } from './auth.service';
import { environment } from '../environments/environment';
describe('AuthService',() => {
const mockAngularFireAuth: any = {
auth: jasmine.createSpyObj('auth', {
'signInAnonymously': Promise.resolve('foo'),
// 'signInWithPopup': Promise.reject(),
// 'signOut': Promise.reject()
}),
authState: Observable.of(null)
};
beforeEach(() => {
TestBed.configureTestingModule({
providers: [
{ provide: AngularFireAuth, useValue: mockAngularFireAuth },
{ provide: AuthService, useClass: AuthService }
]
});
});
it('should be created', inject([ AuthService ], (service: AuthService) => {
expect(service).toBeTruthy();
}));
//
//
//
//
//
describe('when we can’t authenticate',() => {
beforeEach(() => {
mockAngularFireAuth.auth.signInAnonymously.and.returnValue(Promise.reject('bar'));
});
it('should thow', inject([ AuthService ], (service: AuthService) => {
expect(mockAngularFireAuth.auth.signInAnonymously).toThrow();
}));
});
//
//
//
//
//
});
はあなたの助けをありがとう!
なぜあなたがテストを書いていますモック?テスト中のコードは何をしていますか? – jonrsharpe
こんにちは@jonrsharpe、私は 'AngularFireAuth'の' signInAnonymously'を試しています。そうでなければ、テストが実行されるたびにFirebaseへの実際の呼び出しを行います。私はこれらの第三者提供者を模倣すると考えられていますか? –
はい、あなたのテストは運動しているようです。 – jonrsharpe