ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/JSON-XS/t/02_error.t
(Generate patch)

Comparing JSON-XS/t/02_error.t (file contents):
Revision 1.5 by root, Tue Apr 3 23:34:17 2007 UTC vs.
Revision 1.8 by root, Thu Nov 15 20:49:12 2018 UTC

1BEGIN { $| = 1; print "1..31\n"; } 1BEGIN { $| = 1; print "1..35\n"; }
2 2
3use utf8; 3use utf8;
4use JSON::XS; 4use JSON::XS;
5no warnings;
5 6
6our $test; 7our $test;
7sub ok($) { 8sub ok($) {
8 print $_[0] ? "" : "not ", "ok ", ++$test, "\n"; 9 print $_[0] ? "" : "not ", "ok ", ++$test, "\n";
9} 10}
17 18
18eval { JSON::XS->new->allow_nonref (1)->decode ('"\u1234\udc00"') }; ok $@ =~ /missing high /; 19eval { JSON::XS->new->allow_nonref (1)->decode ('"\u1234\udc00"') }; ok $@ =~ /missing high /;
19eval { JSON::XS->new->allow_nonref->decode ('"\ud800"') }; ok $@ =~ /missing low /; 20eval { JSON::XS->new->allow_nonref->decode ('"\ud800"') }; ok $@ =~ /missing low /;
20eval { JSON::XS->new->allow_nonref (1)->decode ('"\ud800\u1234"') }; ok $@ =~ /surrogate pair /; 21eval { JSON::XS->new->allow_nonref (1)->decode ('"\ud800\u1234"') }; ok $@ =~ /surrogate pair /;
21 22
22eval { JSON::XS->new->decode ('null') }; ok $@ =~ /allow_nonref/; 23eval { JSON::XS->new->allow_nonref (0)->decode ('null') }; ok $@ =~ /allow_nonref/;
23eval { JSON::XS->new->allow_nonref (1)->decode ('+0') }; ok $@ =~ /malformed/; 24eval { JSON::XS->new->allow_nonref (1)->decode ('+0') }; ok $@ =~ /malformed/;
24eval { JSON::XS->new->allow_nonref->decode ('.2') }; ok $@ =~ /malformed/; 25eval { JSON::XS->new->allow_nonref->decode ('.2') }; ok $@ =~ /malformed/;
25eval { JSON::XS->new->allow_nonref (1)->decode ('bare') }; ok $@ =~ /malformed/; 26eval { JSON::XS->new->allow_nonref (1)->decode ('bare') }; ok $@ =~ /malformed/;
26eval { JSON::XS->new->allow_nonref->decode ('naughty') }; ok $@ =~ /null/; 27eval { JSON::XS->new->allow_nonref->decode ('naughty') }; ok $@ =~ /null/;
27eval { JSON::XS->new->allow_nonref (1)->decode ('01') }; ok $@ =~ /leading zero/; 28eval { JSON::XS->new->allow_nonref (1)->decode ('01') }; ok $@ =~ /leading zero/;
39eval { JSON::XS->new->decode (\5) }; ok !!$@; # Can't coerce readonly 40eval { JSON::XS->new->decode (\5) }; ok !!$@; # Can't coerce readonly
40eval { JSON::XS->new->decode ([]) }; ok $@ =~ /malformed/; 41eval { JSON::XS->new->decode ([]) }; ok $@ =~ /malformed/;
41eval { JSON::XS->new->decode (\*STDERR) }; ok $@ =~ /malformed/; 42eval { JSON::XS->new->decode (\*STDERR) }; ok $@ =~ /malformed/;
42eval { JSON::XS->new->decode (*STDERR) }; ok !!$@; # cannot coerce GLOB 43eval { JSON::XS->new->decode (*STDERR) }; ok !!$@; # cannot coerce GLOB
43 44
44eval { from_json ("\"\xa0") }; ok $@ =~ /malformed.*character/; 45eval { decode_json ("\"\xa0") }; ok $@ =~ /malformed.*character/;
45eval { from_json ("\"\xa0\"") }; ok $@ =~ /malformed.*character/; 46eval { decode_json ("\"\xa0\"") }; ok $@ =~ /malformed.*character/;
47eval { decode_json ("1\x01") }; ok $@ =~ /garbage after/;
48eval { decode_json ("1\x00") }; ok $@ =~ /garbage after/;
49eval { decode_json ("\"\"\x00") }; ok $@ =~ /garbage after/;
50eval { decode_json ("[]\x00") }; ok $@ =~ /garbage after/;
46 51

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines