ngx-testing-tools
Version:
Makes Angular testing easier
61 lines • 12.3 kB
JavaScript
import { inject } from '@angular/core';
import { TestBed } from '@angular/core/testing';
import { isConstructor } from '../../../common/utils/constructor.util';
import { buildRouteSnapshot, getRouterState } from '../../../common/utils/router.util';
import { isCanActivateChildGuard, isCanActivateGuard, isCanDeactivateGuard, isCanLoadGuard, isCanMatchGuard } from '../../utils/guard.util';
export function buildChallengeTools(guardProxy, injector, guardType) {
const guard = guardProxy.instance;
switch (true) {
case isCanActivateGuard(guard, guardType):
return buildChallengeToolsForActivate(guardProxy, injector, 'canActivate');
case isCanActivateChildGuard(guard, guardType):
return buildChallengeToolsForActivate(guardProxy, injector, 'canActivateChild');
case isCanDeactivateGuard(guard, guardType):
return buildChallengeToolsForDeactivate(guardProxy, injector);
case isCanLoadGuard(guard, guardType):
return buildChallengeToolsForLoad(guardProxy, 'canLoad');
case isCanMatchGuard(guard, guardType):
return buildChallengeToolsForLoad(guardProxy, 'canMatch');
default:
throw new Error(`Unknown guard type (${guardType}) or invalid passed guard (${guard.name ?? guard}).`);
}
}
function buildChallengeToolsForActivate(guardProxy, injector, key) {
const challenge = () => {
const route = buildRouteSnapshot();
const state = getRouterState(injector);
return guardProxy[key](route, state);
};
challenge.withInfo = (info) => {
const { currentState: state = getRouterState(injector), data, params, queryParams, } = info;
const route = buildRouteSnapshot({ data, params, queryParams });
return guardProxy[key](route, state);
};
return challenge;
}
function buildChallengeToolsForDeactivate(guardProxy, injector) {
const challenge = () => {
const currentRoute = buildRouteSnapshot();
const state = getRouterState(injector);
return guardProxy.canDeactivate({}, currentRoute, state, state);
};
challenge.withInfo = (info) => {
const { currentState = getRouterState(injector), nextState = currentState, component: ComponentCtor, data, params, queryParams, } = info;
const component = (isConstructor(ComponentCtor)) ? TestBed.runInInjectionContext(() => inject(ComponentCtor)) : ComponentCtor;
const currentRoute = buildRouteSnapshot({ data, params, queryParams });
return guardProxy.canDeactivate(component ?? {}, currentRoute, currentState, nextState);
};
return challenge;
}
function buildChallengeToolsForLoad(guardProxy, key) {
const challenge = () => {
return guardProxy[key]({ data: {} }, []);
};
challenge.withInfo = (info) => {
const { route = {}, data = {}, segments = [], } = info;
route.data ??= data;
return guardProxy[key](route, segments);
};
return challenge;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"challenge-tools.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-testing-tools/src/lib/guard-test-bed/tools/challenge/challenge-tools.ts"],"names":[],"mappings":"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","sourcesContent":["import { inject, Injector } from '@angular/core';\nimport { TestBed } from '@angular/core/testing';\nimport { ActivatedRouteSnapshot, RouterStateSnapshot } from '@angular/router';\nimport { isConstructor } from '../../../common/utils/constructor.util';\nimport { buildRouteSnapshot, getRouterState } from '../../../common/utils/router.util';\nimport { InternalGuardCan } from '../../models/guard-can.model';\nimport { GuardProxy } from '../../proxy/guard-proxy';\nimport { isCanActivateChildGuard, isCanActivateGuard, isCanDeactivateGuard, isCanLoadGuard, isCanMatchGuard } from '../../utils/guard.util';\nimport { ChallengeTools } from './models/challenge-tools.model';\nimport { RoutingInfo } from './models/routing-info.model';\n\nexport function buildChallengeTools(guardProxy: GuardProxy, injector: Injector, guardType: InternalGuardCan): ChallengeTools<any> {\n  const guard = guardProxy.instance;\n\n  switch (true) {\n    case isCanActivateGuard(guard, guardType):\n      return buildChallengeToolsForActivate(guardProxy, injector, 'canActivate');\n\n    case isCanActivateChildGuard(guard, guardType):\n      return buildChallengeToolsForActivate(guardProxy, injector, 'canActivateChild');\n\n    case isCanDeactivateGuard(guard, guardType):\n      return buildChallengeToolsForDeactivate(guardProxy, injector);\n\n    case isCanLoadGuard(guard, guardType):\n      return buildChallengeToolsForLoad(guardProxy, 'canLoad');\n\n    case isCanMatchGuard(guard, guardType):\n      return buildChallengeToolsForLoad(guardProxy, 'canMatch');\n\n    default:\n      throw new Error(`Unknown guard type (${guardType}) or invalid passed guard (${guard.name ?? guard}).`);\n  }\n}\n\nfunction buildChallengeToolsForActivate(guardProxy: GuardProxy, injector: Injector, key: 'canActivate' | 'canActivateChild'): ChallengeTools<unknown> {\n  const challenge: ChallengeTools<any> = () => {\n    const route: ActivatedRouteSnapshot = buildRouteSnapshot();\n    const state: RouterStateSnapshot = getRouterState(injector);\n\n    return guardProxy[key](route, state);\n  };\n\n  challenge.withInfo = (info: RoutingInfo) => {\n    const {\n      currentState: state = getRouterState(injector),\n      data,\n      params,\n      queryParams,\n    } = info;\n\n    const route: ActivatedRouteSnapshot = buildRouteSnapshot({ data, params, queryParams });\n\n    return guardProxy[key](route, state);\n  };\n\n  return challenge;\n}\n\nfunction buildChallengeToolsForDeactivate(guardProxy: GuardProxy, injector: Injector): ChallengeTools<unknown> {\n  const challenge: ChallengeTools<any> = () => {\n    const currentRoute: ActivatedRouteSnapshot = buildRouteSnapshot();\n    const state: RouterStateSnapshot = getRouterState(injector);\n\n    return guardProxy.canDeactivate({}, currentRoute, state, state);\n  };\n\n  challenge.withInfo = (info: RoutingInfo) => {\n    const {\n      currentState = getRouterState(injector),\n      nextState = currentState,\n      component: ComponentCtor,\n      data,\n      params,\n      queryParams,\n    } = info;\n\n    const component = (isConstructor(ComponentCtor)) ? TestBed.runInInjectionContext(() => inject(ComponentCtor)) : ComponentCtor;\n    const currentRoute: ActivatedRouteSnapshot = buildRouteSnapshot({ data, params, queryParams });\n\n    return guardProxy.canDeactivate(component ?? {}, currentRoute, currentState, nextState);\n  };\n\n  return challenge;\n}\n\nfunction buildChallengeToolsForLoad(guardProxy: GuardProxy, key: 'canLoad' | 'canMatch'): ChallengeTools<unknown> {\n  const challenge: ChallengeTools<any> = () => {\n    return guardProxy[key]({ data: {} }, []);\n  };\n\n  challenge.withInfo = (info: RoutingInfo) => {\n    const {\n      route = {},\n      data = {},\n      segments = [],\n    } = info;\n\n    route.data ??= data;\n    return guardProxy[key](route, segments);\n  };\n\n  return challenge;\n}\n"]}