mirror of
https://github.com/denoland/deno.git
synced 2025-01-07 22:58:24 -05:00
fix(node/zlib): consistently return buffer (#21747)
This fixes point 3 of https://github.com/denoland/deno/issues/20516 This PR creates consistency between the sync and async versions of the brotli compress where we will always return a buffer like Node.
This commit is contained in:
parent
2319c51dc0
commit
ce539e9189
2 changed files with 14 additions and 1 deletions
|
@ -3,6 +3,7 @@
|
||||||
import { assert, assertEquals } from "../../../test_util/std/assert/mod.ts";
|
import { assert, assertEquals } from "../../../test_util/std/assert/mod.ts";
|
||||||
import { fromFileUrl, relative } from "../../../test_util/std/path/mod.ts";
|
import { fromFileUrl, relative } from "../../../test_util/std/path/mod.ts";
|
||||||
import {
|
import {
|
||||||
|
brotliCompress,
|
||||||
brotliCompressSync,
|
brotliCompressSync,
|
||||||
brotliDecompressSync,
|
brotliDecompressSync,
|
||||||
createBrotliCompress,
|
createBrotliCompress,
|
||||||
|
@ -19,6 +20,18 @@ Deno.test("brotli compression sync", () => {
|
||||||
assertEquals(decompressed.toString(), "hello world");
|
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("brotli compression", async () => {
|
Deno.test("brotli compression", async () => {
|
||||||
const { promise, resolve } = Promise.withResolvers<void>();
|
const { promise, resolve } = Promise.withResolvers<void>();
|
||||||
const compress = createBrotliCompress();
|
const compress = createBrotliCompress();
|
||||||
|
|
|
@ -126,7 +126,7 @@ export function brotliCompress(
|
||||||
|
|
||||||
const { quality, lgwin, mode } = oneOffCompressOptions(options);
|
const { quality, lgwin, mode } = oneOffCompressOptions(options);
|
||||||
op_brotli_compress_async(buf, quality, lgwin, mode)
|
op_brotli_compress_async(buf, quality, lgwin, mode)
|
||||||
.then((result) => callback(null, result))
|
.then((result) => callback(null, Buffer.from(result)))
|
||||||
.catch((err) => callback(err));
|
.catch((err) => callback(err));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue