mirror of
https://github.com/nodejs/node.git
synced 2025-05-20 12:34:23 +00:00

1. Signal aborted while writing file Refs: https://coverage.nodejs.org/coverage-0b6d3070a176d437/lib/internal/fs/promises.js.html#L278 2. Signal aborted on first tick Refs: https://coverage.nodejs.org/coverage-0b6d3070a176d437/lib/internal/fs/promises.js.html#L301 3. Validate file size is withing range for reading Refs: https://coverage.nodejs.org/coverage-0b6d3070a176d437/lib/internal/fs/promises.js.html#L312 4. Signal aborted right before buffer read Refs: https://coverage.nodejs.org/coverage-0b6d3070a176d437/lib/internal/fs/promises.js.html#L321 5. Use fallback buffer allocation when input not buffer Refs: https://coverage.nodejs.org/coverage-0b6d3070a176d437/lib/internal/fs/promises.js.html#L374 6. Specify symlink type Refs: https://coverage.nodejs.org/coverage-0b6d3070a176d437/lib/internal/fs/promises.js.html#L539 7. Set modification times with lutimes Refs: https://coverage.nodejs.org/coverage-0b6d3070a176d437/lib/internal/fs/promises.js.html#L635 8. Use fallback encoding when input is null Refs: https://coverage.nodejs.org/coverage-0b6d3070a176d437/lib/internal/fs/promises.js.html#L665 9. Use fallback flag when input is null Refs: https://coverage.nodejs.org/coverage-0b6d3070a176d437/lib/internal/fs/promises.js.html#L681 PR-URL: https://github.com/nodejs/node/pull/36813 Reviewed-By: Antoine du Hamel <duhamelantoine1995@gmail.com> Reviewed-By: Darshan Sen <raisinten@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com>
59 lines
1.6 KiB
JavaScript
59 lines
1.6 KiB
JavaScript
'use strict';
|
|
|
|
const common = require('../common');
|
|
const fs = require('fs');
|
|
const fsPromises = fs.promises;
|
|
const path = require('path');
|
|
const tmpdir = require('../common/tmpdir');
|
|
const assert = require('assert');
|
|
const tmpDir = tmpdir.path;
|
|
|
|
tmpdir.refresh();
|
|
|
|
const dest = path.resolve(tmpDir, 'tmp.txt');
|
|
const otherDest = path.resolve(tmpDir, 'tmp-2.txt');
|
|
const buffer = Buffer.from('abc'.repeat(1000));
|
|
const buffer2 = Buffer.from('xyz'.repeat(1000));
|
|
|
|
async function doWrite() {
|
|
await fsPromises.writeFile(dest, buffer);
|
|
const data = fs.readFileSync(dest);
|
|
assert.deepStrictEqual(data, buffer);
|
|
}
|
|
|
|
async function doWriteWithCancel() {
|
|
const controller = new AbortController();
|
|
const { signal } = controller;
|
|
process.nextTick(() => controller.abort());
|
|
assert.rejects(fsPromises.writeFile(otherDest, buffer, { signal }), {
|
|
name: 'AbortError'
|
|
});
|
|
}
|
|
|
|
async function doAppend() {
|
|
await fsPromises.appendFile(dest, buffer2, { flag: null });
|
|
const data = fs.readFileSync(dest);
|
|
const buf = Buffer.concat([buffer, buffer2]);
|
|
assert.deepStrictEqual(buf, data);
|
|
}
|
|
|
|
async function doRead() {
|
|
const data = await fsPromises.readFile(dest);
|
|
const buf = fs.readFileSync(dest);
|
|
assert.deepStrictEqual(buf, data);
|
|
}
|
|
|
|
async function doReadWithEncoding() {
|
|
const data = await fsPromises.readFile(dest, 'utf-8');
|
|
const syncData = fs.readFileSync(dest, 'utf-8');
|
|
assert.strictEqual(typeof data, 'string');
|
|
assert.deepStrictEqual(data, syncData);
|
|
}
|
|
|
|
doWrite()
|
|
.then(doWriteWithCancel)
|
|
.then(doAppend)
|
|
.then(doRead)
|
|
.then(doReadWithEncoding)
|
|
.then(common.mustCall());
|