blob: 83258416851a3ab2648ba1b927ee26e409aa751f [file] [log] [blame]
Bram Moolenaar53f16732016-09-07 20:46:39 +02001" Test for v:hlsearch
2
Bram Moolenaar6d91bcb2020-08-12 18:50:36 +02003source check.vim
4
Bram Moolenaar1e115362019-01-09 23:01:02 +01005func Test_hlsearch()
Bram Moolenaar53f16732016-09-07 20:46:39 +02006 new
7 call setline(1, repeat(['aaa'], 10))
8 set hlsearch nolazyredraw
Bram Moolenaar53f16732016-09-07 20:46:39 +02009 " redraw is needed to make hlsearch highlight the matches
10 exe "normal! /aaa\<CR>" | redraw
11 let r1 = screenattr(1, 1)
12 nohlsearch | redraw
13 call assert_notequal(r1, screenattr(1,1))
14 let v:hlsearch=1 | redraw
15 call assert_equal(r1, screenattr(1,1))
16 let v:hlsearch=0 | redraw
17 call assert_notequal(r1, screenattr(1,1))
18 set hlsearch | redraw
19 call assert_equal(r1, screenattr(1,1))
20 let v:hlsearch=0 | redraw
21 call assert_notequal(r1, screenattr(1,1))
22 exe "normal! n" | redraw
23 call assert_equal(r1, screenattr(1,1))
24 let v:hlsearch=0 | redraw
25 call assert_notequal(r1, screenattr(1,1))
26 exe "normal! /\<CR>" | redraw
27 call assert_equal(r1, screenattr(1,1))
28 set nohls
29 exe "normal! /\<CR>" | redraw
30 call assert_notequal(r1, screenattr(1,1))
Bram Moolenaare2e40752020-09-04 21:18:46 +020031 call assert_fails('let v:hlsearch=[]', 'E745:')
Bram Moolenaar53f16732016-09-07 20:46:39 +020032 call garbagecollect(1)
33 call getchar(1)
34 enew!
Bram Moolenaar1e115362019-01-09 23:01:02 +010035endfunc
Bram Moolenaar5b1affe2017-06-17 19:13:49 +020036
37func Test_hlsearch_hangs()
Bram Moolenaar6d91bcb2020-08-12 18:50:36 +020038 CheckFunction reltimefloat
Bram Moolenaar5b1affe2017-06-17 19:13:49 +020039
Paul Ollis65745772022-06-05 16:55:54 +010040 " So, it turns out the Windows 7 implements TimerQueue timers differently
41 " and they can expire *before* the requested time has elapsed. So allow for
42 " the timeout occurring after 80 ms (5 * 16 (the typical clock tick)).
43 if has("win32")
44 let min_timeout = 0.08
45 else
46 let min_timeout = 0.1
47 endif
48
Bram Moolenaar1ef9bbe2017-06-17 20:08:20 +020049 " This pattern takes a long time to match, it should timeout.
Bram Moolenaar09463262017-06-17 20:55:06 +020050 new
51 call setline(1, ['aaa', repeat('abc ', 1000), 'ccc'])
Bram Moolenaar5b1affe2017-06-17 19:13:49 +020052 let start = reltime()
53 set hlsearch nolazyredraw redrawtime=101
Bram Moolenaar1ef9bbe2017-06-17 20:08:20 +020054 let @/ = '\%#=1a*.*X\@<=b*'
Bram Moolenaar5b1affe2017-06-17 19:13:49 +020055 redraw
56 let elapsed = reltimefloat(reltime(start))
Paul Ollis65745772022-06-05 16:55:54 +010057 call assert_true(elapsed > min_timeout)
Bram Moolenaar5b1affe2017-06-17 19:13:49 +020058 call assert_true(elapsed < 1.0)
59 set nohlsearch redrawtime&
Bram Moolenaar09463262017-06-17 20:55:06 +020060 bwipe!
Bram Moolenaar5b1affe2017-06-17 19:13:49 +020061endfunc
Bram Moolenaar7ee3f152018-09-02 15:07:28 +020062
63func Test_hlsearch_eol_highlight()
64 new
65 call append(1, repeat([''], 9))
66 set hlsearch nolazyredraw
67 exe "normal! /$\<CR>" | redraw
68 let attr = screenattr(1, 1)
69 for row in range(2, 10)
70 call assert_equal(attr, screenattr(row, 1), 'in line ' . row)
71 endfor
72 set nohlsearch
73 bwipe!
74endfunc
Bram Moolenaar6d91bcb2020-08-12 18:50:36 +020075
76" vim: shiftwidth=2 sts=2 expandtab