view src/testdir/test_reltime.vim @ 25214:218df177cff8 v8.2.3143

patch 8.2.3143: Vim9: wrong context if lambda called from profiled function Commit: https://github.com/vim/vim/commit/d9162550aa47ca3865a5cadf78ff2212a1d8eca7 Author: Bram Moolenaar <Bram@vim.org> Date: Sun Jul 11 15:26:13 2021 +0200 patch 8.2.3143: Vim9: wrong context if lambda called from profiled function Problem: Vim9: A lambda may be compiled with the wrong context if it is called from a profiled function. Solution: Compile the lambda with and without profiling. (closes #8543)
author Bram Moolenaar <Bram@vim.org>
date Sun, 11 Jul 2021 15:30:03 +0200
parents 2fb397573541
children acda780ffc3e
line wrap: on
line source

" Tests for reltime()

source check.vim
CheckFeature reltime
CheckFeature float

func Test_reltime()
  let now = reltime()
  sleep 10m
  let later = reltime()
  let elapsed = now->reltime()
  call assert_true(reltimestr(elapsed) =~ '0\.0')
  call assert_true(elapsed->reltimestr() != '0.0')
  call assert_true(reltimefloat(elapsed) < 0.1)
  call assert_true(elapsed->reltimefloat() > 0.0)

  let same = reltime(now, now)
  call assert_equal('0.000', split(reltimestr(same))[0][:4])
  call assert_equal(0.0, reltimefloat(same))

  let differs = reltime(now, later)
  call assert_true(reltimestr(differs) =~ '0\.0')
  call assert_true(reltimestr(differs) != '0.0')
  call assert_true(reltimefloat(differs) < 0.1)
  call assert_true(reltimefloat(differs) > 0.0)

  call assert_equal(0, reltime({}))
  call assert_equal(0, reltime({}, {}))
endfunc

" vim: shiftwidth=2 sts=2 expandtab