|
@@ -4,6 +4,8 @@ import { readFileAsString } from '../helpers/readFileAsString';
|
|
|
|
|
|
import { JavaScriptObfuscator } from '../../src/JavaScriptObfuscatorFacade';
|
|
|
|
|
|
+const heapValueToMB = (value: number) => Math.round(value / 1024 / 1024 * 100) / 100;
|
|
|
+
|
|
|
describe('JavaScriptObfuscator performance', function () {
|
|
|
const iterationsCount: number = 500;
|
|
|
|
|
@@ -26,4 +28,60 @@ describe('JavaScriptObfuscator performance', function () {
|
|
|
assert.isOk(true);
|
|
|
});
|
|
|
});
|
|
|
+
|
|
|
+ describe('performance: heap usage', () => {
|
|
|
+ it('should keep heap usage without memory leakd', () => {
|
|
|
+ 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);
|
|
|
+ });
|
|
|
+ });
|
|
|
});
|