mirror of
https://github.com/denoland/deno.git
synced 2025-01-15 10:35:19 -05:00
f5ad15b504
Fixes #20516 Follow up to #21747 and #21746 This tackles the last point of #20516 where certain inputs weren't accepted in the other zlib methods This adds the `toU8` conversion of `_brotli` to `_zlib.mjs`, when we create the ZLibBuffer, we'll sanitize the input. I noticed that the async had no handler for `string` input so I added that as well.
157 lines
4.5 KiB
TypeScript
157 lines
4.5 KiB
TypeScript
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
|
|
|
import { assert, assertEquals } from "../../../test_util/std/assert/mod.ts";
|
|
import { fromFileUrl, relative } from "../../../test_util/std/path/mod.ts";
|
|
import {
|
|
brotliCompress,
|
|
brotliCompressSync,
|
|
brotliDecompressSync,
|
|
createBrotliCompress,
|
|
createBrotliDecompress,
|
|
createDeflate,
|
|
gzipSync,
|
|
unzipSync,
|
|
} from "node:zlib";
|
|
import { Buffer } from "node:buffer";
|
|
import { createReadStream, createWriteStream } from "node:fs";
|
|
|
|
Deno.test("brotli compression sync", () => {
|
|
const buf = Buffer.from("hello world");
|
|
const compressed = brotliCompressSync(buf);
|
|
const decompressed = brotliDecompressSync(compressed);
|
|
assertEquals(decompressed.toString(), "hello world");
|
|
});
|
|
|
|
Deno.test("brotli compression async", async () => {
|
|
const buf = Buffer.from("hello world");
|
|
const compressed: Buffer = await new Promise((resolve) =>
|
|
brotliCompress(buf, (_, res) => {
|
|
return resolve(res);
|
|
})
|
|
);
|
|
assertEquals(compressed instanceof Buffer, true);
|
|
const decompressed = brotliDecompressSync(compressed);
|
|
assertEquals(decompressed.toString(), "hello world");
|
|
});
|
|
|
|
Deno.test("gzip compression sync", { sanitizeResources: false }, () => {
|
|
const buf = Buffer.from("hello world");
|
|
const compressed = gzipSync(buf);
|
|
const decompressed = unzipSync(compressed);
|
|
assertEquals(decompressed.toString(), "hello world");
|
|
});
|
|
|
|
Deno.test("brotli compression", async () => {
|
|
const { promise, resolve } = Promise.withResolvers<void>();
|
|
const compress = createBrotliCompress();
|
|
const filePath = relative(
|
|
Deno.cwd(),
|
|
fromFileUrl(new URL("./testdata/lorem_ipsum.txt", import.meta.url)),
|
|
);
|
|
const input = createReadStream(filePath);
|
|
const output = createWriteStream("lorem_ipsum.txt.br");
|
|
|
|
const stream = input.pipe(compress).pipe(output);
|
|
|
|
stream.on("finish", () => {
|
|
const decompress = createBrotliDecompress();
|
|
const input2 = createReadStream("lorem_ipsum.txt.br");
|
|
const output2 = createWriteStream("lorem_ipsum.txt");
|
|
|
|
const stream2 = input2.pipe(decompress).pipe(output2);
|
|
|
|
stream2.on("finish", () => {
|
|
resolve();
|
|
});
|
|
});
|
|
|
|
await promise;
|
|
const content = Deno.readTextFileSync("lorem_ipsum.txt");
|
|
assert(content.startsWith("Lorem ipsum dolor sit amet"));
|
|
try {
|
|
Deno.removeSync("lorem_ipsum.txt.br");
|
|
} catch {
|
|
// pass
|
|
}
|
|
try {
|
|
Deno.removeSync("lorem_ipsum.txt");
|
|
} catch {
|
|
// pass
|
|
}
|
|
});
|
|
|
|
Deno.test("brotli end-to-end with 4097 bytes", () => {
|
|
const a = "a".repeat(4097);
|
|
const compressed = brotliCompressSync(a);
|
|
const decompressed = brotliDecompressSync(compressed);
|
|
assertEquals(decompressed.toString(), a);
|
|
});
|
|
|
|
Deno.test(
|
|
"zlib create deflate with dictionary",
|
|
{ sanitizeResources: false },
|
|
async () => {
|
|
const { promise, resolve } = Promise.withResolvers<void>();
|
|
const handle = createDeflate({
|
|
dictionary: Buffer.alloc(0),
|
|
});
|
|
|
|
handle.on("close", () => resolve());
|
|
handle.end();
|
|
handle.destroy();
|
|
|
|
await promise;
|
|
},
|
|
);
|
|
|
|
Deno.test(
|
|
"zlib flush i32",
|
|
// FIXME: Handle is not closed properly
|
|
{ sanitizeResources: false },
|
|
function () {
|
|
const handle = createDeflate({
|
|
// @ts-expect-error: passing non-int flush value
|
|
flush: "",
|
|
});
|
|
|
|
handle.end();
|
|
handle.destroy();
|
|
},
|
|
);
|
|
|
|
Deno.test("should work with dataview", () => {
|
|
const buf = Buffer.from("hello world");
|
|
const compressed = brotliCompressSync(new DataView(buf.buffer));
|
|
const decompressed = brotliDecompressSync(compressed);
|
|
assertEquals(decompressed.toString(), "hello world");
|
|
});
|
|
|
|
Deno.test("should work with a buffer from an encoded string", () => {
|
|
const encoder = new TextEncoder();
|
|
const buffer = encoder.encode("hello world");
|
|
const buf = Buffer.from(buffer);
|
|
const compressed = brotliCompressSync(buf);
|
|
const decompressed = brotliDecompressSync(compressed);
|
|
assertEquals(decompressed.toString(), "hello world");
|
|
});
|
|
|
|
Deno.test(
|
|
"zlib compression with dataview",
|
|
{ sanitizeResources: false },
|
|
() => {
|
|
const buf = Buffer.from("hello world");
|
|
const compressed = gzipSync(new DataView(buf.buffer));
|
|
const decompressed = unzipSync(compressed);
|
|
assertEquals(decompressed.toString(), "hello world");
|
|
},
|
|
);
|
|
|
|
Deno.test("zlib compression with an encoded string", {
|
|
sanitizeResources: false,
|
|
}, () => {
|
|
const encoder = new TextEncoder();
|
|
const buffer = encoder.encode("hello world");
|
|
const compressed = gzipSync(buffer);
|
|
const decompressed = unzipSync(compressed);
|
|
assertEquals(decompressed.toString(), "hello world");
|
|
});
|