vitest implementation
This commit is contained in:
@@ -1,6 +1,6 @@
|
||||
import {TestBed} from '@angular/core/testing';
|
||||
import {Router} from '@angular/router';
|
||||
import {of} from 'rxjs';
|
||||
import {firstValueFrom, of} from 'rxjs';
|
||||
import {UserService} from '../../services/user/user.service';
|
||||
import {RoleGuard} from './role.guard';
|
||||
|
||||
@@ -30,14 +30,13 @@ describe('RoleGuard', () => {
|
||||
expect(() => guard.canActivate({data: {}} as never)).toThrowError('requiredRoles is not defined!');
|
||||
});
|
||||
|
||||
it('should deny access when there is no current user', done => {
|
||||
guard.canActivate({data: {requiredRoles: ['leader']}} as never).subscribe(result => {
|
||||
expect(result).toEqual({commands: ['brand', 'new-user']} as never);
|
||||
done();
|
||||
});
|
||||
it('should deny access when there is no current user', async () => {
|
||||
await expectAsync(firstValueFrom(guard.canActivate({data: {requiredRoles: ['leader']}} as never))).toBeResolvedTo(
|
||||
{commands: ['brand', 'new-user']} as never
|
||||
);
|
||||
});
|
||||
|
||||
it('should allow admins regardless of requiredRoles', done => {
|
||||
it('should allow admins regardless of requiredRoles', async () => {
|
||||
TestBed.resetTestingModule();
|
||||
routerSpy = jasmine.createSpyObj<Router>('Router', ['createUrlTree']);
|
||||
TestBed.configureTestingModule({
|
||||
@@ -48,13 +47,10 @@ describe('RoleGuard', () => {
|
||||
});
|
||||
guard = TestBed.inject(RoleGuard);
|
||||
|
||||
guard.canActivate({data: {requiredRoles: ['leader']}} as never).subscribe(result => {
|
||||
expect(result).toBeTrue();
|
||||
done();
|
||||
});
|
||||
await expectAsync(firstValueFrom(guard.canActivate({data: {requiredRoles: ['leader']}} as never))).toBeResolvedTo(true);
|
||||
});
|
||||
|
||||
it('should allow users with a matching required role', done => {
|
||||
it('should allow users with a matching required role', async () => {
|
||||
TestBed.resetTestingModule();
|
||||
routerSpy = jasmine.createSpyObj<Router>('Router', ['createUrlTree']);
|
||||
TestBed.configureTestingModule({
|
||||
@@ -65,13 +61,10 @@ describe('RoleGuard', () => {
|
||||
});
|
||||
guard = TestBed.inject(RoleGuard);
|
||||
|
||||
guard.canActivate({data: {requiredRoles: ['leader']}} as never).subscribe(result => {
|
||||
expect(result).toBeTrue();
|
||||
done();
|
||||
});
|
||||
await expectAsync(firstValueFrom(guard.canActivate({data: {requiredRoles: ['leader']}} as never))).toBeResolvedTo(true);
|
||||
});
|
||||
|
||||
it('should redirect users without the required role to their role default route', done => {
|
||||
it('should redirect users without the required role to their role default route', async () => {
|
||||
TestBed.resetTestingModule();
|
||||
routerSpy = jasmine.createSpyObj<Router>('Router', ['createUrlTree']);
|
||||
routerSpy.createUrlTree.and.returnValue({redirect: ['presentation']} as never);
|
||||
@@ -83,14 +76,12 @@ describe('RoleGuard', () => {
|
||||
});
|
||||
guard = TestBed.inject(RoleGuard);
|
||||
|
||||
guard.canActivate({data: {requiredRoles: ['leader']}} as never).subscribe(result => {
|
||||
expect(routerSpy.createUrlTree).toHaveBeenCalledWith(['presentation']);
|
||||
expect(result).toEqual({redirect: ['presentation']} as never);
|
||||
done();
|
||||
});
|
||||
const result = await firstValueFrom(guard.canActivate({data: {requiredRoles: ['leader']}} as never));
|
||||
expect(routerSpy.createUrlTree).toHaveBeenCalledWith(['presentation']);
|
||||
expect(result).toEqual({redirect: ['presentation']} as never);
|
||||
});
|
||||
|
||||
it('should redirect members to shows instead of new-user', done => {
|
||||
it('should redirect members to shows instead of new-user', async () => {
|
||||
TestBed.resetTestingModule();
|
||||
routerSpy = jasmine.createSpyObj<Router>('Router', ['createUrlTree']);
|
||||
routerSpy.createUrlTree.and.returnValue({redirect: ['shows']} as never);
|
||||
@@ -102,14 +93,12 @@ describe('RoleGuard', () => {
|
||||
});
|
||||
guard = TestBed.inject(RoleGuard);
|
||||
|
||||
guard.canActivate({data: {requiredRoles: ['user']}} as never).subscribe(result => {
|
||||
expect(routerSpy.createUrlTree).toHaveBeenCalledWith(['shows']);
|
||||
expect(result).toEqual({redirect: ['shows']} as never);
|
||||
done();
|
||||
});
|
||||
const result = await firstValueFrom(guard.canActivate({data: {requiredRoles: ['user']}} as never));
|
||||
expect(routerSpy.createUrlTree).toHaveBeenCalledWith(['shows']);
|
||||
expect(result).toEqual({redirect: ['shows']} as never);
|
||||
});
|
||||
|
||||
it('should choose a matching default route from all assigned roles', done => {
|
||||
it('should choose a matching default route from all assigned roles', async () => {
|
||||
TestBed.resetTestingModule();
|
||||
routerSpy = jasmine.createSpyObj<Router>('Router', ['createUrlTree']);
|
||||
routerSpy.createUrlTree.and.callFake(commands => ({redirect: commands}) as never);
|
||||
@@ -121,10 +110,8 @@ describe('RoleGuard', () => {
|
||||
});
|
||||
guard = TestBed.inject(RoleGuard);
|
||||
|
||||
guard.canActivate({data: {requiredRoles: ['presenter']}} as never).subscribe(result => {
|
||||
expect(routerSpy.createUrlTree).toHaveBeenCalledWith(['shows']);
|
||||
expect(result).toEqual({redirect: ['shows']} as never);
|
||||
done();
|
||||
});
|
||||
const result = await firstValueFrom(guard.canActivate({data: {requiredRoles: ['presenter']}} as never));
|
||||
expect(routerSpy.createUrlTree).toHaveBeenCalledWith(['shows']);
|
||||
expect(result).toEqual({redirect: ['shows']} as never);
|
||||
});
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user