'use strict'; var fs = require('fs'); var path = require('path'); var assert = require('assert'); var pako = require('../index'); // Load fixtures to test // return: { 'filename1': content1, 'filename2': content2, ...} // function loadSamples(subdir) { var result = {}; var dir = path.join(__dirname, 'fixtures', subdir || 'samples'); fs.readdirSync(dir).sort().forEach(function (sample) { var filepath = path.join(dir, sample), extname = path.extname(filepath), basename = path.basename(filepath, extname), content = new Uint8Array(fs.readFileSync(filepath)); if (basename[0] === '_') { return; } // skip files with name, started with dash result[basename] = content; }); return result; } // Helper to test deflate/inflate with different options. // Use zlib streams, because it's the only way to define options. // function testSingle(zlib_method, pako_method, data, options) { var zlib_options = Object.assign({}, options); // hack for testing negative windowBits if (zlib_options.windowBits < 0) { zlib_options.windowBits = -zlib_options.windowBits; } var zlib_result = zlib_method(data, zlib_options); var pako_result = pako_method(data, options); // One more hack: gzip header contains OS code, that can vary. // Override OS code if requested. For simplicity, we assume it on fixed // position (= no additional gzip headers used) if (options.ignore_os) zlib_result[9] = pako_result[9]; assert.deepStrictEqual(pako_result, new Uint8Array(zlib_result)); } function testSamples(zlib_method, pako_method, samples, options) { Object.keys(samples).forEach(function (name) { var data = samples[name]; testSingle(zlib_method, pako_method, data, options); }); } function testInflate(samples, inflateOptions, deflateOptions) { var name, data, deflated, inflated; // inflate options have windowBits = 0 to force autodetect window size // for (name in samples) { if (!samples.hasOwnProperty(name)) continue; data = samples[name]; deflated = pako.deflate(data, deflateOptions); inflated = pako.inflate(deflated, inflateOptions); assert.deepStrictEqual(inflated, data); } } exports.testSamples = testSamples; exports.testInflate = testInflate; exports.loadSamples = loadSamples;