summaryrefslogtreecommitdiff
path: root/test/parallel/test-fs-promises-file-handle-write.js
diff options
context:
space:
mode:
authorwillhayslett <william.hayslettjr@gmail.com>2018-03-25 21:56:06 -0500
committerRich Trott <rtrott@gmail.com>2018-04-04 19:05:29 -0700
commit126b03e2f9e5a695b025a1a70eb49b88de43d080 (patch)
tree6ec5dd3826a38da12d0151765f5f7d10b85d7bf6 /test/parallel/test-fs-promises-file-handle-write.js
parent0876a0314d15129e8b29cb6e9753b886086cbfe2 (diff)
downloadandroid-node-v8-126b03e2f9e5a695b025a1a70eb49b88de43d080.tar.gz
android-node-v8-126b03e2f9e5a695b025a1a70eb49b88de43d080.tar.bz2
android-node-v8-126b03e2f9e5a695b025a1a70eb49b88de43d080.zip
test: add tests for fs/promises.js fileHandle methods
Working to increase test code coverage for fs/promises.js. Added tests for fileHandle.appendFile and fileHandle.chmod. PR-URL: https://github.com/nodejs/node/pull/19605 Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Rich Trott <rtrott@gmail.com>
Diffstat (limited to 'test/parallel/test-fs-promises-file-handle-write.js')
-rw-r--r--test/parallel/test-fs-promises-file-handle-write.js40
1 files changed, 40 insertions, 0 deletions
diff --git a/test/parallel/test-fs-promises-file-handle-write.js b/test/parallel/test-fs-promises-file-handle-write.js
new file mode 100644
index 0000000000..842095a214
--- /dev/null
+++ b/test/parallel/test-fs-promises-file-handle-write.js
@@ -0,0 +1,40 @@
+'use strict';
+
+const common = require('../common');
+
+// The following tests validate base functionality for the fs/promises
+// FileHandle.read method.
+
+const fs = require('fs');
+const { open } = require('fs/promises');
+const path = require('path');
+const tmpdir = require('../common/tmpdir');
+const assert = require('assert');
+const tmpDir = tmpdir.path;
+
+tmpdir.refresh();
+common.crashOnUnhandledRejection();
+
+async function validateWrite() {
+ const filePathForHandle = path.resolve(tmpDir, 'tmp-write.txt');
+ const fileHandle = await open(filePathForHandle, 'w+');
+ const buffer = Buffer.from('Hello world'.repeat(100), 'utf8');
+
+ await fileHandle.write(buffer, 0, buffer.length);
+ const readFileData = fs.readFileSync(filePathForHandle);
+ assert.deepStrictEqual(buffer, readFileData);
+}
+
+async function validateEmptyWrite() {
+ const filePathForHandle = path.resolve(tmpDir, 'tmp-empty-write.txt');
+ const fileHandle = await open(filePathForHandle, 'w+');
+ const buffer = Buffer.from(''); // empty buffer
+
+ await fileHandle.write(buffer, 0, buffer.length);
+ const readFileData = fs.readFileSync(filePathForHandle);
+ assert.deepStrictEqual(buffer, readFileData);
+}
+
+validateWrite()
+ .then(validateEmptyWrite)
+ .then(common.mustCall());