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 | ||||
| 		   c	    Command-line editing | ||||
| 		   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| | ||||
| 		   cvr	    Vim Ex while in overstrike mode |c_<Insert>| | ||||
| 		   cvr	    Vim Ex mode while in overstrike mode |c_<Insert>| | ||||
| 		   ce	    Normal Ex mode |Q| | ||||
| 		   r	    Hit-enter 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) | ||||
| 	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 | ||||
|     // a shell command using some shared library: | ||||
|     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(2, g:n_to_c) | ||||
|   call assert_equal(2, g:c_to_n) | ||||
|   unlet g:n_to_c | ||||
|   unlet g:c_to_n | ||||
|  | ||||
|   let g:n_to_v = 0 | ||||
|   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(1, g:n_to_v) | ||||
|   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 | ||||
|   delfunc TestMode | ||||
| @ -3808,6 +3808,10 @@ func Test_mode_changes() | ||||
|   unlet! g:i_to_n | ||||
|   unlet! g:nori_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 | ||||
|  | ||||
| func Test_recursive_ModeChanged() | ||||
|  | ||||
| @ -755,7 +755,7 @@ func Test_mode() | ||||
|   " Only complete from the current buffer. | ||||
|   set complete=. | ||||
|  | ||||
|   inoremap <F2> <C-R>=Save_mode()<CR> | ||||
|   noremap! <F2> <C-R>=Save_mode()<CR> | ||||
|   xnoremap <F2> <Cmd>call Save_mode()<CR> | ||||
|  | ||||
|   normal! 3G | ||||
| @ -914,17 +914,24 @@ func Test_mode() | ||||
|   exe "normal g\<C-H>\<C-O>\<F2>\<Esc>" | ||||
|   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 feedkeys(":\<insert>\<C-r>=Save_mode()\<CR>",'xt') | ||||
|   call feedkeys(":\<Insert>\<F2>\<CR>", 'xt') | ||||
|   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 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) | ||||
|  | ||||
|   " 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 assert_equal('c-ce', g:current_modes) | ||||
|   " How to test Ex mode? | ||||
|  | ||||
|   " Test mode in operatorfunc (it used to be Operator-pending). | ||||
|   set operatorfunc=OperatorFunc | ||||
| @ -939,14 +946,15 @@ func Test_mode() | ||||
|   call assert_equal('n-niR', g:current_modes) | ||||
|   execute "normal! gR\<C-o>g@l\<Esc>" | ||||
|   call assert_equal('n-niV', g:current_modes) | ||||
|   " Test statusline updates for overstike mode | ||||
|  | ||||
|   " Test statusline updates for overstrike mode | ||||
|   if CanRunVimInTerminal() | ||||
|     let buf = RunVimInTerminal('', {'rows': 12}) | ||||
|     call term_sendkeys(buf, ":set laststatus=2 statusline=%!mode(1)\<CR>") | ||||
|     call term_sendkeys(buf, ":") | ||||
|     call TermWait(buf) | ||||
|     call VerifyScreenDump(buf, 'Test_mode_1', {}) | ||||
|     call term_sendkeys(buf, "\<insert>") | ||||
|     call term_sendkeys(buf, "\<Insert>") | ||||
|     call TermWait(buf) | ||||
|     call VerifyScreenDump(buf, 'Test_mode_2', {}) | ||||
|     call StopVimInTerminal(buf) | ||||
| @ -971,7 +979,7 @@ func Test_mode() | ||||
|   endif | ||||
|  | ||||
|   bwipe! | ||||
|   iunmap <F2> | ||||
|   unmap! <F2> | ||||
|   xunmap <F2> | ||||
|   set complete& | ||||
|   set operatorfunc& | ||||
|  | ||||
| @ -704,6 +704,8 @@ static char *(features[]) = | ||||
|  | ||||
| static int included_patches[] = | ||||
| {   /* Add new patch number below this line */ | ||||
| /**/ | ||||
|     2135, | ||||
| /**/ | ||||
|     2134, | ||||
| /**/ | ||||
|  | ||||
		Reference in New Issue
	
	Block a user