patch 9.0.2135: No test for mode() when executing Ex commands
Problem:  No test for mode() when executing Ex commands
Solution: Add some test cases and simplify several other test cases.
          Also add a few more test cases for ModeChanged.
closes: #13588
Signed-off-by: zeertzjq <zeertzjq@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
			
			
This commit is contained in:
		
				
					committed by
					
						 Christian Brabandt
						Christian Brabandt
					
				
			
			
				
	
			
			
			
						parent
						
							ffd6d31cb2
						
					
				
				
					commit
					fcaeb3d42b
				
			| @ -6413,9 +6413,9 @@ mode([expr])	Return a string that indicates the current mode. | |||||||
| 		   Rvx	    Virtual Replace mode |i_CTRL-X| completion | 		   Rvx	    Virtual Replace mode |i_CTRL-X| completion | ||||||
| 		   c	    Command-line editing | 		   c	    Command-line editing | ||||||
| 		   ct	    Command-line editing via Terminal-Job mode | 		   ct	    Command-line editing via Terminal-Job mode | ||||||
| 		   cr	    Command-line while in overstrike mode |c_<Insert>| | 		   cr	    Command-line editing overstrike mode |c_<Insert>| | ||||||
| 		   cv	    Vim Ex mode |gQ| | 		   cv	    Vim Ex mode |gQ| | ||||||
| 		   cvr	    Vim Ex while in overstrike mode |c_<Insert>| | 		   cvr	    Vim Ex mode while in overstrike mode |c_<Insert>| | ||||||
| 		   ce	    Normal Ex mode |Q| | 		   ce	    Normal Ex mode |Q| | ||||||
| 		   r	    Hit-enter prompt | 		   r	    Hit-enter prompt | ||||||
| 		   rm	    The -- more -- prompt | 		   rm	    The -- more -- prompt | ||||||
|  | |||||||
| @ -9733,7 +9733,7 @@ f_setenv(typval_T *argvars, typval_T *rettv UNUSED) | |||||||
|     if (in_vim9script() && check_for_string_arg(argvars, 0) == FAIL) |     if (in_vim9script() && check_for_string_arg(argvars, 0) == FAIL) | ||||||
| 	return; | 	return; | ||||||
|  |  | ||||||
|     // seting an environment variable may be dangerous, e.g. you could |     // setting an environment variable may be dangerous, e.g. you could | ||||||
|     // setenv GCONV_PATH=/tmp and then have iconv() unexpectedly call |     // setenv GCONV_PATH=/tmp and then have iconv() unexpectedly call | ||||||
|     // a shell command using some shared library: |     // a shell command using some shared library: | ||||||
|     if (check_restricted() || check_secure()) |     if (check_restricted() || check_secure()) | ||||||
|  | |||||||
| @ -3780,8 +3780,6 @@ func Test_mode_changes() | |||||||
|   call assert_equal(len(g:mode_seq) - 1, g:index) |   call assert_equal(len(g:mode_seq) - 1, g:index) | ||||||
|   call assert_equal(2, g:n_to_c) |   call assert_equal(2, g:n_to_c) | ||||||
|   call assert_equal(2, g:c_to_n) |   call assert_equal(2, g:c_to_n) | ||||||
|   unlet g:n_to_c |  | ||||||
|   unlet g:c_to_n |  | ||||||
|  |  | ||||||
|   let g:n_to_v = 0 |   let g:n_to_v = 0 | ||||||
|   au ModeChanged n:v let g:n_to_v += 1 |   au ModeChanged n:v let g:n_to_v += 1 | ||||||
| @ -3792,8 +3790,10 @@ func Test_mode_changes() | |||||||
|   call assert_equal(len(g:mode_seq) - 1, g:index) |   call assert_equal(len(g:mode_seq) - 1, g:index) | ||||||
|   call assert_equal(1, g:n_to_v) |   call assert_equal(1, g:n_to_v) | ||||||
|   call assert_equal(1, g:v_to_n) |   call assert_equal(1, g:v_to_n) | ||||||
|   unlet g:n_to_v |  | ||||||
|   unlet g:v_to_n |   let g:mode_seq += ['c', 'cr', 'c', 'cr', 'n'] | ||||||
|  |   call feedkeys(":\<Insert>\<Insert>\<Insert>\<CR>", 'tnix') | ||||||
|  |   call assert_equal(len(g:mode_seq) - 1, g:index) | ||||||
|  |  | ||||||
|   au! ModeChanged |   au! ModeChanged | ||||||
|   delfunc TestMode |   delfunc TestMode | ||||||
| @ -3808,6 +3808,10 @@ func Test_mode_changes() | |||||||
|   unlet! g:i_to_n |   unlet! g:i_to_n | ||||||
|   unlet! g:nori_to_any |   unlet! g:nori_to_any | ||||||
|   unlet! g:i_to_any |   unlet! g:i_to_any | ||||||
|  |   unlet! g:n_to_c | ||||||
|  |   unlet! g:c_to_n | ||||||
|  |   unlet! g:n_to_v | ||||||
|  |   unlet! g:v_to_n | ||||||
| endfunc | endfunc | ||||||
|  |  | ||||||
| func Test_recursive_ModeChanged() | func Test_recursive_ModeChanged() | ||||||
|  | |||||||
| @ -755,7 +755,7 @@ func Test_mode() | |||||||
|   " Only complete from the current buffer. |   " Only complete from the current buffer. | ||||||
|   set complete=. |   set complete=. | ||||||
|  |  | ||||||
|   inoremap <F2> <C-R>=Save_mode()<CR> |   noremap! <F2> <C-R>=Save_mode()<CR> | ||||||
|   xnoremap <F2> <Cmd>call Save_mode()<CR> |   xnoremap <F2> <Cmd>call Save_mode()<CR> | ||||||
|  |  | ||||||
|   normal! 3G |   normal! 3G | ||||||
| @ -914,17 +914,24 @@ func Test_mode() | |||||||
|   exe "normal g\<C-H>\<C-O>\<F2>\<Esc>" |   exe "normal g\<C-H>\<C-O>\<F2>\<Esc>" | ||||||
|   call assert_equal("\<C-V>-\<C-V>s", g:current_modes) |   call assert_equal("\<C-V>-\<C-V>s", g:current_modes) | ||||||
|  |  | ||||||
|   call feedkeys(":echo \<C-R>=Save_mode()\<C-U>\<CR>", 'xt') |   call feedkeys(":\<F2>\<CR>", 'xt') | ||||||
|   call assert_equal('c-c', g:current_modes) |   call assert_equal('c-c', g:current_modes) | ||||||
|   call feedkeys(":\<insert>\<C-r>=Save_mode()\<CR>",'xt') |   call feedkeys(":\<Insert>\<F2>\<CR>", 'xt') | ||||||
|   call assert_equal("c-cr", g:current_modes) |   call assert_equal("c-cr", g:current_modes) | ||||||
|   call feedkeys("gQecho \<C-R>=Save_mode()\<CR>\<CR>vi\<CR>", 'xt') |   call feedkeys("gQ\<F2>vi\<CR>", 'xt') | ||||||
|   call assert_equal('c-cv', g:current_modes) |   call assert_equal('c-cv', g:current_modes) | ||||||
|   call feedkeys("gQ\<insert>\<C-r>=Save_mode()\<CR>",'xt') |   call feedkeys("gQ\<Insert>\<F2>vi\<CR>", 'xt') | ||||||
|   call assert_equal("c-cvr", g:current_modes) |   call assert_equal("c-cvr", g:current_modes) | ||||||
|  |  | ||||||
|  |   " Executing commands in Vim Ex mode should return "cv", never "cvr", | ||||||
|  |   " as Cmdline editing has already ended. | ||||||
|  |   call feedkeys("gQcall Save_mode()\<CR>vi\<CR>", 'xt') | ||||||
|  |   call assert_equal('c-cv', g:current_modes) | ||||||
|  |   call feedkeys("gQ\<Insert>call Save_mode()\<CR>vi\<CR>", 'xt') | ||||||
|  |   call assert_equal('c-cv', g:current_modes) | ||||||
|  |  | ||||||
|   call feedkeys("Qcall Save_mode()\<CR>vi\<CR>", 'xt') |   call feedkeys("Qcall Save_mode()\<CR>vi\<CR>", 'xt') | ||||||
|   call assert_equal('c-ce', g:current_modes) |   call assert_equal('c-ce', g:current_modes) | ||||||
|   " How to test Ex mode? |  | ||||||
|  |  | ||||||
|   " Test mode in operatorfunc (it used to be Operator-pending). |   " Test mode in operatorfunc (it used to be Operator-pending). | ||||||
|   set operatorfunc=OperatorFunc |   set operatorfunc=OperatorFunc | ||||||
| @ -939,14 +946,15 @@ func Test_mode() | |||||||
|   call assert_equal('n-niR', g:current_modes) |   call assert_equal('n-niR', g:current_modes) | ||||||
|   execute "normal! gR\<C-o>g@l\<Esc>" |   execute "normal! gR\<C-o>g@l\<Esc>" | ||||||
|   call assert_equal('n-niV', g:current_modes) |   call assert_equal('n-niV', g:current_modes) | ||||||
|   " Test statusline updates for overstike mode |  | ||||||
|  |   " Test statusline updates for overstrike mode | ||||||
|   if CanRunVimInTerminal() |   if CanRunVimInTerminal() | ||||||
|     let buf = RunVimInTerminal('', {'rows': 12}) |     let buf = RunVimInTerminal('', {'rows': 12}) | ||||||
|     call term_sendkeys(buf, ":set laststatus=2 statusline=%!mode(1)\<CR>") |     call term_sendkeys(buf, ":set laststatus=2 statusline=%!mode(1)\<CR>") | ||||||
|     call term_sendkeys(buf, ":") |     call term_sendkeys(buf, ":") | ||||||
|     call TermWait(buf) |     call TermWait(buf) | ||||||
|     call VerifyScreenDump(buf, 'Test_mode_1', {}) |     call VerifyScreenDump(buf, 'Test_mode_1', {}) | ||||||
|     call term_sendkeys(buf, "\<insert>") |     call term_sendkeys(buf, "\<Insert>") | ||||||
|     call TermWait(buf) |     call TermWait(buf) | ||||||
|     call VerifyScreenDump(buf, 'Test_mode_2', {}) |     call VerifyScreenDump(buf, 'Test_mode_2', {}) | ||||||
|     call StopVimInTerminal(buf) |     call StopVimInTerminal(buf) | ||||||
| @ -971,7 +979,7 @@ func Test_mode() | |||||||
|   endif |   endif | ||||||
|  |  | ||||||
|   bwipe! |   bwipe! | ||||||
|   iunmap <F2> |   unmap! <F2> | ||||||
|   xunmap <F2> |   xunmap <F2> | ||||||
|   set complete& |   set complete& | ||||||
|   set operatorfunc& |   set operatorfunc& | ||||||
|  | |||||||
| @ -704,6 +704,8 @@ static char *(features[]) = | |||||||
|  |  | ||||||
| static int included_patches[] = | static int included_patches[] = | ||||||
| {   /* Add new patch number below this line */ | {   /* Add new patch number below this line */ | ||||||
|  | /**/ | ||||||
|  |     2135, | ||||||
| /**/ | /**/ | ||||||
|     2134, |     2134, | ||||||
| /**/ | /**/ | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user