MangledShuffledlIdentifierNamesGenerator.spec.ts 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  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. import { MangledShuffledIdentifierNamesGenerator } from '../../../../src/generators/identifier-names-generators/MangledShuffledIdentifierNamesGenerator';
  9. describe('MangledShuffledIdentifierNamesGenerator', () => {
  10. describe('generateNext', () => {
  11. let identifierNamesGenerator: IIdentifierNamesGenerator,
  12. mangledIdentifierName: string;
  13. beforeEach(() => {
  14. const inversifyContainerFacade: IInversifyContainerFacade = new InversifyContainerFacade();
  15. inversifyContainerFacade.load('', '', {});
  16. identifierNamesGenerator = inversifyContainerFacade.getNamed<IIdentifierNamesGenerator>(
  17. ServiceIdentifiers.IIdentifierNamesGenerator,
  18. IdentifierNamesGenerator.MangledShuffledIdentifierNamesGenerator
  19. );
  20. });
  21. describe('Variant #1: initial mangled name', () => {
  22. const expectedMangledIdentifierNameRegExp: RegExp = /[a-zA-Z]/;
  23. beforeEach(() => {
  24. mangledIdentifierName = identifierNamesGenerator.generateNext();
  25. });
  26. it('should return mangled name', () => {
  27. assert.match(mangledIdentifierName, expectedMangledIdentifierNameRegExp);
  28. });
  29. });
  30. describe('Variant #2: second mangled name', () => {
  31. const expectedMangledIdentifierNameRegExp: RegExp = /[a-zA-Z]/;
  32. const expectedMangledIdentifierPosition: number = 1;
  33. beforeEach(() => {
  34. for (let i: number = 0; i <= expectedMangledIdentifierPosition; i++) {
  35. mangledIdentifierName = identifierNamesGenerator.generateNext();
  36. }
  37. });
  38. it('should return mangled name', () => {
  39. assert.match(mangledIdentifierName, expectedMangledIdentifierNameRegExp);
  40. });
  41. });
  42. describe('Variant #3: correct increase of mangled name length', () => {
  43. const expectedMangledIdentifierNameRegExp: RegExp = /[a-zA-Z]0/;
  44. const expectedMangledIdentifierPosition: number = 52;
  45. beforeEach(() => {
  46. for (let i: number = 0; i <= expectedMangledIdentifierPosition; i++) {
  47. mangledIdentifierName = identifierNamesGenerator.generateNext();
  48. }
  49. });
  50. it('should return mangled name', () => {
  51. assert.match(mangledIdentifierName, expectedMangledIdentifierNameRegExp);
  52. });
  53. });
  54. describe('Variant #4: correct increase of mangled name length #2', () => {
  55. const expectedMangledIdentifierNameRegExp: RegExp = /[a-zA-Z][a-zA-Z]/;
  56. const expectedMangledIdentifierPosition: number = 62;
  57. beforeEach(() => {
  58. for (let i: number = 0; i <= expectedMangledIdentifierPosition; i++) {
  59. mangledIdentifierName = identifierNamesGenerator.generateNext();
  60. }
  61. });
  62. it('should return mangled name', () => {
  63. assert.match(mangledIdentifierName, expectedMangledIdentifierNameRegExp);
  64. });
  65. });
  66. });
  67. describe('generateForGlobalScope', () => {
  68. let identifierNamesGenerator: IIdentifierNamesGenerator,
  69. mangledIdentifierName: string;
  70. before(() => {
  71. const inversifyContainerFacade: IInversifyContainerFacade = new InversifyContainerFacade();
  72. inversifyContainerFacade.load('', '', {
  73. identifiersPrefix: 'foo'
  74. });
  75. identifierNamesGenerator = inversifyContainerFacade.getNamed<IIdentifierNamesGenerator>(
  76. ServiceIdentifiers.IIdentifierNamesGenerator,
  77. IdentifierNamesGenerator.MangledIdentifierNamesGenerator
  78. );
  79. });
  80. describe('Variant #1: initial mangled name', () => {
  81. const expectedMangledIdentifierNameRegExp: RegExp = /foo[a-zA-Z]/;
  82. beforeEach(() => {
  83. mangledIdentifierName = identifierNamesGenerator.generateForGlobalScope();
  84. });
  85. it('should return mangled name with prefix', () => {
  86. assert.match(mangledIdentifierName, expectedMangledIdentifierNameRegExp);
  87. });
  88. });
  89. });
  90. describe('generateForLabel', () => {
  91. const label1: string = 'label1';
  92. const label2: string = 'label2';
  93. const mangledNames1: string[] = [];
  94. const mangledNames2: string[] = [];
  95. let identifierNamesGenerator: IIdentifierNamesGenerator;
  96. before(() => {
  97. const inversifyContainerFacade: IInversifyContainerFacade = new InversifyContainerFacade();
  98. inversifyContainerFacade.load('', '', {
  99. identifiersPrefix: 'foo'
  100. });
  101. identifierNamesGenerator = inversifyContainerFacade.getNamed<IIdentifierNamesGenerator>(
  102. ServiceIdentifiers.IIdentifierNamesGenerator,
  103. IdentifierNamesGenerator.MangledShuffledIdentifierNamesGenerator
  104. );
  105. mangledNames1.push(identifierNamesGenerator.generateForLabel(label1));
  106. mangledNames1.push(identifierNamesGenerator.generateForLabel(label1));
  107. mangledNames1.push(identifierNamesGenerator.generateForLabel(label1));
  108. mangledNames2.push(identifierNamesGenerator.generateForLabel(label2));
  109. mangledNames2.push(identifierNamesGenerator.generateForLabel(label2));
  110. mangledNames2.push(identifierNamesGenerator.generateForLabel(label2));
  111. });
  112. it('should return the same mangled names set for different labels', () => {
  113. assert.deepEqual(mangledNames1, mangledNames2);
  114. })
  115. });
  116. describe('isIncrementedMangledName', function () {
  117. this.timeout(60000);
  118. const samplesCount: number = 1000000;
  119. const inversifyContainerFacade: IInversifyContainerFacade = new InversifyContainerFacade();
  120. inversifyContainerFacade.load('', '', {});
  121. const identifierNamesGenerator: IIdentifierNamesGenerator = inversifyContainerFacade.getNamed<IIdentifierNamesGenerator>(
  122. ServiceIdentifiers.IIdentifierNamesGenerator,
  123. IdentifierNamesGenerator.MangledShuffledIdentifierNamesGenerator
  124. );
  125. let isSuccessComparison: boolean = true;
  126. let mangledName: string = '';
  127. let prevMangledName: string = '9';
  128. for (let sample = 0; sample <= samplesCount; sample++) {
  129. let resultNormal: boolean;
  130. let resultReversed: boolean;
  131. mangledName = identifierNamesGenerator.generateNext();
  132. resultNormal = (<MangledShuffledIdentifierNamesGenerator>identifierNamesGenerator)
  133. .isIncrementedMangledName(mangledName, prevMangledName);
  134. resultReversed = (<MangledShuffledIdentifierNamesGenerator>identifierNamesGenerator)
  135. .isIncrementedMangledName(prevMangledName, mangledName);
  136. if (!resultNormal || resultReversed) {
  137. isSuccessComparison = false;
  138. break;
  139. }
  140. prevMangledName = mangledName;
  141. }
  142. it('should correctly compare mangled names', () => {
  143. assert.isTrue(isSuccessComparison);
  144. });
  145. });
  146. });