From 6d007ad92337a8c2e290037280f41a421f349d43 Mon Sep 17 00:00:00 2001
From: jsteuer <jan.steuer.htw@gmail.com>
Date: Wed, 18 Dec 2019 12:57:47 +0100
Subject: [PATCH] docs, runtime type checks for createStorageBasedApi
---
test/Helpers.spec.ts | 33 ++++++++++++++++++++++++---------
1 files changed, 24 insertions(+), 9 deletions(-)
diff --git a/test/Helpers.spec.ts b/test/Helpers.spec.ts
index 01102be..46872b4 100644
--- a/test/Helpers.spec.ts
+++ b/test/Helpers.spec.ts
@@ -1,4 +1,4 @@
-import test from "ava";
+import test, { ExecutionContext } from "ava";
import { Helpers } from "../src/Helpers";
@@ -56,12 +56,12 @@
})
-test("Helpers.createLocalStorageBasedApi() MC.isReady", async t => {
+test("Helpers.createStorageBasedApi() MC.isReady", async t => {
const MC = Helpers.createStorageBasedApi();
t.true(await MC.isReady());
})
-test("Helpers.createLocalStorageBasedApi() MC.ide.getContextFile", async t => {
+test("Helpers.createStorageBasedApi() MC.ide.getContextFile", async t => {
const MC = Helpers.createStorageBasedApi();
const contextFile = await MC.ide.getContextFile()
t.true(Helpers.isFile(contextFile));
@@ -70,13 +70,22 @@
t.is(contextFile.path, "/file.dummy.json");
})
-test("Helpers.createLocalStorageBasedApi() MC.ide.getUserName", async t => {
+test("Helpers.createStorageBasedApi() MC.ide.getUserName", async t => {
const MC = Helpers.createStorageBasedApi();
t.is(await MC.ide.getUserName(), "jdoe");
})
-test("Helpers.createLocalStorageBasedApi() MC.ide.fs readFile+writeFile", async t => {
- const MC = Helpers.createStorageBasedApi();
+async function expectThrows(t: ExecutionContext, callback: () => Promise<any>) {
+ try {
+ await callback();
+ t.fail()
+ } catch (error) {
+ t.pass()
+ }
+}
+
+test("Helpers.createStorageBasedApi() MC.ide.fs readFile+writeFile", async t => {
+ const MC = Helpers.createStorageBasedApi(); // expect InMemory Storage
const contextFile = await MC.ide.getContextFile();
const exerciseFile = Helpers.contextFileToExerciseFile(contextFile);
@@ -88,11 +97,13 @@
t.is(await MC.ide.fs.readFile(contextFile), "123");
t.is(await MC.ide.fs.readFile(exerciseFile), "456");
+
+ expectThrows(t, () => MC.ide.fs.writeFile({} as any, ""));
+ expectThrows(t, () => MC.ide.fs.writeFile(exerciseFile, 42 as any));
+ expectThrows(t, () => MC.ide.fs.writeFile(null as any, null as any));
})
-
-
-test("Helpers.createLocalStorageBasedApi() MC.ide.navigator", async t => {
+test("Helpers.createStorageBasedApi() MC.ide.navigator", async t => {
const MC = Helpers.createStorageBasedApi();
const contextFile = await MC.ide.getContextFile();
const exerciseFile = Helpers.contextFileToExerciseFile(contextFile);
@@ -100,5 +111,9 @@
MC.ide.navigator.navigateTo("www.google.de", true);
MC.ide.navigator.navigateToExercise(exerciseFile, true);
+ expectThrows(t, () => MC.ide.navigator.navigateTo(null as any));
+ expectThrows(t, () => MC.ide.navigator.navigateTo(42 as any));
+ expectThrows(t, () => MC.ide.navigator.navigateTo("www.google.de", 42 as any));
+
t.pass();
})
\ No newline at end of file
--
Gitblit v1.10.0