1453b576eSBram Moolenaar" test float functions
2453b576eSBram Moolenaar
3b46fecd3SBram Moolenaarsource check.vim
4b46fecd3SBram MoolenaarCheckFeature float
53cfa5b16SBram Moolenaarsource vim9.vim
6453b576eSBram Moolenaar
7453b576eSBram Moolenaarfunc Test_abs()
862473611SBram Moolenaar  call assert_equal('1.23', string(abs(1.23)))
962473611SBram Moolenaar  call assert_equal('1.23', string(abs(-1.23)))
1093cf85f9SBram Moolenaar  eval -1.23->abs()->string()->assert_equal('1.23')
1193cf85f9SBram Moolenaar
1262473611SBram Moolenaar  call assert_equal('0.0', string(abs(0.0)))
1362473611SBram Moolenaar  call assert_equal('0.0', string(abs(1.0/(1.0/0.0))))
1462473611SBram Moolenaar  call assert_equal('0.0', string(abs(-1.0/(1.0/0.0))))
1562473611SBram Moolenaar  call assert_equal('inf', string(abs(1.0/0.0)))
1662473611SBram Moolenaar  call assert_equal('inf', string(abs(-1.0/0.0)))
1762473611SBram Moolenaar  call assert_equal('nan', string(abs(0.0/0.0)))
1817aca707SBram Moolenaar  call assert_equal('12', string(abs('12abc')))
1987200413SBram Moolenaar  call assert_equal('12', string(abs('-12abc')))
2087200413SBram Moolenaar  call assert_fails("call abs([])", 'E745:')
2187200413SBram Moolenaar  call assert_fails("call abs({})", 'E728:')
2287200413SBram Moolenaar  call assert_fails("call abs(function('string'))", 'E703:')
23453b576eSBram Moolenaarendfunc
24453b576eSBram Moolenaar
25453b576eSBram Moolenaarfunc Test_sqrt()
2662473611SBram Moolenaar  call assert_equal('0.0', string(sqrt(0.0)))
2762473611SBram Moolenaar  call assert_equal('1.414214', string(sqrt(2.0)))
2893cf85f9SBram Moolenaar  eval 2.0->sqrt()->string()->assert_equal('1.414214')
2962473611SBram Moolenaar  call assert_equal('inf', string(sqrt(1.0/0.0)))
3062473611SBram Moolenaar  call assert_equal('nan', string(sqrt(-1.0)))
3162473611SBram Moolenaar  call assert_equal('nan', string(sqrt(0.0/0.0)))
3287200413SBram Moolenaar  call assert_fails('call sqrt("")', 'E808:')
33453b576eSBram Moolenaarendfunc
34453b576eSBram Moolenaar
35453b576eSBram Moolenaarfunc Test_log()
3662473611SBram Moolenaar  call assert_equal('0.0', string(log(1.0)))
3762473611SBram Moolenaar  call assert_equal('-0.693147', string(log(0.5)))
3893cf85f9SBram Moolenaar  eval 0.5->log()->string()->assert_equal('-0.693147')
3962473611SBram Moolenaar  call assert_equal('-inf', string(log(0.0)))
4062473611SBram Moolenaar  call assert_equal('nan', string(log(-1.0)))
4162473611SBram Moolenaar  call assert_equal('inf', string(log(1.0/0.0)))
4262473611SBram Moolenaar  call assert_equal('nan', string(log(0.0/0.0)))
4387200413SBram Moolenaar  call assert_fails('call log("")', 'E808:')
44453b576eSBram Moolenaarendfunc
45453b576eSBram Moolenaar
46453b576eSBram Moolenaarfunc Test_log10()
4762473611SBram Moolenaar  call assert_equal('0.0', string(log10(1.0)))
4862473611SBram Moolenaar  call assert_equal('2.0', string(log10(100.0)))
4962473611SBram Moolenaar  call assert_equal('2.079181', string(log10(120.0)))
5093cf85f9SBram Moolenaar  eval 120.0->log10()->string()->assert_equal('2.079181')
5162473611SBram Moolenaar  call assert_equal('-inf', string(log10(0.0)))
5262473611SBram Moolenaar  call assert_equal('nan', string(log10(-1.0)))
5362473611SBram Moolenaar  call assert_equal('inf', string(log10(1.0/0.0)))
5462473611SBram Moolenaar  call assert_equal('nan', string(log10(0.0/0.0)))
5587200413SBram Moolenaar  call assert_fails('call log10("")', 'E808:')
56453b576eSBram Moolenaarendfunc
57453b576eSBram Moolenaar
58453b576eSBram Moolenaarfunc Test_exp()
5962473611SBram Moolenaar  call assert_equal('1.0', string(exp(0.0)))
6062473611SBram Moolenaar  call assert_equal('7.389056', string(exp(2.0)))
6162473611SBram Moolenaar  call assert_equal('0.367879', string(exp(-1.0)))
6293cf85f9SBram Moolenaar  eval -1.0->exp()->string()->assert_equal('0.367879')
6362473611SBram Moolenaar  call assert_equal('inf', string(exp(1.0/0.0)))
6462473611SBram Moolenaar  call assert_equal('0.0', string(exp(-1.0/0.0)))
6562473611SBram Moolenaar  call assert_equal('nan', string(exp(0.0/0.0)))
6687200413SBram Moolenaar  call assert_fails('call exp("")', 'E808:')
67453b576eSBram Moolenaarendfunc
68453b576eSBram Moolenaar
69453b576eSBram Moolenaarfunc Test_sin()
7062473611SBram Moolenaar  call assert_equal('0.0', string(sin(0.0)))
7162473611SBram Moolenaar  call assert_equal('0.841471', string(sin(1.0)))
7262473611SBram Moolenaar  call assert_equal('-0.479426', string(sin(-0.5)))
7393cf85f9SBram Moolenaar  eval -0.5->sin()->string()->assert_equal('-0.479426')
7462473611SBram Moolenaar  call assert_equal('nan', string(sin(0.0/0.0)))
7562473611SBram Moolenaar  call assert_equal('nan', string(sin(1.0/0.0)))
7662473611SBram Moolenaar  call assert_equal('0.0', string(sin(1.0/(1.0/0.0))))
7762473611SBram Moolenaar  call assert_equal('-0.0', string(sin(-1.0/(1.0/0.0))))
7887200413SBram Moolenaar  call assert_fails('call sin("")', 'E808:')
79453b576eSBram Moolenaarendfunc
80453b576eSBram Moolenaar
81453b576eSBram Moolenaarfunc Test_asin()
8262473611SBram Moolenaar  call assert_equal('0.0', string(asin(0.0)))
8362473611SBram Moolenaar  call assert_equal('1.570796', string(asin(1.0)))
8493cf85f9SBram Moolenaar  eval 1.0->asin()->string()->assert_equal('1.570796')
8593cf85f9SBram Moolenaar
8662473611SBram Moolenaar  call assert_equal('-0.523599', string(asin(-0.5)))
8762473611SBram Moolenaar  call assert_equal('nan', string(asin(1.1)))
8862473611SBram Moolenaar  call assert_equal('nan', string(asin(1.0/0.0)))
8962473611SBram Moolenaar  call assert_equal('nan', string(asin(0.0/0.0)))
9087200413SBram Moolenaar  call assert_fails('call asin("")', 'E808:')
91453b576eSBram Moolenaarendfunc
92453b576eSBram Moolenaar
93453b576eSBram Moolenaarfunc Test_sinh()
9462473611SBram Moolenaar  call assert_equal('0.0', string(sinh(0.0)))
9562473611SBram Moolenaar  call assert_equal('0.521095', string(sinh(0.5)))
9662473611SBram Moolenaar  call assert_equal('-1.026517', string(sinh(-0.9)))
9793cf85f9SBram Moolenaar  eval -0.9->sinh()->string()->assert_equal('-1.026517')
9862473611SBram Moolenaar  call assert_equal('inf', string(sinh(1.0/0.0)))
9962473611SBram Moolenaar  call assert_equal('-inf', string(sinh(-1.0/0.0)))
10062473611SBram Moolenaar  call assert_equal('nan', string(sinh(0.0/0.0)))
10187200413SBram Moolenaar  call assert_fails('call sinh("")', 'E808:')
102453b576eSBram Moolenaarendfunc
103453b576eSBram Moolenaar
104453b576eSBram Moolenaarfunc Test_cos()
10562473611SBram Moolenaar  call assert_equal('1.0', string(cos(0.0)))
10662473611SBram Moolenaar  call assert_equal('0.540302', string(cos(1.0)))
10762473611SBram Moolenaar  call assert_equal('0.877583', string(cos(-0.5)))
10893cf85f9SBram Moolenaar  eval -0.5->cos()->string()->assert_equal('0.877583')
10962473611SBram Moolenaar  call assert_equal('nan', string(cos(0.0/0.0)))
11062473611SBram Moolenaar  call assert_equal('nan', string(cos(1.0/0.0)))
11187200413SBram Moolenaar  call assert_fails('call cos("")', 'E808:')
112453b576eSBram Moolenaarendfunc
113453b576eSBram Moolenaar
114453b576eSBram Moolenaarfunc Test_acos()
11562473611SBram Moolenaar  call assert_equal('1.570796', string(acos(0.0)))
11662473611SBram Moolenaar  call assert_equal('0.0', string(acos(1.0)))
11762473611SBram Moolenaar  call assert_equal('3.141593', string(acos(-1.0)))
11893cf85f9SBram Moolenaar  eval -1.0->acos()->string()->assert_equal('3.141593')
11962473611SBram Moolenaar  call assert_equal('2.094395', string(acos(-0.5)))
12062473611SBram Moolenaar  call assert_equal('nan', string(acos(1.1)))
12162473611SBram Moolenaar  call assert_equal('nan', string(acos(1.0/0.0)))
12262473611SBram Moolenaar  call assert_equal('nan', string(acos(0.0/0.0)))
12387200413SBram Moolenaar  call assert_fails('call acos("")', 'E808:')
124453b576eSBram Moolenaarendfunc
125453b576eSBram Moolenaar
126453b576eSBram Moolenaarfunc Test_cosh()
12762473611SBram Moolenaar  call assert_equal('1.0', string(cosh(0.0)))
12862473611SBram Moolenaar  call assert_equal('1.127626', string(cosh(0.5)))
12993cf85f9SBram Moolenaar  eval 0.5->cosh()->string()->assert_equal('1.127626')
13062473611SBram Moolenaar  call assert_equal('inf', string(cosh(1.0/0.0)))
13162473611SBram Moolenaar  call assert_equal('inf', string(cosh(-1.0/0.0)))
13262473611SBram Moolenaar  call assert_equal('nan', string(cosh(0.0/0.0)))
13387200413SBram Moolenaar  call assert_fails('call cosh("")', 'E808:')
134453b576eSBram Moolenaarendfunc
135453b576eSBram Moolenaar
136453b576eSBram Moolenaarfunc Test_tan()
13762473611SBram Moolenaar  call assert_equal('0.0', string(tan(0.0)))
13862473611SBram Moolenaar  call assert_equal('0.546302', string(tan(0.5)))
13962473611SBram Moolenaar  call assert_equal('-0.546302', string(tan(-0.5)))
14093cf85f9SBram Moolenaar  eval -0.5->tan()->string()->assert_equal('-0.546302')
14162473611SBram Moolenaar  call assert_equal('nan', string(tan(1.0/0.0)))
14262473611SBram Moolenaar  call assert_equal('nan', string(cos(0.0/0.0)))
14362473611SBram Moolenaar  call assert_equal('0.0', string(tan(1.0/(1.0/0.0))))
14462473611SBram Moolenaar  call assert_equal('-0.0', string(tan(-1.0/(1.0/0.0))))
14587200413SBram Moolenaar  call assert_fails('call tan("")', 'E808:')
146453b576eSBram Moolenaarendfunc
147453b576eSBram Moolenaar
148453b576eSBram Moolenaarfunc Test_atan()
14962473611SBram Moolenaar  call assert_equal('0.0', string(atan(0.0)))
15062473611SBram Moolenaar  call assert_equal('0.463648', string(atan(0.5)))
15162473611SBram Moolenaar  call assert_equal('-0.785398', string(atan(-1.0)))
15293cf85f9SBram Moolenaar  eval -1.0->atan()->string()->assert_equal('-0.785398')
15362473611SBram Moolenaar  call assert_equal('1.570796', string(atan(1.0/0.0)))
15462473611SBram Moolenaar  call assert_equal('-1.570796', string(atan(-1.0/0.0)))
15562473611SBram Moolenaar  call assert_equal('nan', string(atan(0.0/0.0)))
15687200413SBram Moolenaar  call assert_fails('call atan("")', 'E808:')
157453b576eSBram Moolenaarendfunc
158453b576eSBram Moolenaar
159453b576eSBram Moolenaarfunc Test_atan2()
16062473611SBram Moolenaar  call assert_equal('-2.356194', string(atan2(-1, -1)))
16162473611SBram Moolenaar  call assert_equal('2.356194', string(atan2(1, -1)))
16262473611SBram Moolenaar  call assert_equal('0.0', string(atan2(1.0, 1.0/0.0)))
16393cf85f9SBram Moolenaar  eval 1.0->atan2(1.0/0.0)->string()->assert_equal('0.0')
16462473611SBram Moolenaar  call assert_equal('1.570796', string(atan2(1.0/0.0, 1.0)))
16562473611SBram Moolenaar  call assert_equal('nan', string(atan2(0.0/0.0, 1.0)))
16687200413SBram Moolenaar  call assert_fails('call atan2("", -1)', 'E808:')
16787200413SBram Moolenaar  call assert_fails('call atan2(-1, "")', 'E808:')
168453b576eSBram Moolenaarendfunc
169453b576eSBram Moolenaar
170453b576eSBram Moolenaarfunc Test_tanh()
17162473611SBram Moolenaar  call assert_equal('0.0', string(tanh(0.0)))
17262473611SBram Moolenaar  call assert_equal('0.462117', string(tanh(0.5)))
17362473611SBram Moolenaar  call assert_equal('-0.761594', string(tanh(-1.0)))
17493cf85f9SBram Moolenaar  eval -1.0->tanh()->string()->assert_equal('-0.761594')
17562473611SBram Moolenaar  call assert_equal('1.0', string(tanh(1.0/0.0)))
17662473611SBram Moolenaar  call assert_equal('-1.0', string(tanh(-1.0/0.0)))
17762473611SBram Moolenaar  call assert_equal('nan', string(tanh(0.0/0.0)))
17887200413SBram Moolenaar  call assert_fails('call tanh("")', 'E808:')
179453b576eSBram Moolenaarendfunc
180453b576eSBram Moolenaar
181453b576eSBram Moolenaarfunc Test_fmod()
18262473611SBram Moolenaar  call assert_equal('0.13', string(fmod(12.33, 1.22)))
18362473611SBram Moolenaar  call assert_equal('-0.13', string(fmod(-12.33, 1.22)))
18462473611SBram Moolenaar  call assert_equal('nan', string(fmod(1.0/0.0, 1.0)))
18593cf85f9SBram Moolenaar  eval (1.0/0.0)->fmod(1.0)->string()->assert_equal('nan')
18662473611SBram Moolenaar  " On Windows we get "nan" instead of 1.0, accept both.
18762473611SBram Moolenaar  let res = string(fmod(1.0, 1.0/0.0))
18862473611SBram Moolenaar  if res != 'nan'
18962473611SBram Moolenaar    call assert_equal('1.0', res)
19062473611SBram Moolenaar  endif
19162473611SBram Moolenaar  call assert_equal('nan', string(fmod(1.0, 0.0)))
19287200413SBram Moolenaar  call assert_fails("call fmod('', 1.22)", 'E808:')
19387200413SBram Moolenaar  call assert_fails("call fmod(12.33, '')", 'E808:')
194453b576eSBram Moolenaarendfunc
195453b576eSBram Moolenaar
196453b576eSBram Moolenaarfunc Test_pow()
19762473611SBram Moolenaar  call assert_equal('1.0', string(pow(0.0, 0.0)))
19862473611SBram Moolenaar  call assert_equal('8.0', string(pow(2.0, 3.0)))
19993cf85f9SBram Moolenaar  eval 2.0->pow(3.0)->string()->assert_equal('8.0')
20062473611SBram Moolenaar  call assert_equal('nan', string(pow(2.0, 0.0/0.0)))
20162473611SBram Moolenaar  call assert_equal('nan', string(pow(0.0/0.0, 3.0)))
20262473611SBram Moolenaar  call assert_equal('nan', string(pow(0.0/0.0, 3.0)))
20362473611SBram Moolenaar  call assert_equal('inf', string(pow(2.0, 1.0/0.0)))
20462473611SBram Moolenaar  call assert_equal('inf', string(pow(1.0/0.0, 3.0)))
20587200413SBram Moolenaar  call assert_fails("call pow('', 2.0)", 'E808:')
20687200413SBram Moolenaar  call assert_fails("call pow(2.0, '')", 'E808:')
207453b576eSBram Moolenaarendfunc
208453b576eSBram Moolenaar
209453b576eSBram Moolenaarfunc Test_str2float()
21062473611SBram Moolenaar  call assert_equal('1.0', string(str2float('1')))
21108243d26SBram Moolenaar  call assert_equal('1.0', string(str2float(' 1 ')))
21208243d26SBram Moolenaar  call assert_equal('1.0', string(str2float(' 1.0 ')))
21362473611SBram Moolenaar  call assert_equal('1.23', string(str2float('1.23')))
21462473611SBram Moolenaar  call assert_equal('1.23', string(str2float('1.23abc')))
21593cf85f9SBram Moolenaar  eval '1.23abc'->str2float()->string()->assert_equal('1.23')
21662473611SBram Moolenaar  call assert_equal('1.0e40', string(str2float('1e40')))
21787200413SBram Moolenaar  call assert_equal('-1.23', string(str2float('-1.23')))
21887200413SBram Moolenaar  call assert_equal('1.23', string(str2float(' + 1.23 ')))
21908243d26SBram Moolenaar
22008243d26SBram Moolenaar  call assert_equal('1.0', string(str2float('+1')))
22108243d26SBram Moolenaar  call assert_equal('1.0', string(str2float('+1')))
22208243d26SBram Moolenaar  call assert_equal('1.0', string(str2float(' +1 ')))
22308243d26SBram Moolenaar  call assert_equal('1.0', string(str2float(' + 1 ')))
22408243d26SBram Moolenaar
22508243d26SBram Moolenaar  call assert_equal('-1.0', string(str2float('-1')))
22608243d26SBram Moolenaar  call assert_equal('-1.0', string(str2float('-1')))
22708243d26SBram Moolenaar  call assert_equal('-1.0', string(str2float(' -1 ')))
22808243d26SBram Moolenaar  call assert_equal('-1.0', string(str2float(' - 1 ')))
22908243d26SBram Moolenaar
23087200413SBram Moolenaar  call assert_equal('0.0', string(str2float('+0.0')))
23187200413SBram Moolenaar  call assert_equal('-0.0', string(str2float('-0.0')))
23262473611SBram Moolenaar  call assert_equal('inf', string(str2float('1e1000')))
23362473611SBram Moolenaar  call assert_equal('inf', string(str2float('inf')))
23462473611SBram Moolenaar  call assert_equal('-inf', string(str2float('-inf')))
23587200413SBram Moolenaar  call assert_equal('inf', string(str2float('+inf')))
23662473611SBram Moolenaar  call assert_equal('inf', string(str2float('Inf')))
23787200413SBram Moolenaar  call assert_equal('inf', string(str2float('  +inf  ')))
23862473611SBram Moolenaar  call assert_equal('nan', string(str2float('nan')))
23962473611SBram Moolenaar  call assert_equal('nan', string(str2float('NaN')))
24087200413SBram Moolenaar  call assert_equal('nan', string(str2float('  nan  ')))
24187200413SBram Moolenaar
2422950065eSBram Moolenaar  call assert_equal('123456.789', string(str2float("123'456.789", 1)))
2432950065eSBram Moolenaar  call assert_equal('123456.789', string(str2float("12'34'56.789", 1)))
2442950065eSBram Moolenaar  call assert_equal('123456.789', string(str2float("1'2'3'4'5'6.789", 1)))
2452950065eSBram Moolenaar  call assert_equal('1.0', string(str2float("1''2.3", 1)))
2462950065eSBram Moolenaar  call assert_equal('123456.7', string(str2float("123'456.7'89", 1)))
2472950065eSBram Moolenaar
2482950065eSBram Moolenaar  call assert_equal(1.2, str2float(1.2, 0))
2494490ec4eSYegappan Lakshmanan  call CheckDefAndScriptFailure2(['str2float(1.2)'], 'E1013: Argument 1: type mismatch, expected string but got float', 'E1174: String required for argument 1')
25087200413SBram Moolenaar  call assert_fails("call str2float([])", 'E730:')
25187200413SBram Moolenaar  call assert_fails("call str2float({})", 'E731:')
25287200413SBram Moolenaar  call assert_fails("call str2float(function('string'))", 'E729:')
253453b576eSBram Moolenaarendfunc
254453b576eSBram Moolenaar
2552950065eSBram Moolenaardef Test_float_quotes()
2562950065eSBram Moolenaar  call assert_equal('123456.789', string(123'456.789))
2572950065eSBram Moolenaar  call assert_equal('123456.789', string(12'34'56.789))
2582950065eSBram Moolenaar  call assert_equal('123456.789', string(1'2'3'4'5'6.789))
2592950065eSBram Moolenaar
2602950065eSBram Moolenaar  call assert_fails("echo string(1''2.3)", 'E116:')
2612950065eSBram Moolenaar  call assert_fails("echo string(123'456.7'89)", 'E116:')
2622950065eSBram Moolenaarenddef
2632950065eSBram Moolenaar
264*ed8b099fSBram Moolenaarfunc Test_float_quotes_from_legacy()
265*ed8b099fSBram Moolenaar  call assert_equal("\n123456.789", execute("vim9 echo 12'34'56.789"))
266*ed8b099fSBram Moolenaarendfunc
267*ed8b099fSBram Moolenaar
268863e80b4SBram Moolenaarfunc Test_float2nr()
269863e80b4SBram Moolenaar  call assert_equal(1, float2nr(1.234))
270863e80b4SBram Moolenaar  call assert_equal(123, float2nr(1.234e2))
271863e80b4SBram Moolenaar  call assert_equal(12, float2nr(123.4e-1))
27293cf85f9SBram Moolenaar  eval 123.4e-1->float2nr()->assert_equal(12)
273863e80b4SBram Moolenaar  let max_number = 1/0
274863e80b4SBram Moolenaar  let min_number = -max_number
275863e80b4SBram Moolenaar  call assert_equal(max_number/2+1, float2nr(pow(2, 62)))
276863e80b4SBram Moolenaar  call assert_equal(max_number, float2nr(pow(2, 63)))
277863e80b4SBram Moolenaar  call assert_equal(max_number, float2nr(pow(2, 64)))
278863e80b4SBram Moolenaar  call assert_equal(min_number/2-1, float2nr(-pow(2, 62)))
279863e80b4SBram Moolenaar  call assert_equal(min_number, float2nr(-pow(2, 63)))
280863e80b4SBram Moolenaar  call assert_equal(min_number, float2nr(-pow(2, 64)))
281863e80b4SBram Moolenaarendfunc
282863e80b4SBram Moolenaar
283453b576eSBram Moolenaarfunc Test_floor()
28462473611SBram Moolenaar  call assert_equal('2.0', string(floor(2.0)))
28562473611SBram Moolenaar  call assert_equal('2.0', string(floor(2.11)))
28662473611SBram Moolenaar  call assert_equal('2.0', string(floor(2.99)))
28793cf85f9SBram Moolenaar  eval 2.99->floor()->string()->assert_equal('2.0')
28862473611SBram Moolenaar  call assert_equal('-3.0', string(floor(-2.11)))
28962473611SBram Moolenaar  call assert_equal('-3.0', string(floor(-2.99)))
29062473611SBram Moolenaar  call assert_equal('nan', string(floor(0.0/0.0)))
29162473611SBram Moolenaar  call assert_equal('inf', string(floor(1.0/0.0)))
29262473611SBram Moolenaar  call assert_equal('-inf', string(floor(-1.0/0.0)))
29387200413SBram Moolenaar  call assert_fails("call floor('')", 'E808:')
294453b576eSBram Moolenaarendfunc
295453b576eSBram Moolenaar
296453b576eSBram Moolenaarfunc Test_ceil()
29762473611SBram Moolenaar  call assert_equal('2.0', string(ceil(2.0)))
29862473611SBram Moolenaar  call assert_equal('3.0', string(ceil(2.11)))
29962473611SBram Moolenaar  call assert_equal('3.0', string(ceil(2.99)))
30062473611SBram Moolenaar  call assert_equal('-2.0', string(ceil(-2.11)))
30193cf85f9SBram Moolenaar  eval -2.11->ceil()->string()->assert_equal('-2.0')
30262473611SBram Moolenaar  call assert_equal('-2.0', string(ceil(-2.99)))
30362473611SBram Moolenaar  call assert_equal('nan', string(ceil(0.0/0.0)))
30462473611SBram Moolenaar  call assert_equal('inf', string(ceil(1.0/0.0)))
30562473611SBram Moolenaar  call assert_equal('-inf', string(ceil(-1.0/0.0)))
30687200413SBram Moolenaar  call assert_fails("call ceil('')", 'E808:')
307453b576eSBram Moolenaarendfunc
308453b576eSBram Moolenaar
309453b576eSBram Moolenaarfunc Test_round()
31062473611SBram Moolenaar  call assert_equal('2.0', string(round(2.1)))
31162473611SBram Moolenaar  call assert_equal('3.0', string(round(2.5)))
31262473611SBram Moolenaar  call assert_equal('3.0', string(round(2.9)))
31393cf85f9SBram Moolenaar  eval 2.9->round()->string()->assert_equal('3.0')
31462473611SBram Moolenaar  call assert_equal('-2.0', string(round(-2.1)))
31562473611SBram Moolenaar  call assert_equal('-3.0', string(round(-2.5)))
31662473611SBram Moolenaar  call assert_equal('-3.0', string(round(-2.9)))
31762473611SBram Moolenaar  call assert_equal('nan', string(round(0.0/0.0)))
31862473611SBram Moolenaar  call assert_equal('inf', string(round(1.0/0.0)))
31962473611SBram Moolenaar  call assert_equal('-inf', string(round(-1.0/0.0)))
32087200413SBram Moolenaar  call assert_fails("call round('')", 'E808:')
321453b576eSBram Moolenaarendfunc
322453b576eSBram Moolenaar
323453b576eSBram Moolenaarfunc Test_trunc()
32462473611SBram Moolenaar  call assert_equal('2.0', string(trunc(2.1)))
32562473611SBram Moolenaar  call assert_equal('2.0', string(trunc(2.5)))
32662473611SBram Moolenaar  call assert_equal('2.0', string(trunc(2.9)))
32793cf85f9SBram Moolenaar  eval 2.9->trunc()->string()->assert_equal('2.0')
32862473611SBram Moolenaar  call assert_equal('-2.0', string(trunc(-2.1)))
32962473611SBram Moolenaar  call assert_equal('-2.0', string(trunc(-2.5)))
33062473611SBram Moolenaar  call assert_equal('-2.0', string(trunc(-2.9)))
33162473611SBram Moolenaar  call assert_equal('nan', string(trunc(0.0/0.0)))
33262473611SBram Moolenaar  call assert_equal('inf', string(trunc(1.0/0.0)))
33362473611SBram Moolenaar  call assert_equal('-inf', string(trunc(-1.0/0.0)))
33487200413SBram Moolenaar  call assert_fails("call trunc('')", 'E808:')
335453b576eSBram Moolenaarendfunc
336453b576eSBram Moolenaar
337fda1bff3SBram Moolenaarfunc Test_isinf()
338fda1bff3SBram Moolenaar  call assert_equal(1, isinf(1.0/0.0))
339fda1bff3SBram Moolenaar  call assert_equal(-1, isinf(-1.0/0.0))
34093cf85f9SBram Moolenaar  eval (-1.0/0.0)->isinf()->assert_equal(-1)
341fda1bff3SBram Moolenaar  call assert_false(isinf(1.0))
342fda1bff3SBram Moolenaar  call assert_false(isinf(0.0/0.0))
343fda1bff3SBram Moolenaar  call assert_false(isinf('a'))
344fda1bff3SBram Moolenaar  call assert_false(isinf([]))
345fda1bff3SBram Moolenaar  call assert_false(isinf({}))
346fda1bff3SBram Moolenaarendfunc
347fda1bff3SBram Moolenaar
348453b576eSBram Moolenaarfunc Test_isnan()
349fda1bff3SBram Moolenaar  call assert_true(isnan(0.0/0.0))
350fda1bff3SBram Moolenaar  call assert_false(isnan(1.0))
351fda1bff3SBram Moolenaar  call assert_false(isnan(1.0/0.0))
35293cf85f9SBram Moolenaar  eval (1.0/0.0)->isnan()->assert_false()
353fda1bff3SBram Moolenaar  call assert_false(isnan(-1.0/0.0))
354fda1bff3SBram Moolenaar  call assert_false(isnan('a'))
355fda1bff3SBram Moolenaar  call assert_false(isnan([]))
356fda1bff3SBram Moolenaar  call assert_false(isnan({}))
357453b576eSBram Moolenaarendfunc
358863e80b4SBram Moolenaar
359863e80b4SBram Moolenaar" This was converted from test65
360863e80b4SBram Moolenaarfunc Test_float_misc()
361863e80b4SBram Moolenaar  call assert_equal('123.456000', printf('%f', 123.456))
362863e80b4SBram Moolenaar  call assert_equal('1.234560e+02', printf('%e', 123.456))
363863e80b4SBram Moolenaar  call assert_equal('123.456', printf('%g', 123.456))
364863e80b4SBram Moolenaar  " +=
365863e80b4SBram Moolenaar  let v = 1.234
366863e80b4SBram Moolenaar  let v += 6.543
367863e80b4SBram Moolenaar  call assert_equal('7.777', printf('%g', v))
368863e80b4SBram Moolenaar  let v = 1.234
369863e80b4SBram Moolenaar  let v += 5
370863e80b4SBram Moolenaar  call assert_equal('6.234', printf('%g', v))
371863e80b4SBram Moolenaar  let v = 5
372863e80b4SBram Moolenaar  let v += 3.333
373863e80b4SBram Moolenaar  call assert_equal('8.333', string(v))
374863e80b4SBram Moolenaar  " ==
375863e80b4SBram Moolenaar  let v = 1.234
376863e80b4SBram Moolenaar  call assert_true(v == 1.234)
377863e80b4SBram Moolenaar  call assert_false(v == 1.2341)
378863e80b4SBram Moolenaar  " add-subtract
379863e80b4SBram Moolenaar  call assert_equal('5.234', printf('%g', 4 + 1.234))
380863e80b4SBram Moolenaar  call assert_equal('-6.766', printf('%g', 1.234 - 8))
381863e80b4SBram Moolenaar  " mult-div
382863e80b4SBram Moolenaar  call assert_equal('4.936', printf('%g', 4 * 1.234))
383863e80b4SBram Moolenaar  call assert_equal('0.003241', printf('%g', 4.0 / 1234))
384863e80b4SBram Moolenaar  " dict
385863e80b4SBram Moolenaar  call assert_equal("{'x': 1.234, 'y': -2.0e20}", string({'x': 1.234, 'y': -2.0e20}))
386863e80b4SBram Moolenaar  " list
387863e80b4SBram Moolenaar  call assert_equal('[-123.4, 2.0e-20]', string([-123.4, 2.0e-20]))
388863e80b4SBram Moolenaarendfunc
389863e80b4SBram Moolenaar
390863e80b4SBram Moolenaar" vim: shiftwidth=2 sts=2 expandtab
391