|
@@ -4,8 +4,6 @@ import { readFileAsString } from '../helpers/readFileAsString';
|
|
|
|
|
|
import { JavaScriptObfuscator } from '../../src/JavaScriptObfuscatorFacade';
|
|
import { JavaScriptObfuscator } from '../../src/JavaScriptObfuscatorFacade';
|
|
|
|
|
|
-const heapValueToMB = (value: number) => Math.round(value / 1024 / 1024 * 100) / 100;
|
|
|
|
-
|
|
|
|
describe('JavaScriptObfuscator performance', function () {
|
|
describe('JavaScriptObfuscator performance', function () {
|
|
const iterationsCount: number = 500;
|
|
const iterationsCount: number = 500;
|
|
|
|
|
|
@@ -28,60 +26,4 @@ describe('JavaScriptObfuscator performance', function () {
|
|
assert.isOk(true);
|
|
assert.isOk(true);
|
|
});
|
|
});
|
|
});
|
|
});
|
|
-
|
|
|
|
- describe('performance: heap usage', () => {
|
|
|
|
- it('should keep heap usage without memory leaks', () => {
|
|
|
|
- const sourceCode: string = readFileAsString('./test/fixtures/sample.js');
|
|
|
|
-
|
|
|
|
- const maxHeapUsed: number[] = [];
|
|
|
|
- let prevHeapUsed: number | null = null;
|
|
|
|
-
|
|
|
|
- for (let i: number = 0; i < iterationsCount; i++) {
|
|
|
|
- JavaScriptObfuscator.obfuscate(
|
|
|
|
- sourceCode,
|
|
|
|
- {
|
|
|
|
- compact: true,
|
|
|
|
- controlFlowFlattening: true,
|
|
|
|
- controlFlowFlatteningThreshold: 0.75,
|
|
|
|
- deadCodeInjection: true,
|
|
|
|
- deadCodeInjectionThreshold: 0.4,
|
|
|
|
- debugProtection: false,
|
|
|
|
- debugProtectionInterval: false,
|
|
|
|
- disableConsoleOutput: true,
|
|
|
|
- identifierNamesGenerator: 'mangled',
|
|
|
|
- log: false,
|
|
|
|
- renameGlobals: false,
|
|
|
|
- rotateStringArray: true,
|
|
|
|
- selfDefending: true,
|
|
|
|
- shuffleStringArray: true,
|
|
|
|
- splitStrings: true,
|
|
|
|
- splitStringsChunkLength: 2,
|
|
|
|
- stringArray: true,
|
|
|
|
- stringArrayEncoding: 'base64',
|
|
|
|
- stringArrayThreshold: 0.75,
|
|
|
|
- transformObjectKeys: true,
|
|
|
|
- unicodeEscapeSequence: false
|
|
|
|
- }
|
|
|
|
- );
|
|
|
|
-
|
|
|
|
- const used = process.memoryUsage();
|
|
|
|
- const heapUsed: number = heapValueToMB(used.heapUsed);
|
|
|
|
-
|
|
|
|
- if (prevHeapUsed !== null && heapUsed < prevHeapUsed) {
|
|
|
|
- maxHeapUsed.push(prevHeapUsed);
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- prevHeapUsed = heapUsed;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- const sortedMaxHeapUsed: number[] = [...maxHeapUsed].sort();
|
|
|
|
-
|
|
|
|
- const firstMaxHeapMBUsed: number = sortedMaxHeapUsed[0];
|
|
|
|
- const lastMaxHeapMbUsed: number = sortedMaxHeapUsed[sortedMaxHeapUsed.length - 1];
|
|
|
|
-
|
|
|
|
- const diff: number = lastMaxHeapMbUsed - firstMaxHeapMBUsed;
|
|
|
|
-
|
|
|
|
- assert.closeTo(diff, 0, 20);
|
|
|
|
- });
|
|
|
|
- });
|
|
|
|
});
|
|
});
|