MangledlIdentifierNamesGenerator.spec.ts 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236
  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', () => {
  10. let identifierNamesGenerator: IIdentifierNamesGenerator,
  11. mangledIdentifierName: string;
  12. beforeEach(() => {
  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. beforeEach(() => {
  23. mangledIdentifierName = identifierNamesGenerator.generate();
  24. });
  25. it('should return mangled name', () => {
  26. assert.equal(mangledIdentifierName, expectedMangledIdentifierName);
  27. });
  28. });
  29. describe('Variant #2: second mangled name', () => {
  30. const expectedMangledIdentifierName: string = 'b';
  31. const expectedMangledIdentifierPosition: number = 1;
  32. beforeEach(() => {
  33. for (let i: number = 0; i <= expectedMangledIdentifierPosition; i++) {
  34. mangledIdentifierName = identifierNamesGenerator.generate();
  35. }
  36. });
  37. it('should return mangled name', () => {
  38. assert.equal(mangledIdentifierName, expectedMangledIdentifierName);
  39. });
  40. });
  41. describe('Variant #3: last mangled name with single character', () => {
  42. const expectedMangledIdentifierName: string = 'Z';
  43. const expectedMangledIdentifierPosition: number = 51;
  44. beforeEach(() => {
  45. for (let i: number = 0; i <= expectedMangledIdentifierPosition; i++) {
  46. mangledIdentifierName = identifierNamesGenerator.generate();
  47. }
  48. });
  49. it('should return mangled name', () => {
  50. assert.equal(mangledIdentifierName, expectedMangledIdentifierName);
  51. });
  52. });
  53. describe('Variant #4: correct increase of mangled name length', () => {
  54. const expectedMangledIdentifierName: string = 'a0';
  55. const expectedMangledIdentifierPosition: number = 52;
  56. beforeEach(() => {
  57. for (let i: number = 0; i <= expectedMangledIdentifierPosition; i++) {
  58. mangledIdentifierName = identifierNamesGenerator.generate();
  59. }
  60. });
  61. it('should return mangled name', () => {
  62. assert.equal(mangledIdentifierName, expectedMangledIdentifierName);
  63. });
  64. });
  65. describe('Variant #5: correct increase of mangled name length #2', () => {
  66. const expectedMangledIdentifierName: string = 'aa';
  67. const expectedMangledIdentifierPosition: number = 62;
  68. beforeEach(() => {
  69. for (let i: number = 0; i <= expectedMangledIdentifierPosition; i++) {
  70. mangledIdentifierName = identifierNamesGenerator.generate();
  71. }
  72. });
  73. it('should return mangled name', () => {
  74. assert.equal(mangledIdentifierName, expectedMangledIdentifierName);
  75. });
  76. });
  77. describe('Variant #6: reserved names', () => {
  78. const expectedMangledIdentifierName1: string = 'dn';
  79. const expectedMangledIdentifierName2: string = 'dp';
  80. const expectedMangledIdentifierPosition1: number = 261;
  81. const expectedMangledIdentifierPosition2: number = 262;
  82. let mangledIdentifierName1: string,
  83. mangledIdentifierName2: string;
  84. beforeEach(() => {
  85. for (let i: number = 0; i <= expectedMangledIdentifierPosition2; i++) {
  86. mangledIdentifierName = identifierNamesGenerator.generate();
  87. if (i === expectedMangledIdentifierPosition1) {
  88. mangledIdentifierName1 = mangledIdentifierName;
  89. } else if (i === expectedMangledIdentifierPosition2) {
  90. mangledIdentifierName2 = mangledIdentifierName;
  91. }
  92. }
  93. });
  94. it('should return mangled name', () => {
  95. assert.equal(mangledIdentifierName1, expectedMangledIdentifierName1);
  96. });
  97. it('shouldn\'t return reserved mangled name', () => {
  98. assert.equal(mangledIdentifierName2, expectedMangledIdentifierName2);
  99. });
  100. });
  101. });
  102. describe('generateWithPrefix (): string', () => {
  103. let identifierNamesGenerator: IIdentifierNamesGenerator,
  104. mangledIdentifierName: string;
  105. before(() => {
  106. const inversifyContainerFacade: IInversifyContainerFacade = new InversifyContainerFacade();
  107. inversifyContainerFacade.load('', {
  108. identifiersPrefix: 'foo'
  109. });
  110. identifierNamesGenerator = inversifyContainerFacade.getNamed<IIdentifierNamesGenerator>(
  111. ServiceIdentifiers.IIdentifierNamesGenerator,
  112. IdentifierNamesGenerator.MangledIdentifierNamesGenerator
  113. );
  114. });
  115. describe('Variant #1: initial mangled name', () => {
  116. const expectedMangledIdentifierName: string = 'foo_a';
  117. beforeEach(() => {
  118. mangledIdentifierName = identifierNamesGenerator.generateWithPrefix();
  119. });
  120. it('should return mangled name with prefix', () => {
  121. assert.equal(mangledIdentifierName, expectedMangledIdentifierName);
  122. });
  123. });
  124. describe('Variant #2: second mangled name', () => {
  125. const expectedMangledIdentifierName: string = 'foo_b';
  126. beforeEach(() => {
  127. mangledIdentifierName = identifierNamesGenerator.generateWithPrefix();
  128. });
  129. it('should return mangled name with prefix', () => {
  130. assert.equal(mangledIdentifierName, expectedMangledIdentifierName);
  131. });
  132. });
  133. });
  134. describe('isValidIdentifierName (identifierName: string): boolean', () => {
  135. describe('Variant #1: reserved name as simple string', () => {
  136. const expectedFirstIdentifier: string = 'a';
  137. const expectedSecondIdentifier: string = 'd';
  138. const reservedNames: string[] = ['b', 'c'];
  139. let identifierNamesGenerator: IIdentifierNamesGenerator,
  140. firstMangledIdentifierName: string,
  141. secondMangledIdentifierName: string;
  142. beforeEach(() => {
  143. const inversifyContainerFacade: IInversifyContainerFacade = new InversifyContainerFacade();
  144. inversifyContainerFacade.load('', { reservedNames });
  145. identifierNamesGenerator = inversifyContainerFacade.getNamed<IIdentifierNamesGenerator>(
  146. ServiceIdentifiers.IIdentifierNamesGenerator,
  147. IdentifierNamesGenerator.MangledIdentifierNamesGenerator
  148. );
  149. firstMangledIdentifierName = identifierNamesGenerator.generate();
  150. secondMangledIdentifierName = identifierNamesGenerator.generate();
  151. });
  152. it('should generate first identifier', () => {
  153. assert.equal(firstMangledIdentifierName, expectedFirstIdentifier);
  154. });
  155. it('should generate second identifier', () => {
  156. assert.equal(secondMangledIdentifierName, expectedSecondIdentifier);
  157. });
  158. });
  159. describe('Variant #2: reserved name as string regexp', () => {
  160. const expectedFirstIdentifier: string = 'a';
  161. const expectedSecondIdentifier: string = 'g';
  162. const reservedNames: string[] = ['[b|c|d|e|f]'];
  163. let identifierNamesGenerator: IIdentifierNamesGenerator,
  164. firstMangledIdentifierName: string,
  165. secondMangledIdentifierName: string;
  166. beforeEach(() => {
  167. const inversifyContainerFacade: IInversifyContainerFacade = new InversifyContainerFacade();
  168. inversifyContainerFacade.load('', { reservedNames });
  169. identifierNamesGenerator = inversifyContainerFacade.getNamed<IIdentifierNamesGenerator>(
  170. ServiceIdentifiers.IIdentifierNamesGenerator,
  171. IdentifierNamesGenerator.MangledIdentifierNamesGenerator
  172. );
  173. firstMangledIdentifierName = identifierNamesGenerator.generate();
  174. secondMangledIdentifierName = identifierNamesGenerator.generate();
  175. });
  176. it('should generate first identifier', () => {
  177. assert.equal(firstMangledIdentifierName, expectedFirstIdentifier);
  178. });
  179. it('should generate second identifier', () => {
  180. assert.equal(secondMangledIdentifierName, expectedSecondIdentifier);
  181. });
  182. });
  183. });
  184. });