blob: 8ef1b9d5eafef83e0d90e37ddf12e05505eb6eef [file] [log] [blame]
Bram Moolenaar453b5762017-01-08 17:59:14 +01001" test float functions
2
Bram Moolenaarb46fecd2019-06-15 17:58:09 +02003source check.vim
4CheckFeature float
Bram Moolenaar62aec932022-01-29 21:45:34 +00005import './vim9.vim' as v9
Bram Moolenaar453b5762017-01-08 17:59:14 +01006
7func Test_abs()
Bram Moolenaar62473612017-01-08 19:25:40 +01008 call assert_equal('1.23', string(abs(1.23)))
9 call assert_equal('1.23', string(abs(-1.23)))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +020010 eval -1.23->abs()->string()->assert_equal('1.23')
11
Bram Moolenaar62473612017-01-08 19:25:40 +010012 call assert_equal('0.0', string(abs(0.0)))
13 call assert_equal('0.0', string(abs(1.0/(1.0/0.0))))
14 call assert_equal('0.0', string(abs(-1.0/(1.0/0.0))))
15 call assert_equal('inf', string(abs(1.0/0.0)))
16 call assert_equal('inf', string(abs(-1.0/0.0)))
17 call assert_equal('nan', string(abs(0.0/0.0)))
Bram Moolenaar17aca702019-05-16 22:24:55 +020018 call assert_equal('12', string(abs('12abc')))
Bram Moolenaar87200412017-01-10 16:31:20 +010019 call assert_equal('12', string(abs('-12abc')))
20 call assert_fails("call abs([])", 'E745:')
21 call assert_fails("call abs({})", 'E728:')
22 call assert_fails("call abs(function('string'))", 'E703:')
Bram Moolenaar453b5762017-01-08 17:59:14 +010023endfunc
24
25func Test_sqrt()
Bram Moolenaar62473612017-01-08 19:25:40 +010026 call assert_equal('0.0', string(sqrt(0.0)))
27 call assert_equal('1.414214', string(sqrt(2.0)))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +020028 eval 2.0->sqrt()->string()->assert_equal('1.414214')
Bram Moolenaar62473612017-01-08 19:25:40 +010029 call assert_equal('inf', string(sqrt(1.0/0.0)))
30 call assert_equal('nan', string(sqrt(-1.0)))
31 call assert_equal('nan', string(sqrt(0.0/0.0)))
Bram Moolenaar87200412017-01-10 16:31:20 +010032 call assert_fails('call sqrt("")', 'E808:')
Bram Moolenaar453b5762017-01-08 17:59:14 +010033endfunc
34
35func Test_log()
Bram Moolenaar62473612017-01-08 19:25:40 +010036 call assert_equal('0.0', string(log(1.0)))
37 call assert_equal('-0.693147', string(log(0.5)))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +020038 eval 0.5->log()->string()->assert_equal('-0.693147')
Bram Moolenaar62473612017-01-08 19:25:40 +010039 call assert_equal('-inf', string(log(0.0)))
40 call assert_equal('nan', string(log(-1.0)))
41 call assert_equal('inf', string(log(1.0/0.0)))
42 call assert_equal('nan', string(log(0.0/0.0)))
Bram Moolenaar87200412017-01-10 16:31:20 +010043 call assert_fails('call log("")', 'E808:')
Bram Moolenaar453b5762017-01-08 17:59:14 +010044endfunc
45
46func Test_log10()
Bram Moolenaar62473612017-01-08 19:25:40 +010047 call assert_equal('0.0', string(log10(1.0)))
48 call assert_equal('2.0', string(log10(100.0)))
49 call assert_equal('2.079181', string(log10(120.0)))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +020050 eval 120.0->log10()->string()->assert_equal('2.079181')
Bram Moolenaar62473612017-01-08 19:25:40 +010051 call assert_equal('-inf', string(log10(0.0)))
52 call assert_equal('nan', string(log10(-1.0)))
53 call assert_equal('inf', string(log10(1.0/0.0)))
54 call assert_equal('nan', string(log10(0.0/0.0)))
Bram Moolenaar87200412017-01-10 16:31:20 +010055 call assert_fails('call log10("")', 'E808:')
Bram Moolenaar453b5762017-01-08 17:59:14 +010056endfunc
57
58func Test_exp()
Bram Moolenaar62473612017-01-08 19:25:40 +010059 call assert_equal('1.0', string(exp(0.0)))
60 call assert_equal('7.389056', string(exp(2.0)))
61 call assert_equal('0.367879', string(exp(-1.0)))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +020062 eval -1.0->exp()->string()->assert_equal('0.367879')
Bram Moolenaar62473612017-01-08 19:25:40 +010063 call assert_equal('inf', string(exp(1.0/0.0)))
64 call assert_equal('0.0', string(exp(-1.0/0.0)))
65 call assert_equal('nan', string(exp(0.0/0.0)))
Bram Moolenaar87200412017-01-10 16:31:20 +010066 call assert_fails('call exp("")', 'E808:')
Bram Moolenaar453b5762017-01-08 17:59:14 +010067endfunc
68
69func Test_sin()
Bram Moolenaar62473612017-01-08 19:25:40 +010070 call assert_equal('0.0', string(sin(0.0)))
71 call assert_equal('0.841471', string(sin(1.0)))
72 call assert_equal('-0.479426', string(sin(-0.5)))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +020073 eval -0.5->sin()->string()->assert_equal('-0.479426')
Bram Moolenaar62473612017-01-08 19:25:40 +010074 call assert_equal('nan', string(sin(0.0/0.0)))
75 call assert_equal('nan', string(sin(1.0/0.0)))
76 call assert_equal('0.0', string(sin(1.0/(1.0/0.0))))
77 call assert_equal('-0.0', string(sin(-1.0/(1.0/0.0))))
Bram Moolenaar87200412017-01-10 16:31:20 +010078 call assert_fails('call sin("")', 'E808:')
Bram Moolenaar453b5762017-01-08 17:59:14 +010079endfunc
80
81func Test_asin()
Bram Moolenaar62473612017-01-08 19:25:40 +010082 call assert_equal('0.0', string(asin(0.0)))
83 call assert_equal('1.570796', string(asin(1.0)))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +020084 eval 1.0->asin()->string()->assert_equal('1.570796')
85
Bram Moolenaar62473612017-01-08 19:25:40 +010086 call assert_equal('-0.523599', string(asin(-0.5)))
87 call assert_equal('nan', string(asin(1.1)))
88 call assert_equal('nan', string(asin(1.0/0.0)))
89 call assert_equal('nan', string(asin(0.0/0.0)))
Bram Moolenaar87200412017-01-10 16:31:20 +010090 call assert_fails('call asin("")', 'E808:')
Bram Moolenaar453b5762017-01-08 17:59:14 +010091endfunc
92
93func Test_sinh()
Bram Moolenaar62473612017-01-08 19:25:40 +010094 call assert_equal('0.0', string(sinh(0.0)))
95 call assert_equal('0.521095', string(sinh(0.5)))
96 call assert_equal('-1.026517', string(sinh(-0.9)))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +020097 eval -0.9->sinh()->string()->assert_equal('-1.026517')
Bram Moolenaar62473612017-01-08 19:25:40 +010098 call assert_equal('inf', string(sinh(1.0/0.0)))
99 call assert_equal('-inf', string(sinh(-1.0/0.0)))
100 call assert_equal('nan', string(sinh(0.0/0.0)))
Bram Moolenaar87200412017-01-10 16:31:20 +0100101 call assert_fails('call sinh("")', 'E808:')
Bram Moolenaar453b5762017-01-08 17:59:14 +0100102endfunc
103
104func Test_cos()
Bram Moolenaar62473612017-01-08 19:25:40 +0100105 call assert_equal('1.0', string(cos(0.0)))
106 call assert_equal('0.540302', string(cos(1.0)))
107 call assert_equal('0.877583', string(cos(-0.5)))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +0200108 eval -0.5->cos()->string()->assert_equal('0.877583')
Bram Moolenaar62473612017-01-08 19:25:40 +0100109 call assert_equal('nan', string(cos(0.0/0.0)))
110 call assert_equal('nan', string(cos(1.0/0.0)))
Bram Moolenaar87200412017-01-10 16:31:20 +0100111 call assert_fails('call cos("")', 'E808:')
Bram Moolenaar453b5762017-01-08 17:59:14 +0100112endfunc
113
114func Test_acos()
Bram Moolenaar62473612017-01-08 19:25:40 +0100115 call assert_equal('1.570796', string(acos(0.0)))
116 call assert_equal('0.0', string(acos(1.0)))
117 call assert_equal('3.141593', string(acos(-1.0)))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +0200118 eval -1.0->acos()->string()->assert_equal('3.141593')
Bram Moolenaar62473612017-01-08 19:25:40 +0100119 call assert_equal('2.094395', string(acos(-0.5)))
120 call assert_equal('nan', string(acos(1.1)))
121 call assert_equal('nan', string(acos(1.0/0.0)))
122 call assert_equal('nan', string(acos(0.0/0.0)))
Bram Moolenaar87200412017-01-10 16:31:20 +0100123 call assert_fails('call acos("")', 'E808:')
Bram Moolenaar453b5762017-01-08 17:59:14 +0100124endfunc
125
126func Test_cosh()
Bram Moolenaar62473612017-01-08 19:25:40 +0100127 call assert_equal('1.0', string(cosh(0.0)))
128 call assert_equal('1.127626', string(cosh(0.5)))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +0200129 eval 0.5->cosh()->string()->assert_equal('1.127626')
Bram Moolenaar62473612017-01-08 19:25:40 +0100130 call assert_equal('inf', string(cosh(1.0/0.0)))
131 call assert_equal('inf', string(cosh(-1.0/0.0)))
132 call assert_equal('nan', string(cosh(0.0/0.0)))
Bram Moolenaar87200412017-01-10 16:31:20 +0100133 call assert_fails('call cosh("")', 'E808:')
Bram Moolenaar453b5762017-01-08 17:59:14 +0100134endfunc
135
136func Test_tan()
Bram Moolenaar62473612017-01-08 19:25:40 +0100137 call assert_equal('0.0', string(tan(0.0)))
138 call assert_equal('0.546302', string(tan(0.5)))
139 call assert_equal('-0.546302', string(tan(-0.5)))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +0200140 eval -0.5->tan()->string()->assert_equal('-0.546302')
Bram Moolenaar62473612017-01-08 19:25:40 +0100141 call assert_equal('nan', string(tan(1.0/0.0)))
142 call assert_equal('nan', string(cos(0.0/0.0)))
143 call assert_equal('0.0', string(tan(1.0/(1.0/0.0))))
144 call assert_equal('-0.0', string(tan(-1.0/(1.0/0.0))))
Bram Moolenaar87200412017-01-10 16:31:20 +0100145 call assert_fails('call tan("")', 'E808:')
Bram Moolenaar453b5762017-01-08 17:59:14 +0100146endfunc
147
148func Test_atan()
Bram Moolenaar62473612017-01-08 19:25:40 +0100149 call assert_equal('0.0', string(atan(0.0)))
150 call assert_equal('0.463648', string(atan(0.5)))
151 call assert_equal('-0.785398', string(atan(-1.0)))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +0200152 eval -1.0->atan()->string()->assert_equal('-0.785398')
Bram Moolenaar62473612017-01-08 19:25:40 +0100153 call assert_equal('1.570796', string(atan(1.0/0.0)))
154 call assert_equal('-1.570796', string(atan(-1.0/0.0)))
155 call assert_equal('nan', string(atan(0.0/0.0)))
Bram Moolenaar87200412017-01-10 16:31:20 +0100156 call assert_fails('call atan("")', 'E808:')
Bram Moolenaar453b5762017-01-08 17:59:14 +0100157endfunc
158
159func Test_atan2()
Bram Moolenaar62473612017-01-08 19:25:40 +0100160 call assert_equal('-2.356194', string(atan2(-1, -1)))
161 call assert_equal('2.356194', string(atan2(1, -1)))
162 call assert_equal('0.0', string(atan2(1.0, 1.0/0.0)))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +0200163 eval 1.0->atan2(1.0/0.0)->string()->assert_equal('0.0')
Bram Moolenaar62473612017-01-08 19:25:40 +0100164 call assert_equal('1.570796', string(atan2(1.0/0.0, 1.0)))
165 call assert_equal('nan', string(atan2(0.0/0.0, 1.0)))
Bram Moolenaar87200412017-01-10 16:31:20 +0100166 call assert_fails('call atan2("", -1)', 'E808:')
167 call assert_fails('call atan2(-1, "")', 'E808:')
Bram Moolenaar453b5762017-01-08 17:59:14 +0100168endfunc
169
170func Test_tanh()
Bram Moolenaar62473612017-01-08 19:25:40 +0100171 call assert_equal('0.0', string(tanh(0.0)))
172 call assert_equal('0.462117', string(tanh(0.5)))
173 call assert_equal('-0.761594', string(tanh(-1.0)))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +0200174 eval -1.0->tanh()->string()->assert_equal('-0.761594')
Bram Moolenaar62473612017-01-08 19:25:40 +0100175 call assert_equal('1.0', string(tanh(1.0/0.0)))
176 call assert_equal('-1.0', string(tanh(-1.0/0.0)))
177 call assert_equal('nan', string(tanh(0.0/0.0)))
Bram Moolenaar87200412017-01-10 16:31:20 +0100178 call assert_fails('call tanh("")', 'E808:')
Bram Moolenaar453b5762017-01-08 17:59:14 +0100179endfunc
180
181func Test_fmod()
Bram Moolenaar62473612017-01-08 19:25:40 +0100182 call assert_equal('0.13', string(fmod(12.33, 1.22)))
183 call assert_equal('-0.13', string(fmod(-12.33, 1.22)))
184 call assert_equal('nan', string(fmod(1.0/0.0, 1.0)))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +0200185 eval (1.0/0.0)->fmod(1.0)->string()->assert_equal('nan')
Bram Moolenaar62473612017-01-08 19:25:40 +0100186 " On Windows we get "nan" instead of 1.0, accept both.
187 let res = string(fmod(1.0, 1.0/0.0))
188 if res != 'nan'
189 call assert_equal('1.0', res)
190 endif
191 call assert_equal('nan', string(fmod(1.0, 0.0)))
Bram Moolenaar87200412017-01-10 16:31:20 +0100192 call assert_fails("call fmod('', 1.22)", 'E808:')
193 call assert_fails("call fmod(12.33, '')", 'E808:')
Bram Moolenaar453b5762017-01-08 17:59:14 +0100194endfunc
195
196func Test_pow()
Bram Moolenaar62473612017-01-08 19:25:40 +0100197 call assert_equal('1.0', string(pow(0.0, 0.0)))
198 call assert_equal('8.0', string(pow(2.0, 3.0)))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +0200199 eval 2.0->pow(3.0)->string()->assert_equal('8.0')
Bram Moolenaar62473612017-01-08 19:25:40 +0100200 call assert_equal('nan', string(pow(2.0, 0.0/0.0)))
201 call assert_equal('nan', string(pow(0.0/0.0, 3.0)))
202 call assert_equal('nan', string(pow(0.0/0.0, 3.0)))
203 call assert_equal('inf', string(pow(2.0, 1.0/0.0)))
204 call assert_equal('inf', string(pow(1.0/0.0, 3.0)))
Bram Moolenaar87200412017-01-10 16:31:20 +0100205 call assert_fails("call pow('', 2.0)", 'E808:')
206 call assert_fails("call pow(2.0, '')", 'E808:')
Bram Moolenaar453b5762017-01-08 17:59:14 +0100207endfunc
208
209func Test_str2float()
Bram Moolenaar62473612017-01-08 19:25:40 +0100210 call assert_equal('1.0', string(str2float('1')))
Bram Moolenaar08243d22017-01-10 16:12:29 +0100211 call assert_equal('1.0', string(str2float(' 1 ')))
212 call assert_equal('1.0', string(str2float(' 1.0 ')))
Bram Moolenaar62473612017-01-08 19:25:40 +0100213 call assert_equal('1.23', string(str2float('1.23')))
214 call assert_equal('1.23', string(str2float('1.23abc')))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +0200215 eval '1.23abc'->str2float()->string()->assert_equal('1.23')
Bram Moolenaar62473612017-01-08 19:25:40 +0100216 call assert_equal('1.0e40', string(str2float('1e40')))
Bram Moolenaar87200412017-01-10 16:31:20 +0100217 call assert_equal('-1.23', string(str2float('-1.23')))
218 call assert_equal('1.23', string(str2float(' + 1.23 ')))
Bram Moolenaar08243d22017-01-10 16:12:29 +0100219
220 call assert_equal('1.0', string(str2float('+1')))
221 call assert_equal('1.0', string(str2float('+1')))
222 call assert_equal('1.0', string(str2float(' +1 ')))
223 call assert_equal('1.0', string(str2float(' + 1 ')))
224
225 call assert_equal('-1.0', string(str2float('-1')))
226 call assert_equal('-1.0', string(str2float('-1')))
227 call assert_equal('-1.0', string(str2float(' -1 ')))
228 call assert_equal('-1.0', string(str2float(' - 1 ')))
229
Bram Moolenaar87200412017-01-10 16:31:20 +0100230 call assert_equal('0.0', string(str2float('+0.0')))
231 call assert_equal('-0.0', string(str2float('-0.0')))
Bram Moolenaar62473612017-01-08 19:25:40 +0100232 call assert_equal('inf', string(str2float('1e1000')))
233 call assert_equal('inf', string(str2float('inf')))
234 call assert_equal('-inf', string(str2float('-inf')))
Bram Moolenaar87200412017-01-10 16:31:20 +0100235 call assert_equal('inf', string(str2float('+inf')))
Bram Moolenaar62473612017-01-08 19:25:40 +0100236 call assert_equal('inf', string(str2float('Inf')))
Bram Moolenaar87200412017-01-10 16:31:20 +0100237 call assert_equal('inf', string(str2float(' +inf ')))
Bram Moolenaar62473612017-01-08 19:25:40 +0100238 call assert_equal('nan', string(str2float('nan')))
239 call assert_equal('nan', string(str2float('NaN')))
Bram Moolenaar87200412017-01-10 16:31:20 +0100240 call assert_equal('nan', string(str2float(' nan ')))
241
Bram Moolenaar29500652021-08-08 15:43:34 +0200242 call assert_equal('123456.789', string(str2float("123'456.789", 1)))
243 call assert_equal('123456.789', string(str2float("12'34'56.789", 1)))
244 call assert_equal('123456.789', string(str2float("1'2'3'4'5'6.789", 1)))
245 call assert_equal('1.0', string(str2float("1''2.3", 1)))
246 call assert_equal('123456.7', string(str2float("123'456.7'89", 1)))
247
248 call assert_equal(1.2, str2float(1.2, 0))
Bram Moolenaar62aec932022-01-29 21:45:34 +0000249 call v9.CheckDefAndScriptFailure(['str2float(1.2)'], ['E1013: Argument 1: type mismatch, expected string but got float', 'E1174: String required for argument 1'])
Bram Moolenaar87200412017-01-10 16:31:20 +0100250 call assert_fails("call str2float([])", 'E730:')
251 call assert_fails("call str2float({})", 'E731:')
252 call assert_fails("call str2float(function('string'))", 'E729:')
Bram Moolenaar453b5762017-01-08 17:59:14 +0100253endfunc
254
Bram Moolenaar29500652021-08-08 15:43:34 +0200255def Test_float_quotes()
256 call assert_equal('123456.789', string(123'456.789))
257 call assert_equal('123456.789', string(12'34'56.789))
258 call assert_equal('123456.789', string(1'2'3'4'5'6.789))
259
260 call assert_fails("echo string(1''2.3)", 'E116:')
261 call assert_fails("echo string(123'456.7'89)", 'E116:')
262enddef
263
Bram Moolenaared8b0992021-08-08 19:56:28 +0200264func Test_float_quotes_from_legacy()
265 call assert_equal("\n123456.789", execute("vim9 echo 12'34'56.789"))
266endfunc
267
Bram Moolenaar863e80b2017-06-04 20:30:00 +0200268func Test_float2nr()
269 call assert_equal(1, float2nr(1.234))
270 call assert_equal(123, float2nr(1.234e2))
271 call assert_equal(12, float2nr(123.4e-1))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +0200272 eval 123.4e-1->float2nr()->assert_equal(12)
Bram Moolenaar863e80b2017-06-04 20:30:00 +0200273 let max_number = 1/0
274 let min_number = -max_number
275 call assert_equal(max_number/2+1, float2nr(pow(2, 62)))
276 call assert_equal(max_number, float2nr(pow(2, 63)))
277 call assert_equal(max_number, float2nr(pow(2, 64)))
278 call assert_equal(min_number/2-1, float2nr(-pow(2, 62)))
279 call assert_equal(min_number, float2nr(-pow(2, 63)))
280 call assert_equal(min_number, float2nr(-pow(2, 64)))
281endfunc
282
Bram Moolenaar453b5762017-01-08 17:59:14 +0100283func Test_floor()
Bram Moolenaar62473612017-01-08 19:25:40 +0100284 call assert_equal('2.0', string(floor(2.0)))
285 call assert_equal('2.0', string(floor(2.11)))
286 call assert_equal('2.0', string(floor(2.99)))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +0200287 eval 2.99->floor()->string()->assert_equal('2.0')
Bram Moolenaar62473612017-01-08 19:25:40 +0100288 call assert_equal('-3.0', string(floor(-2.11)))
289 call assert_equal('-3.0', string(floor(-2.99)))
290 call assert_equal('nan', string(floor(0.0/0.0)))
291 call assert_equal('inf', string(floor(1.0/0.0)))
292 call assert_equal('-inf', string(floor(-1.0/0.0)))
Bram Moolenaar87200412017-01-10 16:31:20 +0100293 call assert_fails("call floor('')", 'E808:')
Bram Moolenaar453b5762017-01-08 17:59:14 +0100294endfunc
295
296func Test_ceil()
Bram Moolenaar62473612017-01-08 19:25:40 +0100297 call assert_equal('2.0', string(ceil(2.0)))
298 call assert_equal('3.0', string(ceil(2.11)))
299 call assert_equal('3.0', string(ceil(2.99)))
300 call assert_equal('-2.0', string(ceil(-2.11)))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +0200301 eval -2.11->ceil()->string()->assert_equal('-2.0')
Bram Moolenaar62473612017-01-08 19:25:40 +0100302 call assert_equal('-2.0', string(ceil(-2.99)))
303 call assert_equal('nan', string(ceil(0.0/0.0)))
304 call assert_equal('inf', string(ceil(1.0/0.0)))
305 call assert_equal('-inf', string(ceil(-1.0/0.0)))
Bram Moolenaar87200412017-01-10 16:31:20 +0100306 call assert_fails("call ceil('')", 'E808:')
Bram Moolenaar453b5762017-01-08 17:59:14 +0100307endfunc
308
309func Test_round()
Bram Moolenaar62473612017-01-08 19:25:40 +0100310 call assert_equal('2.0', string(round(2.1)))
311 call assert_equal('3.0', string(round(2.5)))
312 call assert_equal('3.0', string(round(2.9)))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +0200313 eval 2.9->round()->string()->assert_equal('3.0')
Bram Moolenaar62473612017-01-08 19:25:40 +0100314 call assert_equal('-2.0', string(round(-2.1)))
315 call assert_equal('-3.0', string(round(-2.5)))
316 call assert_equal('-3.0', string(round(-2.9)))
317 call assert_equal('nan', string(round(0.0/0.0)))
318 call assert_equal('inf', string(round(1.0/0.0)))
319 call assert_equal('-inf', string(round(-1.0/0.0)))
Bram Moolenaar87200412017-01-10 16:31:20 +0100320 call assert_fails("call round('')", 'E808:')
Bram Moolenaar453b5762017-01-08 17:59:14 +0100321endfunc
322
323func Test_trunc()
Bram Moolenaar62473612017-01-08 19:25:40 +0100324 call assert_equal('2.0', string(trunc(2.1)))
325 call assert_equal('2.0', string(trunc(2.5)))
326 call assert_equal('2.0', string(trunc(2.9)))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +0200327 eval 2.9->trunc()->string()->assert_equal('2.0')
Bram Moolenaar62473612017-01-08 19:25:40 +0100328 call assert_equal('-2.0', string(trunc(-2.1)))
329 call assert_equal('-2.0', string(trunc(-2.5)))
330 call assert_equal('-2.0', string(trunc(-2.9)))
331 call assert_equal('nan', string(trunc(0.0/0.0)))
332 call assert_equal('inf', string(trunc(1.0/0.0)))
333 call assert_equal('-inf', string(trunc(-1.0/0.0)))
Bram Moolenaar87200412017-01-10 16:31:20 +0100334 call assert_fails("call trunc('')", 'E808:')
Bram Moolenaar453b5762017-01-08 17:59:14 +0100335endfunc
336
Bram Moolenaarfda1bff2019-04-04 13:44:37 +0200337func Test_isinf()
338 call assert_equal(1, isinf(1.0/0.0))
339 call assert_equal(-1, isinf(-1.0/0.0))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +0200340 eval (-1.0/0.0)->isinf()->assert_equal(-1)
Bram Moolenaarfda1bff2019-04-04 13:44:37 +0200341 call assert_false(isinf(1.0))
342 call assert_false(isinf(0.0/0.0))
343 call assert_false(isinf('a'))
344 call assert_false(isinf([]))
345 call assert_false(isinf({}))
346endfunc
347
Bram Moolenaar453b5762017-01-08 17:59:14 +0100348func Test_isnan()
Bram Moolenaarfda1bff2019-04-04 13:44:37 +0200349 call assert_true(isnan(0.0/0.0))
350 call assert_false(isnan(1.0))
351 call assert_false(isnan(1.0/0.0))
Bram Moolenaar93cf85f2019-08-17 21:36:28 +0200352 eval (1.0/0.0)->isnan()->assert_false()
Bram Moolenaarfda1bff2019-04-04 13:44:37 +0200353 call assert_false(isnan(-1.0/0.0))
354 call assert_false(isnan('a'))
355 call assert_false(isnan([]))
356 call assert_false(isnan({}))
Bram Moolenaar453b5762017-01-08 17:59:14 +0100357endfunc
Bram Moolenaar863e80b2017-06-04 20:30:00 +0200358
359" This was converted from test65
360func Test_float_misc()
361 call assert_equal('123.456000', printf('%f', 123.456))
362 call assert_equal('1.234560e+02', printf('%e', 123.456))
363 call assert_equal('123.456', printf('%g', 123.456))
364 " +=
365 let v = 1.234
366 let v += 6.543
367 call assert_equal('7.777', printf('%g', v))
368 let v = 1.234
369 let v += 5
370 call assert_equal('6.234', printf('%g', v))
371 let v = 5
372 let v += 3.333
373 call assert_equal('8.333', string(v))
374 " ==
375 let v = 1.234
376 call assert_true(v == 1.234)
377 call assert_false(v == 1.2341)
378 " add-subtract
379 call assert_equal('5.234', printf('%g', 4 + 1.234))
380 call assert_equal('-6.766', printf('%g', 1.234 - 8))
381 " mult-div
382 call assert_equal('4.936', printf('%g', 4 * 1.234))
383 call assert_equal('0.003241', printf('%g', 4.0 / 1234))
384 " dict
385 call assert_equal("{'x': 1.234, 'y': -2.0e20}", string({'x': 1.234, 'y': -2.0e20}))
386 " list
387 call assert_equal('[-123.4, 2.0e-20]', string([-123.4, 2.0e-20]))
388endfunc
389
390" vim: shiftwidth=2 sts=2 expandtab