mirror of
https://github.com/denoland/deno.git
synced 2025-01-11 16:42:21 -05:00
fix(ext/node): implement "ascii" encoding for node:fs writeFile() (#18097)
This commit is contained in:
parent
392f91da00
commit
96bc15dfa2
2 changed files with 50 additions and 2 deletions
48
cli/tests/unit_node/fs_test.ts
Normal file
48
cli/tests/unit_node/fs_test.ts
Normal file
|
@ -0,0 +1,48 @@
|
|||
// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
|
||||
|
||||
import {
|
||||
assert,
|
||||
assertThrows,
|
||||
} from "../../../test_util/std/testing/asserts.ts";
|
||||
import { join } from "node:path";
|
||||
import { tmpdir } from "node:os";
|
||||
import { mkdtempSync, readFileSync, writeFileSync } from "node:fs";
|
||||
|
||||
Deno.test(
|
||||
"[node/fs writeFileSync] write file without option",
|
||||
() => {
|
||||
const data = "Hello";
|
||||
const filename = mkdtempSync(join(tmpdir(), "foo-")) + "/test.txt";
|
||||
|
||||
writeFileSync(filename, data);
|
||||
const dataRead = readFileSync(filename, "utf8");
|
||||
|
||||
assert(dataRead === "Hello");
|
||||
},
|
||||
);
|
||||
|
||||
Deno.test(
|
||||
"[node/fs writeFileSync] write file with option ASCII",
|
||||
() => {
|
||||
const data = "Hello";
|
||||
const filename = mkdtempSync(join(tmpdir(), "foo-")) + "/test.txt";
|
||||
|
||||
writeFileSync(filename, data, { encoding: "ascii" });
|
||||
const dataRead = readFileSync(filename, "utf8");
|
||||
|
||||
assert(dataRead === "Hello");
|
||||
},
|
||||
);
|
||||
|
||||
Deno.test(
|
||||
"[node/fs writeFileSync] write file throws error when encoding is not implemented",
|
||||
() => {
|
||||
const data = "Hello";
|
||||
const filename = mkdtempSync(join(tmpdir(), "foo-")) + "/test.txt";
|
||||
|
||||
assertThrows(
|
||||
() => writeFileSync(filename, data, { encoding: "utf16le" }),
|
||||
'The value "utf16le" is invalid for option "encoding"',
|
||||
);
|
||||
},
|
||||
);
|
|
@ -74,7 +74,7 @@ export function checkEncoding(encoding: Encodings | null): Encodings | null {
|
|||
if (!encoding) return null;
|
||||
|
||||
encoding = encoding.toLowerCase() as Encodings;
|
||||
if (["utf8", "hex", "base64"].includes(encoding)) return encoding;
|
||||
if (["utf8", "hex", "base64", "ascii"].includes(encoding)) return encoding;
|
||||
|
||||
if (encoding === "utf-8") {
|
||||
return "utf8";
|
||||
|
@ -85,7 +85,7 @@ export function checkEncoding(encoding: Encodings | null): Encodings | null {
|
|||
// node -e "require('fs').readFile('../world.txt', 'buffer', console.log)"
|
||||
}
|
||||
|
||||
const notImplementedEncodings = ["utf16le", "latin1", "ascii", "ucs2"];
|
||||
const notImplementedEncodings = ["utf16le", "latin1", "ucs2"];
|
||||
|
||||
if (notImplementedEncodings.includes(encoding as string)) {
|
||||
notImplemented(`"${encoding}" encoding`);
|
||||
|
|
Loading…
Reference in a new issue