neovim

Neovim text editor
git clone https://git.dasho.dev/neovim.git
Log | Files | Refs | README

test_float_func.vim (15152B)


      1 " test float functions
      2 
      3 source check.vim
      4 CheckFeature float
      5 source vim9.vim
      6 
      7 func Test_abs()
      8  call assert_equal('1.23', string(abs(1.23)))
      9  call assert_equal('1.23', string(abs(-1.23)))
     10  eval -1.23->abs()->string()->assert_equal('1.23')
     11 
     12  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("str2float('inf')", string(abs(1.0/0.0)))
     16  call assert_equal("str2float('inf')", string(abs(-1.0/0.0)))
     17  call assert_equal("str2float('nan')", string(abs(0.0/0.0)))
     18  call assert_equal('12', string(abs('12abc')))
     19  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:')
     23 endfunc
     24 
     25 func Test_sqrt()
     26  call assert_equal('0.0', string(sqrt(0.0)))
     27  call assert_equal('1.414214', string(sqrt(2.0)))
     28  eval 2.0->sqrt()->string()->assert_equal('1.414214')
     29  call assert_equal("str2float('inf')", string(sqrt(1.0/0.0)))
     30  call assert_equal("str2float('nan')", string(sqrt(-1.0)))
     31  call assert_equal("str2float('nan')", string(sqrt(0.0/0.0)))
     32  call assert_fails('call sqrt("")', 'E808:')
     33 endfunc
     34 
     35 func Test_log()
     36  call assert_equal('0.0', string(log(1.0)))
     37  call assert_equal('-0.693147', string(log(0.5)))
     38  eval 0.5->log()->string()->assert_equal('-0.693147')
     39  call assert_equal("-str2float('inf')", string(log(0.0)))
     40  call assert_equal("str2float('nan')", string(log(-1.0)))
     41  call assert_equal("str2float('inf')", string(log(1.0/0.0)))
     42  call assert_equal("str2float('nan')", string(log(0.0/0.0)))
     43  call assert_fails('call log("")', 'E808:')
     44 endfunc
     45 
     46 func Test_log10()
     47  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)))
     50  eval 120.0->log10()->string()->assert_equal('2.079181')
     51  call assert_equal("-str2float('inf')", string(log10(0.0)))
     52  call assert_equal("str2float('nan')", string(log10(-1.0)))
     53  call assert_equal("str2float('inf')", string(log10(1.0/0.0)))
     54  call assert_equal("str2float('nan')", string(log10(0.0/0.0)))
     55  call assert_fails('call log10("")', 'E808:')
     56 endfunc
     57 
     58 func Test_exp()
     59  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)))
     62  eval -1.0->exp()->string()->assert_equal('0.367879')
     63  call assert_equal("str2float('inf')", string(exp(1.0/0.0)))
     64  call assert_equal('0.0', string(exp(-1.0/0.0)))
     65  call assert_equal("str2float('nan')", string(exp(0.0/0.0)))
     66  call assert_fails('call exp("")', 'E808:')
     67 endfunc
     68 
     69 func Test_sin()
     70  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)))
     73  eval -0.5->sin()->string()->assert_equal('-0.479426')
     74  call assert_equal("str2float('nan')", string(sin(0.0/0.0)))
     75  call assert_equal("str2float('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))))
     78  call assert_fails('call sin("")', 'E808:')
     79 endfunc
     80 
     81 func Test_asin()
     82  call assert_equal('0.0', string(asin(0.0)))
     83  call assert_equal('1.570796', string(asin(1.0)))
     84  eval 1.0->asin()->string()->assert_equal('1.570796')
     85 
     86  call assert_equal('-0.523599', string(asin(-0.5)))
     87  call assert_equal("str2float('nan')", string(asin(1.1)))
     88  call assert_equal("str2float('nan')", string(asin(1.0/0.0)))
     89  call assert_equal("str2float('nan')", string(asin(0.0/0.0)))
     90  call assert_fails('call asin("")', 'E808:')
     91 endfunc
     92 
     93 func Test_sinh()
     94  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)))
     97  eval -0.9->sinh()->string()->assert_equal('-1.026517')
     98  call assert_equal("str2float('inf')", string(sinh(1.0/0.0)))
     99  call assert_equal("-str2float('inf')", string(sinh(-1.0/0.0)))
    100  call assert_equal("str2float('nan')", string(sinh(0.0/0.0)))
    101  call assert_fails('call sinh("")', 'E808:')
    102 endfunc
    103 
    104 func Test_cos()
    105  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)))
    108  eval -0.5->cos()->string()->assert_equal('0.877583')
    109  call assert_equal("str2float('nan')", string(cos(0.0/0.0)))
    110  call assert_equal("str2float('nan')", string(cos(1.0/0.0)))
    111  call assert_fails('call cos("")', 'E808:')
    112 endfunc
    113 
    114 func Test_acos()
    115  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)))
    118  eval -1.0->acos()->string()->assert_equal('3.141593')
    119  call assert_equal('2.094395', string(acos(-0.5)))
    120  call assert_equal("str2float('nan')", string(acos(1.1)))
    121  call assert_equal("str2float('nan')", string(acos(1.0/0.0)))
    122  call assert_equal("str2float('nan')", string(acos(0.0/0.0)))
    123  call assert_fails('call acos("")', 'E808:')
    124 endfunc
    125 
    126 func Test_cosh()
    127  call assert_equal('1.0', string(cosh(0.0)))
    128  call assert_equal('1.127626', string(cosh(0.5)))
    129  eval 0.5->cosh()->string()->assert_equal('1.127626')
    130  call assert_equal("str2float('inf')", string(cosh(1.0/0.0)))
    131  call assert_equal("str2float('inf')", string(cosh(-1.0/0.0)))
    132  call assert_equal("str2float('nan')", string(cosh(0.0/0.0)))
    133  call assert_fails('call cosh("")', 'E808:')
    134 endfunc
    135 
    136 func Test_tan()
    137  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)))
    140  eval -0.5->tan()->string()->assert_equal('-0.546302')
    141  call assert_equal("str2float('nan')", string(tan(1.0/0.0)))
    142  call assert_equal("str2float('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))))
    145  call assert_fails('call tan("")', 'E808:')
    146 endfunc
    147 
    148 func Test_atan()
    149  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)))
    152  eval -1.0->atan()->string()->assert_equal('-0.785398')
    153  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("str2float('nan')", string(atan(0.0/0.0)))
    156  call assert_fails('call atan("")', 'E808:')
    157 endfunc
    158 
    159 func Test_atan2()
    160  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)))
    163  eval 1.0->atan2(1.0/0.0)->string()->assert_equal('0.0')
    164  call assert_equal('1.570796', string(atan2(1.0/0.0, 1.0)))
    165  call assert_equal("str2float('nan')", string(atan2(0.0/0.0, 1.0)))
    166  call assert_fails('call atan2("", -1)', 'E808:')
    167  call assert_fails('call atan2(-1, "")', 'E808:')
    168 endfunc
    169 
    170 func Test_tanh()
    171  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)))
    174  eval -1.0->tanh()->string()->assert_equal('-0.761594')
    175  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("str2float('nan')", string(tanh(0.0/0.0)))
    178  call assert_fails('call tanh("")', 'E808:')
    179 endfunc
    180 
    181 func Test_fmod()
    182  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("str2float('nan')", string(fmod(1.0/0.0, 1.0)))
    185  eval (1.0/0.0)->fmod(1.0)->string()->assert_equal("str2float('nan')")
    186  " 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 != "str2float('nan')"
    189    call assert_equal('1.0', res)
    190  endif
    191  call assert_equal("str2float('nan')", string(fmod(1.0, 0.0)))
    192  call assert_fails("call fmod('', 1.22)", 'E808:')
    193  call assert_fails("call fmod(12.33, '')", 'E808:')
    194 endfunc
    195 
    196 func Test_pow()
    197  call assert_equal('1.0', string(pow(0.0, 0.0)))
    198  call assert_equal('8.0', string(pow(2.0, 3.0)))
    199  eval 2.0->pow(3.0)->string()->assert_equal('8.0')
    200  call assert_equal("str2float('nan')", string(pow(2.0, 0.0/0.0)))
    201  call assert_equal("str2float('nan')", string(pow(0.0/0.0, 3.0)))
    202  call assert_equal("str2float('nan')", string(pow(0.0/0.0, 3.0)))
    203  call assert_equal("str2float('inf')", string(pow(2.0, 1.0/0.0)))
    204  call assert_equal("str2float('inf')", string(pow(1.0/0.0, 3.0)))
    205  call assert_fails("call pow('', 2.0)", 'E808:')
    206  call assert_fails("call pow(2.0, '')", 'E808:')
    207 endfunc
    208 
    209 func Test_str2float()
    210  call assert_equal('1.0', string(str2float('1')))
    211  call assert_equal('1.0', string(str2float(' 1 ')))
    212  call assert_equal('1.0', string(str2float(' 1.0 ')))
    213  call assert_equal('1.23', string(str2float('1.23')))
    214  call assert_equal('1.23', string(str2float('1.23abc')))
    215  eval '1.23abc'->str2float()->string()->assert_equal('1.23')
    216  call assert_equal('1.0e40', string(str2float('1e40')))
    217  call assert_equal('-1.23', string(str2float('-1.23')))
    218  call assert_equal('1.23', string(str2float(' + 1.23 ')))
    219 
    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 
    230  call assert_equal('0.0', string(str2float('+0.0')))
    231  call assert_equal('-0.0', string(str2float('-0.0')))
    232  call assert_equal("str2float('inf')", string(str2float('1e1000')))
    233  call assert_equal("str2float('inf')", string(str2float('inf')))
    234  call assert_equal("-str2float('inf')", string(str2float('-inf')))
    235  call assert_equal("str2float('inf')", string(str2float('+inf')))
    236  call assert_equal("str2float('inf')", string(str2float('Inf')))
    237  call assert_equal("str2float('inf')", string(str2float('  +inf  ')))
    238  call assert_equal("str2float('nan')", string(str2float('nan')))
    239  call assert_equal("str2float('nan')", string(str2float('NaN')))
    240  call assert_equal("str2float('nan')", string(str2float('  nan  ')))
    241 
    242  call assert_equal(1.2, str2float(1.2))
    243  call CheckDefExecFailure(['str2float(1.2)'], 'E1013:')
    244  call CheckScriptFailure(['vim9script', 'str2float(1.2)'], 'E806:')
    245  call assert_fails("call str2float([])", 'E730:')
    246  call assert_fails("call str2float({})", 'E731:')
    247  call assert_fails("call str2float(function('string'))", 'E729:')
    248 endfunc
    249 
    250 func Test_float2nr()
    251  call assert_equal(1, float2nr(1.234))
    252  call assert_equal(123, float2nr(1.234e2))
    253  call assert_equal(12, float2nr(123.4e-1))
    254  eval 123.4e-1->float2nr()->assert_equal(12)
    255  let max_number = 1/0
    256  let min_number = -max_number
    257  call assert_equal(max_number/2+1, float2nr(pow(2, 62)))
    258  call assert_equal(max_number, float2nr(pow(2, 63)))
    259  call assert_equal(max_number, float2nr(pow(2, 64)))
    260  call assert_equal(min_number/2-1, float2nr(-pow(2, 62)))
    261  call assert_equal(min_number, float2nr(-pow(2, 63)))
    262  call assert_equal(min_number, float2nr(-pow(2, 64)))
    263 endfunc
    264 
    265 func Test_floor()
    266  call assert_equal('2.0', string(floor(2.0)))
    267  call assert_equal('2.0', string(floor(2.11)))
    268  call assert_equal('2.0', string(floor(2.99)))
    269  eval 2.99->floor()->string()->assert_equal('2.0')
    270  call assert_equal('-3.0', string(floor(-2.11)))
    271  call assert_equal('-3.0', string(floor(-2.99)))
    272  call assert_equal("str2float('nan')", string(floor(0.0/0.0)))
    273  call assert_equal("str2float('inf')", string(floor(1.0/0.0)))
    274  call assert_equal("-str2float('inf')", string(floor(-1.0/0.0)))
    275  call assert_fails("call floor('')", 'E808:')
    276 endfunc
    277 
    278 func Test_ceil()
    279  call assert_equal('2.0', string(ceil(2.0)))
    280  call assert_equal('3.0', string(ceil(2.11)))
    281  call assert_equal('3.0', string(ceil(2.99)))
    282  call assert_equal('-2.0', string(ceil(-2.11)))
    283  eval -2.11->ceil()->string()->assert_equal('-2.0')
    284  call assert_equal('-2.0', string(ceil(-2.99)))
    285  call assert_equal("str2float('nan')", string(ceil(0.0/0.0)))
    286  call assert_equal("str2float('inf')", string(ceil(1.0/0.0)))
    287  call assert_equal("-str2float('inf')", string(ceil(-1.0/0.0)))
    288  call assert_fails("call ceil('')", 'E808:')
    289 endfunc
    290 
    291 func Test_round()
    292  call assert_equal('2.0', string(round(2.1)))
    293  call assert_equal('3.0', string(round(2.5)))
    294  call assert_equal('3.0', string(round(2.9)))
    295  eval 2.9->round()->string()->assert_equal('3.0')
    296  call assert_equal('-2.0', string(round(-2.1)))
    297  call assert_equal('-3.0', string(round(-2.5)))
    298  call assert_equal('-3.0', string(round(-2.9)))
    299  call assert_equal("str2float('nan')", string(round(0.0/0.0)))
    300  call assert_equal("str2float('inf')", string(round(1.0/0.0)))
    301  call assert_equal("-str2float('inf')", string(round(-1.0/0.0)))
    302  call assert_fails("call round('')", 'E808:')
    303 endfunc
    304 
    305 func Test_trunc()
    306  call assert_equal('2.0', string(trunc(2.1)))
    307  call assert_equal('2.0', string(trunc(2.5)))
    308  call assert_equal('2.0', string(trunc(2.9)))
    309  eval 2.9->trunc()->string()->assert_equal('2.0')
    310  call assert_equal('-2.0', string(trunc(-2.1)))
    311  call assert_equal('-2.0', string(trunc(-2.5)))
    312  call assert_equal('-2.0', string(trunc(-2.9)))
    313  call assert_equal("str2float('nan')", string(trunc(0.0/0.0)))
    314  call assert_equal("str2float('inf')", string(trunc(1.0/0.0)))
    315  call assert_equal("-str2float('inf')", string(trunc(-1.0/0.0)))
    316  call assert_fails("call trunc('')", 'E808:')
    317 endfunc
    318 
    319 func Test_isinf()
    320  call assert_equal(1, isinf(1.0/0.0))
    321  call assert_equal(-1, isinf(-1.0/0.0))
    322  eval (-1.0/0.0)->isinf()->assert_equal(-1)
    323  call assert_false(isinf(1.0))
    324  call assert_false(isinf(0.0/0.0))
    325  call assert_false(isinf('a'))
    326  call assert_false(isinf([]))
    327  call assert_false(isinf({}))
    328 endfunc
    329 
    330 func Test_isnan()
    331  call assert_true(isnan(0.0/0.0))
    332  call assert_false(isnan(1.0))
    333  call assert_false(isnan(1.0/0.0))
    334  eval (1.0/0.0)->isnan()->assert_false()
    335  call assert_false(isnan(-1.0/0.0))
    336  call assert_false(isnan('a'))
    337  call assert_false(isnan([]))
    338  call assert_false(isnan({}))
    339 endfunc
    340 
    341 " This was converted from test65
    342 func Test_float_misc()
    343  call assert_equal('123.456000', printf('%f', 123.456))
    344  call assert_equal('1.234560e+02', printf('%e', 123.456))
    345  call assert_equal('123.456', printf('%g', 123.456))
    346  " +=
    347  let v = 1.234
    348  let v += 6.543
    349  call assert_equal('7.777', printf('%g', v))
    350  let v = 1.234
    351  let v += 5
    352  call assert_equal('6.234', printf('%g', v))
    353  let v = 5
    354  let v += 3.333
    355  call assert_equal('8.333', string(v))
    356  " ==
    357  let v = 1.234
    358  call assert_true(v == 1.234)
    359  call assert_false(v == 1.2341)
    360  " add-subtract
    361  call assert_equal('5.234', printf('%g', 4 + 1.234))
    362  call assert_equal('-6.766', printf('%g', 1.234 - 8))
    363  " mult-div
    364  call assert_equal('4.936', printf('%g', 4 * 1.234))
    365  call assert_equal('0.003241', printf('%g', 4.0 / 1234))
    366  " dict
    367  call assert_equal("{'x': 1.234, 'y': -2.0e20}", string({'x': 1.234, 'y': -2.0e20}))
    368  " list
    369  call assert_equal('[-123.4, 2.0e-20]', string([-123.4, 2.0e-20]))
    370 endfunc
    371 
    372 " vim: shiftwidth=2 sts=2 expandtab