zig

fork of https://codeberg.org/ziglang/zig
Log | Files | Refs | README | LICENSE

commit 6d3b95a708c87ed81bd4f270b956913d82a0972d (tree)
parent f9b7d6d75d24fa5844a6b83be312722d1a71efaf
Author: xackus <14938807+xackus@users.noreply.github.com>
Date:   Mon, 11 Nov 2019 23:41:53 +0100

Stricter tests for non-streaming parser

Diffstat:
Mlib/std/json/test.zig | 32++++++++++++++++++++++----------
1 file changed, 22 insertions(+), 10 deletions(-)

diff --git a/lib/std/json/test.zig b/lib/std/json/test.zig @@ -37,6 +37,18 @@ fn any(comptime s: []const u8) void { _ = p.parse(s) catch {}; } +fn anyStreamingErrNonStreaming(comptime s: []const u8) void { + _ = std.json.validate(s); + + var mem_buffer: [1024 * 20]u8 = undefined; + const allocator = &std.heap.FixedBufferAllocator.init(&mem_buffer).allocator; + var p = std.json.Parser.init(allocator, false); + + if(p.parse(s)) |_| { + unreachable; + } else |_| {} +} + //////////////////////////////////////////////////////////////////////////////////////////////////// // // Additional tests not part of test JSONTestSuite. @@ -1784,49 +1796,49 @@ test "i_number_very_big_negative_int" { } test "i_object_key_lone_2nd_surrogate" { - any( + anyStreamingErrNonStreaming( \\{"\uDFAA":0} ); } test "i_string_1st_surrogate_but_2nd_missing" { - any( + anyStreamingErrNonStreaming( \\["\uDADA"] ); } test "i_string_1st_valid_surrogate_2nd_invalid" { - any( + anyStreamingErrNonStreaming( \\["\uD888\u1234"] ); } test "i_string_incomplete_surrogate_and_escape_valid" { - any( + anyStreamingErrNonStreaming( \\["\uD800\n"] ); } test "i_string_incomplete_surrogate_pair" { - any( + anyStreamingErrNonStreaming( \\["\uDd1ea"] ); } test "i_string_incomplete_surrogates_escape_valid" { - any( + anyStreamingErrNonStreaming( \\["\uD800\uD800\n"] ); } test "i_string_invalid_lonely_surrogate" { - any( + anyStreamingErrNonStreaming( \\["\ud800"] ); } test "i_string_invalid_surrogate" { - any( + anyStreamingErrNonStreaming( \\["\ud800abc"] ); } @@ -1838,7 +1850,7 @@ test "i_string_invalid_utf-8" { } test "i_string_inverted_surrogates_U+1D11E" { - any( + anyStreamingErrNonStreaming( \\["\uDd1e\uD834"] ); } @@ -1850,7 +1862,7 @@ test "i_string_iso_latin_1" { } test "i_string_lone_second_surrogate" { - any( + anyStreamingErrNonStreaming( \\["\uDFAA"] ); }