MangledlIdentifierNamesGenerator.spec.ts 3.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. import 'reflect-metadata';
  2. import { assert } from 'chai';
  3. import { ServiceIdentifiers } from '../../../../src/container/ServiceIdentifiers';
  4. import { IIdentifierNamesGenerator } from '../../../../src/interfaces/generators/identifier-names-generators/IIdentifierNamesGenerator';
  5. import { IInversifyContainerFacade } from '../../../../src/interfaces/container/IInversifyContainerFacade';
  6. import { IdentifierNamesGenerator } from '../../../../src/enums/generators/identifier-names-generators/IdentifierNamesGenerator';
  7. import { InversifyContainerFacade } from '../../../../src/container/InversifyContainerFacade';
  8. describe('MangledIdentifierNamesGenerator', () => {
  9. describe('generate (length: number): string', () => {
  10. let identifierNamesGenerator: IIdentifierNamesGenerator,
  11. mangledIdentifierName: string;
  12. before(() => {
  13. const inversifyContainerFacade: IInversifyContainerFacade = new InversifyContainerFacade();
  14. inversifyContainerFacade.load('', {});
  15. identifierNamesGenerator = inversifyContainerFacade.getNamed<IIdentifierNamesGenerator>(
  16. ServiceIdentifiers.IIdentifierNamesGenerator,
  17. IdentifierNamesGenerator.MangledIdentifierNamesGenerator
  18. )
  19. });
  20. describe('variant #1: initial mangled name', () => {
  21. const expectedMangledIdentifierName: string = 'a';
  22. before(() => {
  23. mangledIdentifierName = identifierNamesGenerator.generate(4);
  24. });
  25. it('should return hexadecimal name', () => {
  26. assert.equal(mangledIdentifierName, expectedMangledIdentifierName);
  27. })
  28. });
  29. describe('variant #2: second mangled name', () => {
  30. const expectedMangledIdentifierName: string = 'b';
  31. before(() => {
  32. mangledIdentifierName = identifierNamesGenerator.generate(6);
  33. });
  34. it('should return hexadecimal name', () => {
  35. assert.equal(mangledIdentifierName, expectedMangledIdentifierName);
  36. })
  37. });
  38. describe('variant #3: last mangled name with single character', () => {
  39. const expectedMangledIdentifierName: string = 'Z';
  40. before(() => {
  41. for (let i: number = 0; i <= 49; i++) {
  42. mangledIdentifierName = identifierNamesGenerator.generate(6);
  43. }
  44. });
  45. it('should return hexadecimal name', () => {
  46. assert.equal(mangledIdentifierName, expectedMangledIdentifierName);
  47. })
  48. });
  49. describe('variant #4: correct increase of mangled name length', () => {
  50. const expectedMangledIdentifierName: string = 'a0';
  51. before(() => {
  52. for (let i: number = 0; i < 1; i++) {
  53. mangledIdentifierName = identifierNamesGenerator.generate(6);
  54. }
  55. });
  56. it('should return hexadecimal name', () => {
  57. assert.equal(mangledIdentifierName, expectedMangledIdentifierName);
  58. })
  59. });
  60. describe('variant #4: correct increase of mangled name length #2', () => {
  61. const expectedMangledIdentifierName: string = 'aa';
  62. before(() => {
  63. for (let i: number = 0; i < 10; i++) {
  64. mangledIdentifierName = identifierNamesGenerator.generate(6);
  65. }
  66. });
  67. it('should return hexadecimal name', () => {
  68. assert.equal(mangledIdentifierName, expectedMangledIdentifierName);
  69. })
  70. });
  71. });
  72. });