summaryrefslogtreecommitdiff
path: root/std/node/_fs/_fs_stat_test.ts
diff options
context:
space:
mode:
authorali ahmed <48116123+AliBasicCoder@users.noreply.github.com>2020-10-06 07:35:22 +0200
committerGitHub <noreply@github.com>2020-10-06 01:35:22 -0400
commit40324ff74816a99ea061929ece1c6a4ff3078bc3 (patch)
tree1eb11554820f419f7db500272a0f6a2aef1b9532 /std/node/_fs/_fs_stat_test.ts
parenta51408a4bc1621d27241377ac1662944d8c14fc0 (diff)
feat(std/node/fs): adding readdir, rename, and some others (#7666)
Diffstat (limited to 'std/node/_fs/_fs_stat_test.ts')
-rw-r--r--std/node/_fs/_fs_stat_test.ts107
1 files changed, 107 insertions, 0 deletions
diff --git a/std/node/_fs/_fs_stat_test.ts b/std/node/_fs/_fs_stat_test.ts
new file mode 100644
index 000000000..7e352987a
--- /dev/null
+++ b/std/node/_fs/_fs_stat_test.ts
@@ -0,0 +1,107 @@
+import { BigIntStats, stat, Stats, statSync } from "./_fs_stat.ts";
+import { assertEquals, fail } from "../../testing/asserts.ts";
+
+export function assertStats(actual: Stats, expected: Deno.FileInfo) {
+ assertEquals(actual.dev, expected.dev);
+ assertEquals(actual.gid, expected.gid);
+ assertEquals(actual.size, expected.size);
+ assertEquals(actual.blksize, expected.blksize);
+ assertEquals(actual.blocks, expected.blocks);
+ assertEquals(actual.ino, expected.ino);
+ assertEquals(actual.gid, expected.gid);
+ assertEquals(actual.mode, expected.mode);
+ assertEquals(actual.nlink, expected.nlink);
+ assertEquals(actual.rdev, expected.rdev);
+ assertEquals(actual.uid, expected.uid);
+ assertEquals(actual.atime?.getTime(), expected.atime?.getTime());
+ assertEquals(actual.mtime?.getTime(), expected.mtime?.getTime());
+ assertEquals(actual.birthtime?.getTime(), expected.birthtime?.getTime());
+ assertEquals(actual.atimeMs, expected.atime?.getTime());
+ assertEquals(actual.mtimeMs, expected.mtime?.getTime());
+ assertEquals(actual.birthtimeMs, expected.birthtime?.getTime());
+ assertEquals(actual.isFile(), expected.isFile);
+ assertEquals(actual.isDirectory(), expected.isDirectory);
+ assertEquals(actual.isSymbolicLink(), expected.isSymlink);
+ // assertEquals(actual.ctimeMs === expected.ctime?.getTime());
+ // assertEquals(actual.ctime?.getTime() === expected.ctime?.getTime());
+}
+
+export function assertStatsBigInt(
+ actual: BigIntStats,
+ expected: Deno.FileInfo,
+) {
+ assertEquals(actual.dev, BigInt(expected.dev));
+ assertEquals(actual.gid, BigInt(expected.gid));
+ assertEquals(actual.size, BigInt(expected.size));
+ assertEquals(actual.blksize, BigInt(expected.blksize));
+ assertEquals(actual.blocks, BigInt(expected.blocks));
+ assertEquals(actual.ino, BigInt(expected.ino));
+ assertEquals(actual.gid, BigInt(expected.gid));
+ assertEquals(actual.mode, BigInt(expected.mode));
+ assertEquals(actual.nlink, BigInt(expected.nlink));
+ assertEquals(actual.rdev, BigInt(expected.rdev));
+ assertEquals(actual.uid, BigInt(expected.uid));
+ assertEquals(actual.atime?.getTime(), expected.atime?.getTime());
+ assertEquals(actual.mtime?.getTime(), expected.mtime?.getTime());
+ assertEquals(actual.birthtime?.getTime(), expected.birthtime?.getTime());
+ assertEquals(Number(actual.atimeMs), expected.atime?.getTime());
+ assertEquals(Number(actual.mtimeMs), expected.mtime?.getTime());
+ assertEquals(Number(actual.birthtimeMs), expected.birthtime?.getTime());
+ assertEquals(Number(actual.atimeNs) / 1e6, expected.atime?.getTime());
+ assertEquals(Number(actual.mtimeNs) / 1e6, expected.atime?.getTime());
+ assertEquals(Number(actual.birthtimeNs) / 1e6, expected.atime?.getTime());
+ assertEquals(actual.isFile(), expected.isFile);
+ assertEquals(actual.isDirectory(), expected.isDirectory);
+ assertEquals(actual.isSymbolicLink(), expected.isSymlink);
+ // assertEquals(actual.ctime?.getTime() === expected.ctime?.getTime());
+ // assertEquals(Number(actual.ctimeMs) === expected.ctime?.getTime());
+ // assertEquals(Number(actual.ctimeNs) / 1e+6 === expected.ctime?.getTime());
+}
+
+Deno.test({
+ name: "ASYNC: get a file Stats",
+ async fn() {
+ const file = Deno.makeTempFileSync();
+ await new Promise<Stats>((resolve, reject) => {
+ stat(file, (err, stat) => {
+ if (err) reject(err);
+ resolve(stat);
+ });
+ })
+ .then((stat) => assertStats(stat, Deno.statSync(file)))
+ .catch(() => fail())
+ .finally(() => Deno.removeSync(file));
+ },
+});
+
+Deno.test({
+ name: "SYNC: get a file Stats",
+ fn() {
+ const file = Deno.makeTempFileSync();
+ assertStats(statSync(file), Deno.statSync(file));
+ },
+});
+
+Deno.test({
+ name: "ASYNC: get a file BigInt Stats",
+ async fn() {
+ const file = Deno.makeTempFileSync();
+ await new Promise<BigIntStats>((resolve, reject) => {
+ stat(file, { bigint: true }, (err, stat) => {
+ if (err) reject(err);
+ resolve(stat);
+ });
+ })
+ .then((stat) => assertStatsBigInt(stat, Deno.statSync(file)))
+ .catch(() => fail())
+ .finally(() => Deno.removeSync(file));
+ },
+});
+
+Deno.test({
+ name: "SYNC: get a file BigInt Stats",
+ fn() {
+ const file = Deno.makeTempFileSync();
+ assertStatsBigInt(statSync(file, { bigint: true }), Deno.statSync(file));
+ },
+});