gpt4 book ai didi

angular - 对使用 AngularFireAuth 和模拟 authState 的服务进行单元测试

转载 作者:太空狗 更新时间:2023-10-29 18:30:57 25 4
gpt4 key购买 nike

我一直在兜圈子,试图对依赖于 AngularFireAuth 的服务 (AuthService) 进行单元测试。

我正在尝试找到一种方法来模拟或劫持 Observable AngularFireAuth.authState,而不是服务实际与 Firebase 对话。

这是我的测试规范:

import { inject, TestBed } from '@angular/core/testing';

import { AngularFireModule } from 'angularfire2';
import { AngularFireAuth, AngularFireAuthModule } from 'angularfire2/auth';
import * as firebase from 'firebase/app';
import 'rxjs/add/observable/of';
// import { BehaviorSubject } from 'rxjs/BehaviorSubject';
import { Observable } from 'rxjs/Rx';

import { AuthService } from './auth.service';
import { environment } from '../../environments/environment';

const authState: firebase.User = null;
const mockAngularFireAuth: any = { authState: Observable.of(authState) };

describe('AuthService', () => {
beforeEach(() => {
TestBed.configureTestingModule({
imports: [AngularFireModule.initializeApp(environment.firebaseAppConfig)],
providers: [
{ provider: AngularFireAuth, useValue: mockAngularFireAuth },
AuthService
]
});
});

it('should be defined', inject([ AuthService ], (service: AuthService) => {
expect(service).toBeDefined();
}));

it('.authState should be null', inject([ AuthService ], (service: AuthService) => {
expect(service.authState).toBe(null);
}));
});

这是我的(简化的)服务:

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) => {
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);
});
}

public get currentUser(): firebase.User {
return this.authState ? this.authState : undefined;
}

public get currentUserObservable(): Observable<firebase.User> {
return this.afAuth.authState;
}

public get currentUid(): string {
return this.authState ? this.authState.uid : undefined;
}

public get isAnonymous(): boolean {
return this.authState ? this.authState.isAnonymous : false;
}

public get isAuthenticated(): boolean {
return !!this.authState;
}

public logout(): void {
this.afAuth.auth.signOut();
}
}

我收到错误消息 Property 'authState' is private and only accessible within class 'AuthService'。

当然是,但我不想实际访问它 — 我想模拟或劫持它,以便我可以从我的测试规范中控制它的值。我相信我在这里的代码偏离了轨道。

请注意,我使用的是 AngularFire2 的 ^4 版本,并且引入了重大更改;记录在这里:https://github.com/angular/angularfire2/blob/master/docs/version-4-upgrade.md

最佳答案

封装的成员可以反射(reflect)。

困难的方法:

expect(Reflect.get(service, 'authState')).toBe(null);

简单的方法:

expect(service['authState']).toBe(null);
expect((service as any).authState).toBe(null);

关于angular - 对使用 AngularFireAuth 和模拟 authState 的服务进行单元测试,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45117490/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com