diff --git a/test/issue_130/issue_130.test.js b/test/issue_130/issue_130.test.js new file mode 100644 index 0000000..b32ccb3 --- /dev/null +++ b/test/issue_130/issue_130.test.js @@ -0,0 +1,54 @@ +"use strict"; + +const assert = require("assert"); +const fs = require("fs"); +const pth = require("path"); +const Zip = require("../../adm-zip"); +const rimraf = require("rimraf"); + +describe("ADM-ZIP - Issues", () => { + const destination = pth.resolve("./test/xxx"); + const unzipped = pth.join(destination, "unzipped"); + + // clean up folder content + afterEach((done) => rimraf(destination, done)); + + it("Issue 130 - Created zip's under Windows are corrupt", () => { + // init the final zip file + const writeZip = new Zip(); + + // file in root folder + writeZip.addFile("root_file.txt", "root"); + + // add folder + writeZip.addFile("sub/", Buffer.alloc(0)); + + // file in sub folder + writeZip.addFile("sub/sub_file.txt", "sub"); + + // files from local folder + writeZip.addLocalFolder(pth.resolve("./test/issue_130", "nested"), "nested"); + + // write to disk + writeZip.writeZip(pth.join(destination, "test.zip")); + + // read zip from disk + const readZip = new Zip(pth.join(destination, "test.zip")); + + // unpack everything + readZip.extractAllTo(unzipped, true); + + // assert the files + const fileRoot = fs.readFileSync(pth.join(unzipped, "root_file.txt"), "utf8"); + assert(fileRoot === "root", "root file not correct"); + + const fileSub = fs.readFileSync(pth.join(unzipped, "sub/sub_file.txt"), "utf8"); + assert(fileSub === "sub", "sub file not correct"); + + const fileNested = fs.readFileSync(pth.join(unzipped, "nested/nested_file.txt"), "utf8"); + assert(fileNested === "nested", "nested file not correct"); + + const fileDeeper = fs.readFileSync(pth.join(unzipped, "nested/deeper/deeper_file.txt"), "utf8"); + assert(fileDeeper === "deeper", "deeper file not correct"); + }); +}); diff --git a/test/issue_130/test.js b/test/issue_130/test.js deleted file mode 100644 index cf959db..0000000 --- a/test/issue_130/test.js +++ /dev/null @@ -1,50 +0,0 @@ -"use strict"; - -(function () { - var fs = require("fs"); - var path = require("path"); - var Zip = require("../../adm-zip"); - - // init the final zip file - var writeZip = new Zip(); - - // file in root folder - writeZip.addFile("root_file.txt", "root"); - - // add folder - writeZip.addFile("sub/", Buffer.alloc(0)); - - // file in sub folder - writeZip.addFile("sub/sub_file.txt", "sub"); - - // files from local folder - writeZip.addLocalFolder("nested", "nested"); - - // write to disk - writeZip.writeZip("test.zip"); - - // read zip from disk - var readZip = new Zip("test.zip"); - - // unpack everything - readZip.extractAllTo("unzipped", true); - - // assert the files - var assert = function (content, expectedContent, errMsg) { - if (content !== expectedContent) { - throw new Error(errMsg); - } - }; - - var fileRoot = fs.readFileSync(path.join("unzipped", "root_file.txt"), "utf8"); - assert(fileRoot, "root", "root file not correct"); - - var fileSub = fs.readFileSync(path.join("unzipped", "sub", "sub_file.txt"), "utf8"); - assert(fileSub, "sub", "sub file not correct"); - - var fileNested = fs.readFileSync(path.join("unzipped", "nested", "nested_file.txt"), "utf8"); - assert(fileNested, "nested", "nested file not correct"); - - var fileDeeper = fs.readFileSync(path.join("unzipped", "nested", "deeper", "deeper_file.txt"), "utf8"); - assert(fileDeeper, "deeper", "deeper file not correct"); -})();