我正在使用Angular 14。我正在尝试测试此服务:
import { EnvironmentService } from './environment.service';
import { MsalService, MsalBroadcastService, MSAL_GUARD_CONFIG, MsalGuardConfiguration } from '@azure/msal-angular';
import { InteractionStatus, RedirectRequest, EventMessage, EventType } from '@azure/msal-browser';
import { Subject, filter, takeUntil } from 'rxjs';
import { Inject, Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';
const GRAPH_ENDPOINT = 'https://graph.microsoft.com/v1.0/me';
/**
* Every method is disabled if the environment is for development
*/
@Injectable({
providedIn: 'root'
})
export class AuthenticationService {
public isIframe: boolean = false;
public loginDisplay: boolean = !this._environmentService.getEnvironment().production;
public userLogged$: Subject<boolean> = new Subject<boolean>();
private readonly _destroying$ = new Subject<void>();
public profile: any = {
displayName: "Dev Mode User"
};
constructor(
@Inject(MSAL_GUARD_CONFIG) private _msalGuardConfig: MsalGuardConfiguration,
private _msalService: MsalService,
private _msalBroadcastService: MsalBroadcastService,
private _httpClient: HttpClient,
private _environmentService: EnvironmentService
) { }
/**
* Send thorugh observable the information if the user logged or not
*/
setLoginDisplay() {
console.log("setLoginDisplay called");
}
/**
* Redirec to login display
*/
loginRedirect(): void {
if (this._environmentService.getEnvironment().production) {
this._msalService.loginRedirect().subscribe(
() => {
this.setLoginDisplay();
}
);
}
}
}
在其他情况下,当可观察性是依赖的一个属性时,它起作用了,但由于某种原因,在这里没有,因为我一直得到这个错误:通过检查覆盖率,我注意到测试没有考虑订阅的内容:
这是我尝试的相应的spec.ts文件:
import { EnvironmentService } from './environment.service';
import { Observable, of } from 'rxjs';
import { HttpClient } from '@angular/common/http';
import { MsalService, MsalBroadcastService, MSAL_GUARD_CONFIG } from '@azure/msal-angular';
import { MockService } from 'ng-mocks';
import { TestBed, tick } from '@angular/core/testing';
import { AuthenticationService } from './authentication.service';
import { AccountInfo, EventMessage, InteractionStatus } from '@azure/msal-browser';
const mockInstance: any = {
enableAccountStorageEvents(): void { },
getAllAccounts(): AccountInfo[] { return [] },
getActiveAccount(): AccountInfo | null { return null },
setActiveAccount(account: AccountInfo | null): void { }
}
describe('AuthenticationService', () => {
let service: AuthenticationService;
const mockMsalService = MockService(MsalService, {
instance: mockInstance
});
const mockMsalBroadcastService = MockService(MsalBroadcastService, {
msalSubject$: new Observable<EventMessage>(),
inProgress$: new Observable<InteractionStatus>(),
});
const mockHttpClient = MockService(HttpClient);
const mockEnvironmentService = MockService(EnvironmentService, {
getEnvironment() { return { production: true } }
});
beforeEach(() => {
TestBed.configureTestingModule({
providers: [
{
provide: EnvironmentService,
useValue: mockEnvironmentService
},
{
provide: MsalService,
useValue: mockMsalService
},
{
provide: MsalBroadcastService,
useValue: mockMsalBroadcastService
},
{
provide: HttpClient,
useValue: mockHttpClient
},
{
provide: MSAL_GUARD_CONFIG,
useValue: {}
}
]
});
mockMsalBroadcastService.msalSubject$ = new Observable<EventMessage>();
mockMsalBroadcastService.inProgress$ = new Observable<InteractionStatus>();
});
it('should call setLoginDisplay', fakeAsync(() => {
service = TestBed.inject(AuthenticationService);
const setLoginDisplaySpy = spyOn(service, "setLoginDisplay").and.callFake(() => { });
const loginRedirectSpy = spyOn(mockMsalService, "loginRedirect").and.returnValue(new Observable<void>());
service.loginRedirect();
tick();
expect(setLoginDisplaySpy).toHaveBeenCalled();
}));
});
有人能帮我解释一下为什么会发生这种情况吗?提前谢谢你!
2条答案
按热度按时间s71maibg1#
我认为您的spied
mockMsalService
中的new Observable()
没有发出任何值。因此,即使您等待一个tick
,您的订阅也不会执行。您可能需要使用of(undefined)
或of({})
:由于
of
同步工作,您甚至可以从测试中删除tick()
。a14dhokn2#
您正在拨打虚假电话,请参见以下行:
它用于测试功能,而不是实际数据!