123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316 |
- import 'reflect-metadata';
- import { assert } from 'chai';
- import { ServiceIdentifiers } from '../../../../src/container/ServiceIdentifiers';
- import { IIdentifierNamesGenerator } from '../../../../src/interfaces/generators/identifier-names-generators/IIdentifierNamesGenerator';
- import { IInversifyContainerFacade } from '../../../../src/interfaces/container/IInversifyContainerFacade';
- import { IdentifierNamesGenerator } from '../../../../src/enums/generators/identifier-names-generators/IdentifierNamesGenerator';
- import { InversifyContainerFacade } from '../../../../src/container/InversifyContainerFacade';
- import { MangledIdentifierNamesGenerator } from '../../../../src/generators/identifier-names-generators/MangledIdentifierNamesGenerator';
- describe('MangledIdentifierNamesGenerator', () => {
- describe('generateNext', () => {
- let identifierNamesGenerator: IIdentifierNamesGenerator,
- mangledIdentifierName: string;
- beforeEach(() => {
- const inversifyContainerFacade: IInversifyContainerFacade = new InversifyContainerFacade();
- inversifyContainerFacade.load('', '', {});
- identifierNamesGenerator = inversifyContainerFacade.getNamed<IIdentifierNamesGenerator>(
- ServiceIdentifiers.IIdentifierNamesGenerator,
- IdentifierNamesGenerator.MangledIdentifierNamesGenerator
- );
- });
- describe('Variant #1: initial mangled name', () => {
- const expectedMangledIdentifierName: string = 'a';
- beforeEach(() => {
- mangledIdentifierName = identifierNamesGenerator.generateNext();
- });
- it('should return mangled name', () => {
- assert.equal(mangledIdentifierName, expectedMangledIdentifierName);
- });
- });
- describe('Variant #2: second mangled name', () => {
- const expectedMangledIdentifierName: string = 'b';
- const expectedMangledIdentifierPosition: number = 1;
- beforeEach(() => {
- for (let i: number = 0; i <= expectedMangledIdentifierPosition; i++) {
- mangledIdentifierName = identifierNamesGenerator.generateNext();
- }
- });
- it('should return mangled name', () => {
- assert.equal(mangledIdentifierName, expectedMangledIdentifierName);
- });
- });
- describe('Variant #3: last mangled name with single character', () => {
- const expectedMangledIdentifierName: string = 'Z';
- const expectedMangledIdentifierPosition: number = 51;
- beforeEach(() => {
- for (let i: number = 0; i <= expectedMangledIdentifierPosition; i++) {
- mangledIdentifierName = identifierNamesGenerator.generateNext();
- }
- });
- it('should return mangled name', () => {
- assert.equal(mangledIdentifierName, expectedMangledIdentifierName);
- });
- });
- describe('Variant #4: correct increase of mangled name length', () => {
- const expectedMangledIdentifierName: string = 'a0';
- const expectedMangledIdentifierPosition: number = 52;
- beforeEach(() => {
- for (let i: number = 0; i <= expectedMangledIdentifierPosition; i++) {
- mangledIdentifierName = identifierNamesGenerator.generateNext();
- }
- });
- it('should return mangled name', () => {
- assert.equal(mangledIdentifierName, expectedMangledIdentifierName);
- });
- });
- describe('Variant #5: correct increase of mangled name length #2', () => {
- const expectedMangledIdentifierName: string = 'aa';
- const expectedMangledIdentifierPosition: number = 62;
- beforeEach(() => {
- for (let i: number = 0; i <= expectedMangledIdentifierPosition; i++) {
- mangledIdentifierName = identifierNamesGenerator.generateNext();
- }
- });
- it('should return mangled name', () => {
- assert.equal(mangledIdentifierName, expectedMangledIdentifierName);
- });
- });
- describe('Variant #6: reserved names', () => {
- const expectedMangledIdentifierName1: string = 'dn';
- const expectedMangledIdentifierName2: string = 'dp';
- const expectedMangledIdentifierPosition1: number = 261;
- const expectedMangledIdentifierPosition2: number = 262;
- let mangledIdentifierName1: string,
- mangledIdentifierName2: string;
- beforeEach(() => {
- for (let i: number = 0; i <= expectedMangledIdentifierPosition2; i++) {
- mangledIdentifierName = identifierNamesGenerator.generateNext();
- if (i === expectedMangledIdentifierPosition1) {
- mangledIdentifierName1 = mangledIdentifierName;
- } else if (i === expectedMangledIdentifierPosition2) {
- mangledIdentifierName2 = mangledIdentifierName;
- }
- }
- });
- it('should return mangled name', () => {
- assert.equal(mangledIdentifierName1, expectedMangledIdentifierName1);
- });
- it('shouldn\'t return reserved mangled name', () => {
- assert.equal(mangledIdentifierName2, expectedMangledIdentifierName2);
- });
- });
- });
- describe('generateForGlobalScope', () => {
- let identifierNamesGenerator: IIdentifierNamesGenerator,
- mangledIdentifierName: string;
- before(() => {
- const inversifyContainerFacade: IInversifyContainerFacade = new InversifyContainerFacade();
- inversifyContainerFacade.load('', '', {
- identifiersPrefix: 'foo'
- });
- identifierNamesGenerator = inversifyContainerFacade.getNamed<IIdentifierNamesGenerator>(
- ServiceIdentifiers.IIdentifierNamesGenerator,
- IdentifierNamesGenerator.MangledIdentifierNamesGenerator
- );
- });
- describe('Variant #1: initial mangled name', () => {
- const expectedMangledIdentifierName: string = 'fooa';
- beforeEach(() => {
- mangledIdentifierName = identifierNamesGenerator.generateForGlobalScope();
- });
- it('should return mangled name with prefix', () => {
- assert.equal(mangledIdentifierName, expectedMangledIdentifierName);
- });
- });
- describe('Variant #2: second mangled name', () => {
- const expectedMangledIdentifierName: string = 'foob';
- beforeEach(() => {
- mangledIdentifierName = identifierNamesGenerator.generateForGlobalScope();
- });
- it('should return mangled name with prefix', () => {
- assert.equal(mangledIdentifierName, expectedMangledIdentifierName);
- });
- });
- });
- describe('generateForLabel', () => {
- const label1: string = 'label1';
- const label2: string = 'label2';
- const mangledNames1: string[] = [];
- const mangledNames2: string[] = [];
- const expectedMangledNames1: string[] = ['a', 'b', 'c']
- const expectedMangledNames2: string[] = ['a', 'b']
- let identifierNamesGenerator: IIdentifierNamesGenerator;
- before(() => {
- const inversifyContainerFacade: IInversifyContainerFacade = new InversifyContainerFacade();
- inversifyContainerFacade.load('', '', {
- identifiersPrefix: 'foo'
- });
- identifierNamesGenerator = inversifyContainerFacade.getNamed<IIdentifierNamesGenerator>(
- ServiceIdentifiers.IIdentifierNamesGenerator,
- IdentifierNamesGenerator.MangledIdentifierNamesGenerator
- );
- mangledNames1.push(identifierNamesGenerator.generateForLabel(label1));
- mangledNames1.push(identifierNamesGenerator.generateForLabel(label1));
- mangledNames1.push(identifierNamesGenerator.generateForLabel(label1));
- mangledNames2.push(identifierNamesGenerator.generateForLabel(label2));
- mangledNames2.push(identifierNamesGenerator.generateForLabel(label2));
- });
- it('should return valid mangled names for label 1', () => {
- assert.deepEqual(mangledNames1, expectedMangledNames1);
- })
- it('should return valid mangled names for label 2', () => {
- assert.deepEqual(mangledNames2, expectedMangledNames2);
- })
- });
- describe('isIncrementedMangledName', function () {
- this.timeout(60000);
- const samplesCount: number = 1000000;
- const inversifyContainerFacade: IInversifyContainerFacade = new InversifyContainerFacade();
- inversifyContainerFacade.load('', '', {});
- const identifierNamesGenerator: IIdentifierNamesGenerator = inversifyContainerFacade.getNamed<IIdentifierNamesGenerator>(
- ServiceIdentifiers.IIdentifierNamesGenerator,
- IdentifierNamesGenerator.MangledIdentifierNamesGenerator
- );
- let isSuccessComparison: boolean = true;
- let mangledName: string = '';
- let prevMangledName: string = '9';
- for (let sample = 0; sample <= samplesCount; sample++) {
- let resultNormal: boolean;
- let resultReversed: boolean;
- mangledName = identifierNamesGenerator.generateNext();
- resultNormal = (<MangledIdentifierNamesGenerator>identifierNamesGenerator)
- .isIncrementedMangledName(mangledName, prevMangledName);
- resultReversed = (<MangledIdentifierNamesGenerator>identifierNamesGenerator)
- .isIncrementedMangledName(prevMangledName, mangledName);
- if (!resultNormal || resultReversed) {
- isSuccessComparison = false;
- break;
- }
- prevMangledName = mangledName;
- }
- it('should correctly compare mangled names', () => {
- assert.isTrue(isSuccessComparison);
- });
- });
- describe('isValidIdentifierName', () => {
- describe('Variant #1: reserved name as simple string', () => {
- const expectedFirstIdentifier: string = 'a';
- const expectedSecondIdentifier: string = 'd';
- const reservedNames: string[] = ['b', 'c'];
- let identifierNamesGenerator: IIdentifierNamesGenerator,
- firstMangledIdentifierName: string,
- secondMangledIdentifierName: string;
- beforeEach(() => {
- const inversifyContainerFacade: IInversifyContainerFacade = new InversifyContainerFacade();
- inversifyContainerFacade.load('', '', { reservedNames });
- identifierNamesGenerator = inversifyContainerFacade.getNamed<IIdentifierNamesGenerator>(
- ServiceIdentifiers.IIdentifierNamesGenerator,
- IdentifierNamesGenerator.MangledIdentifierNamesGenerator
- );
- firstMangledIdentifierName = identifierNamesGenerator.generateNext();
- secondMangledIdentifierName = identifierNamesGenerator.generateNext();
- });
- it('should generate first identifier', () => {
- assert.equal(firstMangledIdentifierName, expectedFirstIdentifier);
- });
- it('should generate second identifier', () => {
- assert.equal(secondMangledIdentifierName, expectedSecondIdentifier);
- });
- });
- describe('Variant #2: reserved name as string regexp', () => {
- const expectedFirstIdentifier: string = 'a';
- const expectedSecondIdentifier: string = 'g';
- const reservedNames: string[] = ['[b|c|d|e|f]'];
- let identifierNamesGenerator: IIdentifierNamesGenerator,
- firstMangledIdentifierName: string,
- secondMangledIdentifierName: string;
- beforeEach(() => {
- const inversifyContainerFacade: IInversifyContainerFacade = new InversifyContainerFacade();
- inversifyContainerFacade.load('', '', { reservedNames });
- identifierNamesGenerator = inversifyContainerFacade.getNamed<IIdentifierNamesGenerator>(
- ServiceIdentifiers.IIdentifierNamesGenerator,
- IdentifierNamesGenerator.MangledIdentifierNamesGenerator
- );
- firstMangledIdentifierName = identifierNamesGenerator.generateNext();
- secondMangledIdentifierName = identifierNamesGenerator.generateNext();
- });
- it('should generate first identifier', () => {
- assert.equal(firstMangledIdentifierName, expectedFirstIdentifier);
- });
- it('should generate second identifier', () => {
- assert.equal(secondMangledIdentifierName, expectedSecondIdentifier);
- });
- });
- });
- });
|