- add sources.
[platform/framework/web/crosswalk.git] / src / third_party / JSON / JSON-2.59 / t / x02_error.t
1 use strict;
2 use Test::More;
3 BEGIN { plan tests => 31 };
4
5 BEGIN { $ENV{PERL_JSON_BACKEND} = 1; }
6
7 local $^W;
8
9 BEGIN {
10     use lib qw(t);
11     use _unicode_handling;
12 }
13
14 use utf8;
15 use JSON;
16
17 SKIP: {
18     skip "can't use JSON::XS.", 31, unless( JSON->backend->is_xs );
19
20 eval { JSON->new->encode ([\-1]) }; ok $@ =~ /cannot encode reference/;
21 eval { JSON->new->encode ([\undef]) }; ok $@ =~ /cannot encode reference/;
22 eval { JSON->new->encode ([\2]) }; ok $@ =~ /cannot encode reference/;
23 eval { JSON->new->encode ([\{}]) }; ok $@ =~ /cannot encode reference/;
24 eval { JSON->new->encode ([\[]]) }; ok $@ =~ /cannot encode reference/;
25 eval { JSON->new->encode ([\\1]) }; ok $@ =~ /cannot encode reference/;
26
27 eval { JSON->new->allow_nonref (1)->decode ('"\u1234\udc00"') }; ok $@ =~ /missing high /;
28 eval { JSON->new->allow_nonref->decode ('"\ud800"') }; ok $@ =~ /missing low /;
29 eval { JSON->new->allow_nonref (1)->decode ('"\ud800\u1234"') }; ok $@ =~ /surrogate pair /;
30
31 eval { JSON->new->decode ('null') }; ok $@ =~ /allow_nonref/;
32 eval { JSON->new->allow_nonref (1)->decode ('+0') }; ok $@ =~ /malformed/;
33 eval { JSON->new->allow_nonref->decode ('.2') }; ok $@ =~ /malformed/;
34 eval { JSON->new->allow_nonref (1)->decode ('bare') }; ok $@ =~ /malformed/;
35 eval { JSON->new->allow_nonref->decode ('naughty') }; ok $@ =~ /null/;
36 eval { JSON->new->allow_nonref (1)->decode ('01') }; ok $@ =~ /leading zero/;
37 eval { JSON->new->allow_nonref->decode ('00') }; ok $@ =~ /leading zero/;
38 eval { JSON->new->allow_nonref (1)->decode ('-0.') }; ok $@ =~ /decimal point/;
39 eval { JSON->new->allow_nonref->decode ('-0e') }; ok $@ =~ /exp sign/;
40 eval { JSON->new->allow_nonref (1)->decode ('-e+1') }; ok $@ =~ /initial minus/;
41 eval { JSON->new->allow_nonref->decode ("\"\n\"") }; ok $@ =~ /invalid character/;
42 eval { JSON->new->allow_nonref (1)->decode ("\"\x01\"") }; ok $@ =~ /invalid character/;
43 eval { JSON->new->decode ('[5') }; ok $@ =~ /parsing array/;
44 eval { JSON->new->decode ('{"5"') }; ok $@ =~ /':' expected/;
45 eval { JSON->new->decode ('{"5":null') }; ok $@ =~ /parsing object/;
46
47 eval { JSON->new->decode (undef) }; ok $@ =~ /malformed/;
48 eval { JSON->new->decode (\5) }; ok !!$@; # Can't coerce readonly
49 eval { JSON->new->decode ([]) }; ok $@ =~ /malformed/;
50 eval { JSON->new->decode (\*STDERR) }; ok $@ =~ /malformed/;
51 eval { JSON->new->decode (*STDERR) }; ok !!$@; # cannot coerce GLOB
52
53 # differences between JSON::XS and JSON::PP
54
55 eval { decode_json ("\"\xa0") }; ok $@ =~ /malformed.*character/;
56 eval { decode_json ("\"\xa0\"") }; ok $@ =~ /malformed.*character/;
57
58 #eval { decode_json ("\"\xa0") }; ok $@ =~ /JSON text must be an object or array/;
59 #eval { decode_json ("\"\xa0\"") }; ok $@ =~ /JSON text must be an object or array/;
60
61 }