Index: third_party/JSON/JSON-2.59/t/03_types.t |
diff --git a/third_party/JSON/JSON-2.59/t/03_types.t b/third_party/JSON/JSON-2.59/t/03_types.t |
new file mode 100644 |
index 0000000000000000000000000000000000000000..f22c09bcca553d8b2f85fd318defe5ad61509177 |
--- /dev/null |
+++ b/third_party/JSON/JSON-2.59/t/03_types.t |
@@ -0,0 +1,60 @@ |
+# copied over from JSON::XS and modified to use JSON |
+use strict; |
+use Test::More; |
+ |
+BEGIN { plan tests => 76 }; |
+ |
+BEGIN { $ENV{PERL_JSON_BACKEND} = "JSON::backportPP"; } |
+ |
+use JSON; |
+ |
+ |
+ok (!defined JSON->new->allow_nonref (1)->decode ('null')); |
+ok (JSON->new->allow_nonref (1)->decode ('true') == 1); |
+ok (JSON->new->allow_nonref (1)->decode ('false') == 0); |
+ |
+my $true = JSON->new->allow_nonref (1)->decode ('true'); |
+ok ($true eq 1); |
+ok (JSON::is_bool $true); |
+my $false = JSON->new->allow_nonref (1)->decode ('false'); |
+ok ($false == !$true); |
+ok (JSON::is_bool $false); |
+ok (++$false == 1); |
+ok (!JSON::is_bool $false); |
+ |
+ok (JSON->new->allow_nonref (1)->decode ('5') == 5); |
+ok (JSON->new->allow_nonref (1)->decode ('-5') == -5); |
+ok (JSON->new->allow_nonref (1)->decode ('5e1') == 50); |
+ok (JSON->new->allow_nonref (1)->decode ('-333e+0') == -333); |
+ok (JSON->new->allow_nonref (1)->decode ('2.5') == 2.5); |
+ |
+ok (JSON->new->allow_nonref (1)->decode ('""') eq ""); |
+ok ('[1,2,3,4]' eq encode_json decode_json ('[1,2, 3,4]')); |
+ok ('[{},[],[],{}]' eq encode_json decode_json ('[{},[], [ ] ,{ }]')); |
+ok ('[{"1":[5]}]' eq encode_json [{1 => [5]}]); |
+ok ('{"1":2,"3":4}' eq JSON->new->canonical (1)->encode (decode_json '{ "1" : 2, "3" : 4 }')); |
+ok ('{"1":2,"3":1.2}' eq JSON->new->canonical (1)->encode (decode_json '{ "1" : 2, "3" : 1.2 }')); |
+ |
+ok ('[true]' eq encode_json [JSON::true]); |
+ok ('[false]' eq encode_json [JSON::false]); |
+ok ('[true]' eq encode_json [\1]); |
+ok ('[false]' eq encode_json [\0]); |
+ok ('[null]' eq encode_json [undef]); |
+ok ('[true]' eq encode_json [JSON::true]); |
+ok ('[false]' eq encode_json [JSON::false]); |
+ |
+for my $v (1, 2, 3, 5, -1, -2, -3, -4, 100, 1000, 10000, -999, -88, -7, 7, 88, 999, -1e5, 1e6, 1e7, 1e8) { |
+ ok ($v == ((decode_json "[$v]")->[0])); |
+ ok ($v == ((decode_json encode_json [$v])->[0])); |
+} |
+ |
+ok (30123 == ((decode_json encode_json [30123])->[0])); |
+ok (32123 == ((decode_json encode_json [32123])->[0])); |
+ok (32456 == ((decode_json encode_json [32456])->[0])); |
+ok (32789 == ((decode_json encode_json [32789])->[0])); |
+ok (32767 == ((decode_json encode_json [32767])->[0])); |
+ok (32768 == ((decode_json encode_json [32768])->[0])); |
+ |
+my @sparse; @sparse[0,3] = (1, 4); |
+ok ("[1,null,null,4]" eq encode_json \@sparse); |
+ |