[DURACOM-234] Fixes after migrating to functional guards

This commit is contained in:
Giuseppe Digilio
2024-04-02 18:45:57 +02:00
parent 026e16ffd9
commit b8c26a71c3
2 changed files with 28 additions and 41 deletions

View File

@@ -1,4 +1,3 @@
/* eslint-disable max-classes-per-file */
import { import {
ChangeDetectionStrategy, ChangeDetectionStrategy,
NO_ERRORS_SCHEMA, NO_ERRORS_SCHEMA,
@@ -13,9 +12,9 @@ import { By } from '@angular/platform-browser';
import { import {
ActivatedRoute, ActivatedRoute,
ActivatedRouteSnapshot, ActivatedRouteSnapshot,
CanActivateFn,
RouterModule, RouterModule,
RouterStateSnapshot, RouterStateSnapshot,
UrlTree,
} from '@angular/router'; } from '@angular/router';
import { import {
TranslateLoader, TranslateLoader,
@@ -31,29 +30,31 @@ import { TranslateLoaderMock } from '../../shared/mocks/translate-loader.mock';
import { createSuccessfulRemoteDataObject } from '../../shared/remote-data.utils'; import { createSuccessfulRemoteDataObject } from '../../shared/remote-data.utils';
import { EditItemPageComponent } from './edit-item-page.component'; import { EditItemPageComponent } from './edit-item-page.component';
describe('ItemPageComponent', () => { describe('EditItemPageComponent', () => {
let comp: EditItemPageComponent; let comp: EditItemPageComponent;
let fixture: ComponentFixture<EditItemPageComponent>; let fixture: ComponentFixture<EditItemPageComponent>;
class AcceptAllGuard { const AcceptAllGuard: CanActivateFn = (
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<boolean | UrlTree> | Promise<boolean | UrlTree> | boolean | UrlTree { route: ActivatedRouteSnapshot,
return observableOf(true); state: RouterStateSnapshot,
} ): Observable<boolean> => {
} return observableOf(true);
};
class AcceptNoneGuard { const AcceptNoneGuard: CanActivateFn = (
canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<boolean | UrlTree> | Promise<boolean | UrlTree> | boolean | UrlTree { route: ActivatedRouteSnapshot,
return observableOf(false); state: RouterStateSnapshot,
} ): Observable<boolean> => {
} return observableOf(false);
};
const accesiblePages = ['accessible']; const accessiblePages = ['accessible'];
const inaccesiblePages = ['inaccessible', 'inaccessibleDoubleGuard']; const inaccessiblePages = ['inaccessible', 'inaccessibleDoubleGuard'];
const mockRoute = { const mockRoute = {
snapshot: { snapshot: {
firstChild: { firstChild: {
routeConfig: { routeConfig: {
path: accesiblePages[0], path: accessiblePages[0],
}, },
}, },
routerState: { routerState: {
@@ -63,13 +64,13 @@ describe('ItemPageComponent', () => {
routeConfig: { routeConfig: {
children: [ children: [
{ {
path: accesiblePages[0], path: accessiblePages[0],
canActivate: [AcceptAllGuard], canActivate: [AcceptAllGuard],
}, { }, {
path: inaccesiblePages[0], path: inaccessiblePages[0],
canActivate: [AcceptNoneGuard], canActivate: [AcceptNoneGuard],
}, { }, {
path: inaccesiblePages[1], path: inaccessiblePages[1],
canActivate: [AcceptAllGuard, AcceptNoneGuard], canActivate: [AcceptAllGuard, AcceptNoneGuard],
}, },
], ],
@@ -77,13 +78,6 @@ describe('ItemPageComponent', () => {
data: observableOf({ dso: createSuccessfulRemoteDataObject(new Item()) }), data: observableOf({ dso: createSuccessfulRemoteDataObject(new Item()) }),
}; };
const mockRouter = {
routerState: {
snapshot: undefined,
},
events: observableOf(undefined),
};
beforeEach(waitForAsync(() => { beforeEach(waitForAsync(() => {
TestBed.configureTestingModule({ TestBed.configureTestingModule({
imports: [ imports: [
@@ -98,8 +92,6 @@ describe('ItemPageComponent', () => {
], ],
providers: [ providers: [
{ provide: ActivatedRoute, useValue: mockRoute }, { provide: ActivatedRoute, useValue: mockRoute },
AcceptAllGuard,
AcceptNoneGuard,
], ],
schemas: [NO_ERRORS_SCHEMA], schemas: [NO_ERRORS_SCHEMA],
}).overrideComponent(EditItemPageComponent, { }).overrideComponent(EditItemPageComponent, {
@@ -110,19 +102,19 @@ describe('ItemPageComponent', () => {
beforeEach(waitForAsync(() => { beforeEach(waitForAsync(() => {
fixture = TestBed.createComponent(EditItemPageComponent); fixture = TestBed.createComponent(EditItemPageComponent);
comp = fixture.componentInstance; comp = fixture.componentInstance;
spyOn((comp as any).injector, 'get').and.callFake((a) => new a()); // spyOn((comp as any).injector, 'get').and.callFake((a) => new a());
fixture.detectChanges(); fixture.detectChanges();
})); }));
describe('ngOnInit', () => { describe('ngOnInit', () => {
it('should enable tabs that the user can activate', fakeAsync(() => { it('should enable tabs that the user can activate', fakeAsync(() => {
const enabledItems = fixture.debugElement.queryAll(By.css('a.nav-link')); const enabledItems = fixture.debugElement.queryAll(By.css('a.nav-link'));
expect(enabledItems.length).toBe(accesiblePages.length); expect(enabledItems.length).toBe(accessiblePages.length);
})); }));
it('should disable tabs that the user can not activate', () => { it('should disable tabs that the user can not activate', () => {
const disabledItems = fixture.debugElement.queryAll(By.css('button.nav-link.disabled')); const disabledItems = fixture.debugElement.queryAll(By.css('button.nav-link.disabled'));
expect(disabledItems.length).toBe(inaccesiblePages.length); expect(disabledItems.length).toBe(inaccessiblePages.length);
}); });
}); });
}); });

View File

@@ -9,6 +9,7 @@ import {
Component, Component,
Injector, Injector,
OnInit, OnInit,
runInInjectionContext,
} from '@angular/core'; } from '@angular/core';
import { import {
ActivatedRoute, ActivatedRoute,
@@ -28,7 +29,6 @@ import {
import { map } from 'rxjs/operators'; import { map } from 'rxjs/operators';
import { RemoteData } from '../../core/data/remote-data'; import { RemoteData } from '../../core/data/remote-data';
import { GenericConstructor } from '../../core/shared/generic-constructor';
import { Item } from '../../core/shared/item.model'; import { Item } from '../../core/shared/item.model';
import { import {
fadeIn, fadeIn,
@@ -88,15 +88,10 @@ export class EditItemPageComponent implements OnInit {
.map((child: Route) => { .map((child: Route) => {
let enabled = observableOf(true); let enabled = observableOf(true);
if (isNotEmpty(child.canActivate)) { if (isNotEmpty(child.canActivate)) {
enabled = observableCombineLatest(child.canActivate.map((guardConstructor: GenericConstructor<{ enabled = observableCombineLatest(child.canActivate.map((guardFn: CanActivateFn) => {
canActivate: CanActivateFn; return runInInjectionContext(this.injector, () => {
}>) => { return guardFn(this.route.snapshot, this.router.routerState.snapshot);
const guard: { });
canActivate: CanActivateFn;
} = this.injector.get<{
canActivate: CanActivateFn;
}>(guardConstructor);
return guard.canActivate(this.route.snapshot, this.router.routerState.snapshot);
}), }),
).pipe( ).pipe(
map((canActivateOutcomes: any[]) => canActivateOutcomes.every((e) => e === true)), map((canActivateOutcomes: any[]) => canActivateOutcomes.every((e) => e === true)),