diff options
| author | Justin M. Keyes <justinkz@gmail.com> | 2019-04-24 11:23:32 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2019-04-24 11:23:32 +0200 |
| commit | 24a9516ff41b69e649f0dac131ad20efbe19eb4b (patch) | |
| tree | 3703fe68b2381407524033959e3e7721d7a7dbdc /src/nvim/testdir/test_syntax.vim | |
| parent | 8c6f5b7f9268087bce8c136e81c1631a8f87abbe (diff) | |
| parent | 37c7c964aef5f0d47c0bd0fb8abb15a5407e4b27 (diff) | |
| download | rneovim-24a9516ff41b69e649f0dac131ad20efbe19eb4b.tar.gz rneovim-24a9516ff41b69e649f0dac131ad20efbe19eb4b.tar.bz2 rneovim-24a9516ff41b69e649f0dac131ad20efbe19eb4b.zip | |
Merge #9906 from janlazo/vim-8.0.0647
vim-patch:8.0.{647,768,797,1085,1092,1107,1133,1408}
Diffstat (limited to 'src/nvim/testdir/test_syntax.vim')
| -rw-r--r-- | src/nvim/testdir/test_syntax.vim | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/src/nvim/testdir/test_syntax.vim b/src/nvim/testdir/test_syntax.vim index 6978faeb7b..850947f89f 100644 --- a/src/nvim/testdir/test_syntax.vim +++ b/src/nvim/testdir/test_syntax.vim @@ -503,3 +503,37 @@ func Test_syn_wrong_z_one() " call test_override("ALL", 0) bwipe! endfunc + +func Test_syntax_hangs() + if !has('reltime') || !has('float') || !has('syntax') + return + endif + + " This pattern takes a long time to match, it should timeout. + new + call setline(1, ['aaa', repeat('abc ', 1000), 'ccc']) + let start = reltime() + set nolazyredraw redrawtime=101 + syn match Error /\%#=1a*.*X\@<=b*/ + redraw + let elapsed = reltimefloat(reltime(start)) + call assert_true(elapsed > 0.1) + call assert_true(elapsed < 1.0) + + " second time syntax HL is disabled + let start = reltime() + redraw + let elapsed = reltimefloat(reltime(start)) + call assert_true(elapsed < 0.1) + + " after CTRL-L the timeout flag is reset + let start = reltime() + exe "normal \<C-L>" + redraw + let elapsed = reltimefloat(reltime(start)) + call assert_true(elapsed > 0.1) + call assert_true(elapsed < 1.0) + + set redrawtime& + bwipe! +endfunc |