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