mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-07 01:54:15 +00:00
[DURACOM-234] Fixes after migrating to functional guards
This commit is contained in:
@@ -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);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@@ -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)),
|
||||||
|
Reference in New Issue
Block a user