MangledlIdentifierNamesGenerator.spec.ts 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343
  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 { MangledIdentifierNamesGenerator } from '../../../../src/generators/identifier-names-generators/MangledIdentifierNamesGenerator';
  9. describe('MangledIdentifierNamesGenerator', () => {
  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.MangledIdentifierNamesGenerator
  19. );
  20. });
  21. describe('Variant #1: initial mangled name', () => {
  22. const expectedMangledIdentifierName: string = 'a';
  23. beforeEach(() => {
  24. mangledIdentifierName = identifierNamesGenerator.generateNext();
  25. });
  26. it('should return mangled name', () => {
  27. assert.equal(mangledIdentifierName, expectedMangledIdentifierName);
  28. });
  29. });
  30. describe('Variant #2: second mangled name', () => {
  31. const expectedMangledIdentifierName: string = 'b';
  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.equal(mangledIdentifierName, expectedMangledIdentifierName);
  40. });
  41. });
  42. describe('Variant #3: last mangled name with single character', () => {
  43. const expectedMangledIdentifierName: string = 'Z';
  44. const expectedMangledIdentifierPosition: number = 51;
  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.equal(mangledIdentifierName, expectedMangledIdentifierName);
  52. });
  53. });
  54. describe('Variant #4: correct increase of mangled name length', () => {
  55. const expectedMangledIdentifierName: string = 'a0';
  56. const expectedMangledIdentifierPosition: number = 52;
  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.equal(mangledIdentifierName, expectedMangledIdentifierName);
  64. });
  65. });
  66. describe('Variant #5: correct increase of mangled name length #2', () => {
  67. const expectedMangledIdentifierName: string = 'aa';
  68. const expectedMangledIdentifierPosition: number = 62;
  69. beforeEach(() => {
  70. for (let i: number = 0; i <= expectedMangledIdentifierPosition; i++) {
  71. mangledIdentifierName = identifierNamesGenerator.generateNext();
  72. }
  73. });
  74. it('should return mangled name', () => {
  75. assert.equal(mangledIdentifierName, expectedMangledIdentifierName);
  76. });
  77. });
  78. describe('Variant #6: reserved names', () => {
  79. const expectedMangledIdentifierName1: string = 'dn';
  80. const expectedMangledIdentifierName2: string = 'dp';
  81. const expectedMangledIdentifierPosition1: number = 261;
  82. const expectedMangledIdentifierPosition2: number = 262;
  83. let mangledIdentifierName1: string,
  84. mangledIdentifierName2: string;
  85. beforeEach(() => {
  86. for (let i: number = 0; i <= expectedMangledIdentifierPosition2; i++) {
  87. mangledIdentifierName = identifierNamesGenerator.generateNext();
  88. if (i === expectedMangledIdentifierPosition1) {
  89. mangledIdentifierName1 = mangledIdentifierName;
  90. } else if (i === expectedMangledIdentifierPosition2) {
  91. mangledIdentifierName2 = mangledIdentifierName;
  92. }
  93. }
  94. });
  95. it('should return mangled name', () => {
  96. assert.equal(mangledIdentifierName1, expectedMangledIdentifierName1);
  97. });
  98. it('shouldn\'t return reserved mangled name', () => {
  99. assert.equal(mangledIdentifierName2, expectedMangledIdentifierName2);
  100. });
  101. });
  102. });
  103. describe('generateForGlobalScope', () => {
  104. let identifierNamesGenerator: IIdentifierNamesGenerator,
  105. mangledIdentifierName: string;
  106. before(() => {
  107. const inversifyContainerFacade: IInversifyContainerFacade = new InversifyContainerFacade();
  108. inversifyContainerFacade.load('', '', {
  109. identifiersPrefix: 'foo'
  110. });
  111. identifierNamesGenerator = inversifyContainerFacade.getNamed<IIdentifierNamesGenerator>(
  112. ServiceIdentifiers.IIdentifierNamesGenerator,
  113. IdentifierNamesGenerator.MangledIdentifierNamesGenerator
  114. );
  115. });
  116. describe('Variant #1: initial mangled name', () => {
  117. const expectedMangledIdentifierName: string = 'fooa';
  118. beforeEach(() => {
  119. mangledIdentifierName = identifierNamesGenerator.generateForGlobalScope();
  120. });
  121. it('should return mangled name with prefix', () => {
  122. assert.equal(mangledIdentifierName, expectedMangledIdentifierName);
  123. });
  124. });
  125. describe('Variant #2: second mangled name', () => {
  126. const expectedMangledIdentifierName: string = 'foob';
  127. beforeEach(() => {
  128. mangledIdentifierName = identifierNamesGenerator.generateForGlobalScope();
  129. });
  130. it('should return mangled name with prefix', () => {
  131. assert.equal(mangledIdentifierName, expectedMangledIdentifierName);
  132. });
  133. });
  134. });
  135. describe('generateForLabel', () => {
  136. const label1: string = 'label1';
  137. const label2: string = 'label2';
  138. const mangledNames1: string[] = [];
  139. const mangledNames2: string[] = [];
  140. const expectedMangledNames1: string[] = ['a', 'b', 'c']
  141. const expectedMangledNames2: string[] = ['a', 'b']
  142. let identifierNamesGenerator: IIdentifierNamesGenerator;
  143. before(() => {
  144. const inversifyContainerFacade: IInversifyContainerFacade = new InversifyContainerFacade();
  145. inversifyContainerFacade.load('', '', {
  146. identifiersPrefix: 'foo'
  147. });
  148. identifierNamesGenerator = inversifyContainerFacade.getNamed<IIdentifierNamesGenerator>(
  149. ServiceIdentifiers.IIdentifierNamesGenerator,
  150. IdentifierNamesGenerator.MangledIdentifierNamesGenerator
  151. );
  152. mangledNames1.push(identifierNamesGenerator.generateForLabel(label1));
  153. mangledNames1.push(identifierNamesGenerator.generateForLabel(label1));
  154. mangledNames1.push(identifierNamesGenerator.generateForLabel(label1));
  155. mangledNames2.push(identifierNamesGenerator.generateForLabel(label2));
  156. mangledNames2.push(identifierNamesGenerator.generateForLabel(label2));
  157. });
  158. it('should return valid mangled names for label 1', () => {
  159. assert.deepEqual(mangledNames1, expectedMangledNames1);
  160. })
  161. it('should return valid mangled names for label 2', () => {
  162. assert.deepEqual(mangledNames2, expectedMangledNames2);
  163. })
  164. });
  165. describe('isIncrementedMangledName', function () {
  166. this.timeout(60000);
  167. const samplesCount: number = 1000000;
  168. const inversifyContainerFacade: IInversifyContainerFacade = new InversifyContainerFacade();
  169. inversifyContainerFacade.load('', '', {});
  170. const identifierNamesGenerator: IIdentifierNamesGenerator = inversifyContainerFacade.getNamed<IIdentifierNamesGenerator>(
  171. ServiceIdentifiers.IIdentifierNamesGenerator,
  172. IdentifierNamesGenerator.MangledIdentifierNamesGenerator
  173. );
  174. let isSuccessComparison: boolean = true;
  175. let mangledName: string = '';
  176. let prevMangledName: string = '9';
  177. for (let sample = 0; sample <= samplesCount; sample++) {
  178. let resultNormal: boolean;
  179. let resultReversed: boolean;
  180. mangledName = identifierNamesGenerator.generateNext();
  181. resultNormal = (<MangledIdentifierNamesGenerator>identifierNamesGenerator)
  182. .isIncrementedMangledName(mangledName, prevMangledName);
  183. resultReversed = (<MangledIdentifierNamesGenerator>identifierNamesGenerator)
  184. .isIncrementedMangledName(prevMangledName, mangledName);
  185. if (!resultNormal || resultReversed) {
  186. isSuccessComparison = false;
  187. break;
  188. }
  189. prevMangledName = mangledName;
  190. }
  191. it('should correctly compare mangled names', () => {
  192. assert.isTrue(isSuccessComparison);
  193. });
  194. });
  195. describe('isValidIdentifierName', () => {
  196. describe('Variant #1: reserved name as simple string', () => {
  197. const expectedFirstIdentifier: string = 'a';
  198. const expectedSecondIdentifier: string = 'd';
  199. const reservedNames: string[] = ['b', 'c'];
  200. let identifierNamesGenerator: IIdentifierNamesGenerator,
  201. firstMangledIdentifierName: string,
  202. secondMangledIdentifierName: string;
  203. beforeEach(() => {
  204. const inversifyContainerFacade: IInversifyContainerFacade = new InversifyContainerFacade();
  205. inversifyContainerFacade.load('', '', { reservedNames });
  206. identifierNamesGenerator = inversifyContainerFacade.getNamed<IIdentifierNamesGenerator>(
  207. ServiceIdentifiers.IIdentifierNamesGenerator,
  208. IdentifierNamesGenerator.MangledIdentifierNamesGenerator
  209. );
  210. firstMangledIdentifierName = identifierNamesGenerator.generateNext();
  211. secondMangledIdentifierName = identifierNamesGenerator.generateNext();
  212. });
  213. it('should generate first identifier', () => {
  214. assert.equal(firstMangledIdentifierName, expectedFirstIdentifier);
  215. });
  216. it('should generate second identifier', () => {
  217. assert.equal(secondMangledIdentifierName, expectedSecondIdentifier);
  218. });
  219. });
  220. describe('Variant #2: reserved name as string regexp', () => {
  221. const expectedFirstIdentifier: string = 'a';
  222. const expectedSecondIdentifier: string = 'g';
  223. const reservedNames: string[] = ['[b|c|d|e|f]'];
  224. let identifierNamesGenerator: IIdentifierNamesGenerator,
  225. firstMangledIdentifierName: string,
  226. secondMangledIdentifierName: string;
  227. beforeEach(() => {
  228. const inversifyContainerFacade: IInversifyContainerFacade = new InversifyContainerFacade();
  229. inversifyContainerFacade.load('', '', { reservedNames });
  230. identifierNamesGenerator = inversifyContainerFacade.getNamed<IIdentifierNamesGenerator>(
  231. ServiceIdentifiers.IIdentifierNamesGenerator,
  232. IdentifierNamesGenerator.MangledIdentifierNamesGenerator
  233. );
  234. firstMangledIdentifierName = identifierNamesGenerator.generateNext();
  235. secondMangledIdentifierName = identifierNamesGenerator.generateNext();
  236. });
  237. it('should generate first identifier', () => {
  238. assert.equal(firstMangledIdentifierName, expectedFirstIdentifier);
  239. });
  240. it('should generate second identifier', () => {
  241. assert.equal(secondMangledIdentifierName, expectedSecondIdentifier);
  242. });
  243. });
  244. describe('Variant #3: reserved dom property name', () => {
  245. let identifierNamesGenerator: IIdentifierNamesGenerator,
  246. isValidName1: boolean,
  247. isValidName2: boolean,
  248. isValidName3: boolean;
  249. beforeEach(() => {
  250. const inversifyContainerFacade: IInversifyContainerFacade = new InversifyContainerFacade();
  251. inversifyContainerFacade.load('', '', {} );
  252. identifierNamesGenerator = inversifyContainerFacade.getNamed<IIdentifierNamesGenerator>(
  253. ServiceIdentifiers.IIdentifierNamesGenerator,
  254. IdentifierNamesGenerator.MangledIdentifierNamesGenerator
  255. );
  256. isValidName1 = identifierNamesGenerator.isValidIdentifierName('Set');
  257. isValidName2 = identifierNamesGenerator.isValidIdentifierName('Array');
  258. isValidName3 = identifierNamesGenerator.isValidIdentifierName('WeakSet');
  259. });
  260. it('should generate first identifier', () => {
  261. assert.isFalse(isValidName1);
  262. assert.isFalse(isValidName2);
  263. assert.isTrue(isValidName3);
  264. });
  265. });
  266. });
  267. });