File: inf-and-nan.t

package info (click to toggle)
libtoml-tiny-perl 0.20-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,792 kB
  • sloc: perl: 1,173; makefile: 10
file content (159 lines) | stat: -rw-r--r-- 8,070 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
# File automatically generated from BurntSushi/toml-test
use utf8;
use Test2::V0;
use Data::Dumper;
use Math::BigInt;
use Math::BigFloat;
use TOML::Tiny;

local $Data::Dumper::Sortkeys = 1;
local $Data::Dumper::Useqq    = 1;

binmode STDIN,  ':encoding(UTF-8)';
binmode STDOUT, ':encoding(UTF-8)';

open my $fh, '<', "./t/toml-test/valid/float/inf-and-nan.toml" or die $!;
binmode $fh, ':encoding(UTF-8)';
my $toml = do{ local $/; <$fh>; };
close $fh;

my $expected1 = {
               "infinity" => bless( {
                                      "_file" => "(eval 181)",
                                      "_lines" => [
                                                    6
                                                  ],
                                      "code" => sub {
                                                    BEGIN {${^WARNING_BITS} = "\x55\x55\x55\x55\x55\x55\x55\x55\x55\x55\x55\x55\x15\x00\x04\x40\x05\x04\x50"}
                                                    use strict;
                                                    no feature ':all';
                                                    use feature ':5.16';
                                                    require Math::BigFloat;
                                                    'Math::BigFloat'->new($_)->is_inf;
                                                },
                                      "name" => "Math::BigFloat->new(\$_)->is_inf",
                                      "operator" => "CODE(...)"
                                    }, 'Test2::Compare::Custom' ),
               "infinity_neg" => bless( {
                                          "_file" => "(eval 180)",
                                          "_lines" => [
                                                        6
                                                      ],
                                          "code" => sub {
                                                        BEGIN {${^WARNING_BITS} = "\x55\x55\x55\x55\x55\x55\x55\x55\x55\x55\x55\x55\x15\x00\x04\x40\x05\x04\x50"}
                                                        use strict;
                                                        no feature ':all';
                                                        use feature ':5.16';
                                                        require Math::BigFloat;
                                                        'Math::BigFloat'->new($_)->is_inf;
                                                    },
                                          "name" => "Math::BigFloat->new(\$_)->is_inf",
                                          "operator" => "CODE(...)"
                                        }, 'Test2::Compare::Custom' ),
               "infinity_plus" => bless( {
                                           "_file" => "(eval 184)",
                                           "_lines" => [
                                                         7
                                                       ],
                                           "code" => sub {
                                                         BEGIN {${^WARNING_BITS} = "\x55\x55\x55\x55\x55\x55\x55\x55\x55\x55\x55\x55\x15\x00\x04\x40\x05\x04\x50"}
                                                         use strict;
                                                         no feature ':all';
                                                         use feature ':5.16';
                                                         require Math::BigFloat;
                                                         my $got = 'Math::BigFloat'->new($_);
                                                         'Math::BigFloat'->new('+inf')->beq($got);
                                                     },
                                           "name" => "Math::BigFloat->new(\"+inf\")->beq(\$_)",
                                           "operator" => "CODE(...)"
                                         }, 'Test2::Compare::Custom' ),
               "nan" => bless( {
                                 "_file" => "(eval 183)",
                                 "_lines" => [
                                               6
                                             ],
                                 "code" => sub {
                                               BEGIN {${^WARNING_BITS} = "\x55\x55\x55\x55\x55\x55\x55\x55\x55\x55\x55\x55\x15\x00\x04\x40\x05\x04\x50"}
                                               use strict;
                                               no feature ':all';
                                               use feature ':5.16';
                                               require Math::BigFloat;
                                               'Math::BigFloat'->new($_)->is_nan;
                                           },
                                 "name" => "Math::BigFloat->new(\$_)->is_nan",
                                 "operator" => "CODE(...)"
                               }, 'Test2::Compare::Custom' ),
               "nan_neg" => bless( {
                                     "_file" => "(eval 179)",
                                     "_lines" => [
                                                   6
                                                 ],
                                     "code" => sub {
                                                   BEGIN {${^WARNING_BITS} = "\x55\x55\x55\x55\x55\x55\x55\x55\x55\x55\x55\x55\x15\x00\x04\x40\x05\x04\x50"}
                                                   use strict;
                                                   no feature ':all';
                                                   use feature ':5.16';
                                                   require Math::BigFloat;
                                                   'Math::BigFloat'->new($_)->is_nan;
                                               },
                                     "name" => "Math::BigFloat->new(\$_)->is_nan",
                                     "operator" => "CODE(...)"
                                   }, 'Test2::Compare::Custom' ),
               "nan_plus" => bless( {
                                      "_file" => "(eval 182)",
                                      "_lines" => [
                                                    6
                                                  ],
                                      "code" => sub {
                                                    BEGIN {${^WARNING_BITS} = "\x55\x55\x55\x55\x55\x55\x55\x55\x55\x55\x55\x55\x15\x00\x04\x40\x05\x04\x50"}
                                                    use strict;
                                                    no feature ':all';
                                                    use feature ':5.16';
                                                    require Math::BigFloat;
                                                    'Math::BigFloat'->new($_)->is_nan;
                                                },
                                      "name" => "Math::BigFloat->new(\$_)->is_nan",
                                      "operator" => "CODE(...)"
                                    }, 'Test2::Compare::Custom' )
             };


my $actual = from_toml($toml);

is($actual, $expected1, 'float/inf-and-nan - from_toml') or do{
  diag 'TOML INPUT:';
  diag "$toml";

  diag '';
  diag 'EXPECTED:';
  diag Dumper($expected1);

  diag '';
  diag 'ACTUAL:';
  diag Dumper($actual);
};

my $regenerated = to_toml $actual;
my $reparsed    = eval{ scalar from_toml $regenerated };
my $error       = $@;

ok(!$error, 'float/inf-and-nan - to_toml - no errors')
  or diag $error;

is($reparsed, $expected1, 'float/inf-and-nan - to_toml') or do{
  diag "ERROR: $error" if $error;

  diag '';
  diag 'PARSED FROM TEST SOURCE TOML:';
  diag Dumper($actual);

  diag '';
  diag 'REGENERATED TOML:';
  diag $regenerated;

  diag '';
  diag 'REPARSED FROM REGENERATED TOML:';
  diag Dumper($reparsed);
};

done_testing;