summaryrefslogtreecommitdiff
path: root/fs
diff options
context:
space:
mode:
Diffstat (limited to 'fs')
-rw-r--r--fs/read_json.ts42
-rw-r--r--fs/read_json_test.ts91
-rw-r--r--fs/testdata/json_empty.json0
-rw-r--r--fs/testdata/json_invalid.json5
-rw-r--r--fs/testdata/json_valid_array.json5
-rw-r--r--fs/testdata/json_valid_obj.json4
6 files changed, 147 insertions, 0 deletions
diff --git a/fs/read_json.ts b/fs/read_json.ts
new file mode 100644
index 000000000..d5c639ae2
--- /dev/null
+++ b/fs/read_json.ts
@@ -0,0 +1,42 @@
+// Copyright 2018-2019 the Deno authors. All rights reserved. MIT license.
+import * as path from "./path/mod.ts";
+
+/**
+ * Reads a JSON file and then parses it into an object
+ * @export
+ * @param {string} filePath
+ * @returns {Promise<any>}
+ */
+export async function readJson(filePath: string): Promise<any> {
+ filePath = path.resolve(filePath);
+ const decoder = new TextDecoder("utf-8");
+
+ const content = decoder.decode(await Deno.readFile(filePath));
+
+ try {
+ return JSON.parse(content);
+ } catch (err) {
+ err.message = `${filePath}: ${err.message}`;
+ throw err;
+ }
+}
+
+/**
+ * Reads a JSON file and then parses it into an object
+ * @export
+ * @param {string} filePath
+ * @returns {void}
+ */
+export function readJsonSync(filePath: string): any {
+ filePath = path.resolve(filePath);
+ const decoder = new TextDecoder("utf-8");
+
+ const content = decoder.decode(Deno.readFileSync(filePath));
+
+ try {
+ return JSON.parse(content);
+ } catch (err) {
+ err.message = `${filePath}: ${err.message}`;
+ throw err;
+ }
+}
diff --git a/fs/read_json_test.ts b/fs/read_json_test.ts
new file mode 100644
index 000000000..46ce1ec08
--- /dev/null
+++ b/fs/read_json_test.ts
@@ -0,0 +1,91 @@
+// Copyright 2018-2019 the Deno authors. All rights reserved. MIT license.
+import { test } from "../testing/mod.ts";
+import {
+ assertEquals,
+ assertThrowsAsync,
+ assertThrows
+} from "../testing/asserts.ts";
+import { readJson, readJsonSync } from "./read_json.ts";
+import * as path from "./path/mod.ts";
+
+const testdataDir = path.resolve("fs", "testdata");
+
+test(async function readJsonFileNotExists() {
+ const emptyJsonFile = path.join(testdataDir, "json_not_exists.json");
+
+ await assertThrowsAsync(async () => {
+ await readJson(emptyJsonFile);
+ });
+});
+
+test(async function readEmptyJsonFile() {
+ const emptyJsonFile = path.join(testdataDir, "json_empty.json");
+
+ await assertThrowsAsync(async () => {
+ await readJson(emptyJsonFile);
+ });
+});
+
+test(async function readInvalidJsonFile() {
+ const invalidJsonFile = path.join(testdataDir, "json_invalid.json");
+
+ await assertThrowsAsync(async () => {
+ await readJson(invalidJsonFile);
+ });
+});
+
+test(async function readValidJsonFile() {
+ const invalidJsonFile = path.join(testdataDir, "json_valid_array.json");
+
+ const json = await readJson(invalidJsonFile);
+
+ assertEquals(json, ["1", "2", "3"]);
+});
+
+test(async function readValidJsonFile() {
+ const invalidJsonFile = path.join(testdataDir, "json_valid_obj.json");
+
+ const json = await readJson(invalidJsonFile);
+
+ assertEquals(json, { key1: "value1", key2: "value2" });
+});
+
+test(function readJsonFileNotExistsSync() {
+ const emptyJsonFile = path.join(testdataDir, "json_not_exists.json");
+
+ assertThrows(() => {
+ readJsonSync(emptyJsonFile);
+ });
+});
+
+test(function readEmptyJsonFileSync() {
+ const emptyJsonFile = path.join(testdataDir, "json_empty.json");
+
+ assertThrows(() => {
+ readJsonSync(emptyJsonFile);
+ });
+});
+
+test(function readInvalidJsonFile() {
+ const invalidJsonFile = path.join(testdataDir, "json_invalid.json");
+
+ assertThrows(() => {
+ readJsonSync(invalidJsonFile);
+ });
+});
+
+test(function readValidJsonFile() {
+ const invalidJsonFile = path.join(testdataDir, "json_valid_array.json");
+
+ const json = readJsonSync(invalidJsonFile);
+
+ assertEquals(json, ["1", "2", "3"]);
+});
+
+test(function readValidJsonFile() {
+ const invalidJsonFile = path.join(testdataDir, "json_valid_obj.json");
+
+ const json = readJsonSync(invalidJsonFile);
+
+ assertEquals(json, { key1: "value1", key2: "value2" });
+});
diff --git a/fs/testdata/json_empty.json b/fs/testdata/json_empty.json
new file mode 100644
index 000000000..e69de29bb
--- /dev/null
+++ b/fs/testdata/json_empty.json
diff --git a/fs/testdata/json_invalid.json b/fs/testdata/json_invalid.json
new file mode 100644
index 000000000..dd9f98ff0
--- /dev/null
+++ b/fs/testdata/json_invalid.json
@@ -0,0 +1,5 @@
+{
+ [
+ "here is a invalid json file"
+ ]
+} \ No newline at end of file
diff --git a/fs/testdata/json_valid_array.json b/fs/testdata/json_valid_array.json
new file mode 100644
index 000000000..904968e15
--- /dev/null
+++ b/fs/testdata/json_valid_array.json
@@ -0,0 +1,5 @@
+[
+ "1",
+ "2",
+ "3"
+] \ No newline at end of file
diff --git a/fs/testdata/json_valid_obj.json b/fs/testdata/json_valid_obj.json
new file mode 100644
index 000000000..88b3d7123
--- /dev/null
+++ b/fs/testdata/json_valid_obj.json
@@ -0,0 +1,4 @@
+{
+ "key1": "value1",
+ "key2": "value2"
+} \ No newline at end of file