Commit 44652c66 authored by Kamal Marhubi's avatar Kamal Marhubi

Add some JSON parser failure tests

parent 08602884
...@@ -185,7 +185,6 @@ KJ_TEST("encode union") { ...@@ -185,7 +185,6 @@ KJ_TEST("encode union") {
KJ_TEST("basic json decoding") { KJ_TEST("basic json decoding") {
// TODO(cleanup): this test is a mess! // TODO(cleanup): this test is a mess!
// TODO(soon): add expected failing cases.
JsonCodec json; JsonCodec json;
{ {
MallocMessageBuilder message; MallocMessageBuilder message;
...@@ -196,15 +195,6 @@ KJ_TEST("basic json decoding") { ...@@ -196,15 +195,6 @@ KJ_TEST("basic json decoding") {
KJ_EXPECT(root.getNull() == VOID); KJ_EXPECT(root.getNull() == VOID);
} }
{
MallocMessageBuilder message;
auto root = message.initRoot<JsonValue>();
json.decodeRaw(kj::str("null"), root);
KJ_EXPECT(root.which() == JsonValue::NULL_);
KJ_EXPECT(root.getNull() == VOID);
}
{ {
MallocMessageBuilder message; MallocMessageBuilder message;
auto root = message.initRoot<JsonValue>(); auto root = message.initRoot<JsonValue>();
...@@ -412,6 +402,22 @@ KJ_TEST("basic json decoding") { ...@@ -412,6 +402,22 @@ KJ_TEST("basic json decoding") {
KJ_EXPECT(root.which() == JsonValue::NUMBER); KJ_EXPECT(root.which() == JsonValue::NUMBER);
KJ_EXPECT(root.getNumber() == -5.5); KJ_EXPECT(root.getNumber() == -5.5);
} }
{
MallocMessageBuilder message;
auto root = message.initRoot<JsonValue>();
KJ_EXPECT_THROW_MESSAGE("Unexpected input", json.decodeRaw("a", root));
KJ_EXPECT_THROW_MESSAGE("ends prematurely", json.decodeRaw("[", root));
KJ_EXPECT_THROW_MESSAGE("ends prematurely", json.decodeRaw("{", root));
KJ_EXPECT_THROW_MESSAGE("Unexpected input", json.decodeRaw("[}", root));
KJ_EXPECT_THROW_MESSAGE("Unexpected input", json.decodeRaw("{]", root));
KJ_EXPECT_THROW_MESSAGE("Unexpected input", json.decodeRaw("[}]", root));
KJ_EXPECT_THROW_MESSAGE("Unexpected input", json.decodeRaw("[1, , ]", root));
KJ_EXPECT_THROW_MESSAGE("Unexpected input", json.decodeRaw("[,]", root));
KJ_EXPECT_THROW_MESSAGE("Unexpected input", json.decodeRaw("[, 1]", root));
KJ_EXPECT_THROW_MESSAGE("Input remains", json.decodeRaw("11a", root));
}
} }
KJ_TEST("maximum nesting depth") { KJ_TEST("maximum nesting depth") {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment