2016-08-04 20:05:50 +02:00
|
|
|
" Tests specifically for the GUI
|
|
|
|
|
2017-08-13 20:26:20 +02:00
|
|
|
source shared.vim
|
2019-08-07 23:07:07 +02:00
|
|
|
source check.vim
|
|
|
|
CheckCanRunGui
|
2016-08-04 20:05:50 +02:00
|
|
|
|
2017-02-23 19:32:47 +01:00
|
|
|
source setup_gui.vim
|
2016-08-09 22:58:21 +02:00
|
|
|
|
2017-02-23 19:32:47 +01:00
|
|
|
func Setup()
|
|
|
|
call GUISetUpCommon()
|
2016-08-09 22:58:21 +02:00
|
|
|
endfunc
|
|
|
|
|
|
|
|
func TearDown()
|
2017-02-23 19:32:47 +01:00
|
|
|
call GUITearDownCommon()
|
2016-08-04 20:05:50 +02:00
|
|
|
endfunc
|
|
|
|
|
|
|
|
" Test for resetting "secure" flag after GUI has started.
|
2018-02-27 17:17:42 +01:00
|
|
|
" Must be run first, since it starts the GUI on Unix.
|
2016-08-04 20:05:50 +02:00
|
|
|
func Test_1_set_secure()
|
|
|
|
set exrc secure
|
|
|
|
gui -f
|
|
|
|
call assert_equal(1, has('gui_running'))
|
|
|
|
endfunc
|
|
|
|
|
2017-03-05 13:27:25 +01:00
|
|
|
" As for non-GUI, a balloon_show() test was already added with patch 8.0.0401
|
|
|
|
func Test_balloon_show()
|
|
|
|
if has('balloon_eval')
|
|
|
|
" This won't do anything but must not crash either.
|
|
|
|
call balloon_show('hi!')
|
|
|
|
endif
|
|
|
|
endfunc
|
|
|
|
|
2017-03-12 17:10:33 +01:00
|
|
|
func Test_colorscheme()
|
2020-04-12 15:11:06 +02:00
|
|
|
call assert_equal('16777216', &t_Co)
|
|
|
|
|
2017-03-12 17:10:33 +01:00
|
|
|
let colorscheme_saved = exists('g:colors_name') ? g:colors_name : 'default'
|
2018-04-30 15:40:48 +02:00
|
|
|
let g:color_count = 0
|
|
|
|
augroup TestColors
|
|
|
|
au!
|
|
|
|
au ColorScheme * let g:color_count += 1| let g:after_colors = g:color_count
|
|
|
|
au ColorSchemePre * let g:color_count += 1 |let g:before_colors = g:color_count
|
|
|
|
augroup END
|
2017-03-12 17:10:33 +01:00
|
|
|
|
|
|
|
colorscheme torte
|
|
|
|
redraw!
|
|
|
|
call assert_equal('dark', &background)
|
2018-04-30 15:40:48 +02:00
|
|
|
call assert_equal(1, g:before_colors)
|
|
|
|
call assert_equal(2, g:after_colors)
|
2019-01-08 21:05:51 +01:00
|
|
|
call assert_equal("\ntorte", execute('colorscheme'))
|
|
|
|
|
|
|
|
let a = substitute(execute('hi Search'), "\n\\s\\+", ' ', 'g')
|
|
|
|
call assert_match("\nSearch xxx term=reverse ctermfg=0 ctermbg=12 gui=bold guifg=Black guibg=Red", a)
|
|
|
|
|
|
|
|
call assert_fails('colorscheme does_not_exist', 'E185:')
|
2017-03-12 17:10:33 +01:00
|
|
|
|
|
|
|
exec 'colorscheme' colorscheme_saved
|
2018-04-30 15:40:48 +02:00
|
|
|
augroup TestColors
|
|
|
|
au!
|
|
|
|
augroup END
|
|
|
|
unlet g:color_count g:after_colors g:before_colors
|
2017-03-12 17:10:33 +01:00
|
|
|
redraw!
|
|
|
|
endfunc
|
|
|
|
|
2017-02-06 22:11:55 +01:00
|
|
|
func Test_getfontname_with_arg()
|
2017-02-17 13:44:48 +01:00
|
|
|
let skipped = ''
|
|
|
|
|
2017-02-23 19:32:47 +01:00
|
|
|
if !g:x11_based_gui
|
|
|
|
let skipped = g:not_implemented
|
2017-02-17 13:44:48 +01:00
|
|
|
elseif has('gui_athena') || has('gui_motif')
|
2017-02-06 22:11:55 +01:00
|
|
|
" Invalid font name. The result should be an empty string.
|
|
|
|
call assert_equal('', getfontname('notexist'))
|
|
|
|
|
|
|
|
" Valid font name. This is usually the real name of 7x13 by default.
|
2017-03-12 17:10:33 +01:00
|
|
|
let fname = '-Misc-Fixed-Medium-R-Normal--13-120-75-75-C-70-ISO8859-1'
|
|
|
|
call assert_match(fname, getfontname(fname))
|
2017-02-06 22:11:55 +01:00
|
|
|
|
|
|
|
elseif has('gui_gtk2') || has('gui_gnome') || has('gui_gtk3')
|
|
|
|
" Invalid font name. The result should be the name plus the default size.
|
|
|
|
call assert_equal('notexist 10', getfontname('notexist'))
|
2020-03-25 22:23:46 +01:00
|
|
|
call assert_equal('', getfontname('*'))
|
2017-02-06 22:11:55 +01:00
|
|
|
|
|
|
|
" Valid font name. This is usually the real name of Monospace by default.
|
2017-02-17 13:44:48 +01:00
|
|
|
let fname = 'Bitstream Vera Sans Mono 12'
|
|
|
|
call assert_equal(fname, getfontname(fname))
|
|
|
|
endif
|
|
|
|
|
|
|
|
if !empty(skipped)
|
|
|
|
throw skipped
|
2017-02-06 22:11:55 +01:00
|
|
|
endif
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
func Test_getfontname_without_arg()
|
2017-02-17 13:44:48 +01:00
|
|
|
let skipped = ''
|
|
|
|
|
|
|
|
let fname = getfontname()
|
|
|
|
|
2017-02-23 19:32:47 +01:00
|
|
|
if !g:x11_based_gui
|
|
|
|
let skipped = g:not_implemented
|
2017-02-17 13:44:48 +01:00
|
|
|
elseif has('gui_kde')
|
2017-02-06 22:11:55 +01:00
|
|
|
" 'expected' is the value specified by SetUp() above.
|
2017-02-17 13:44:48 +01:00
|
|
|
call assert_equal('Courier 10 Pitch/8/-1/5/50/0/0/0/0/0', fname)
|
2017-02-06 22:11:55 +01:00
|
|
|
elseif has('gui_athena') || has('gui_motif')
|
2017-03-12 17:10:33 +01:00
|
|
|
" 'expected' is DFLT_FONT of gui_x11.c or its real name.
|
|
|
|
let pat = '\(7x13\)\|\(\c-Misc-Fixed-Medium-R-Normal--13-120-75-75-C-70-ISO8859-1\)'
|
|
|
|
call assert_match(pat, fname)
|
2017-02-06 22:11:55 +01:00
|
|
|
elseif has('gui_gtk2') || has('gui_gnome') || has('gui_gtk3')
|
|
|
|
" 'expected' is DEFAULT_FONT of gui_gtk_x11.c.
|
2017-02-17 13:44:48 +01:00
|
|
|
call assert_equal('Monospace 10', fname)
|
|
|
|
endif
|
|
|
|
|
|
|
|
if !empty(skipped)
|
|
|
|
throw skipped
|
2017-02-06 22:11:55 +01:00
|
|
|
endif
|
|
|
|
endfunc
|
|
|
|
|
2017-03-12 17:10:33 +01:00
|
|
|
func Test_getwinpos()
|
|
|
|
call assert_match('Window position: X \d\+, Y \d\+', execute('winpos'))
|
|
|
|
call assert_true(getwinposx() >= 0)
|
|
|
|
call assert_true(getwinposy() >= 0)
|
2018-05-14 21:31:08 +02:00
|
|
|
call assert_equal([getwinposx(), getwinposy()], getwinpos())
|
2017-03-12 17:10:33 +01:00
|
|
|
endfunc
|
|
|
|
|
2017-02-26 15:08:21 +01:00
|
|
|
func Test_quoteplus()
|
|
|
|
let skipped = ''
|
|
|
|
|
|
|
|
if !g:x11_based_gui
|
|
|
|
let skipped = g:not_supported . 'quoteplus'
|
|
|
|
else
|
|
|
|
let quoteplus_saved = @+
|
|
|
|
|
|
|
|
let test_call = 'Can you hear me?'
|
|
|
|
let test_response = 'Yes, I can.'
|
2019-08-14 21:12:05 +02:00
|
|
|
let vim_exe = GetVimCommand()
|
2017-02-26 15:08:21 +01:00
|
|
|
let testee = 'VIMRUNTIME=' . $VIMRUNTIME . '; export VIMRUNTIME;'
|
2019-08-14 21:12:05 +02:00
|
|
|
\ . vim_exe . ' --noplugin --not-a-term -c ''%s'''
|
2017-03-01 18:30:34 +01:00
|
|
|
" Ignore the "failed to create input context" error.
|
2017-03-04 13:32:10 +01:00
|
|
|
let cmd = 'call test_ignore_error("E285") | '
|
|
|
|
\ . 'gui -f | '
|
|
|
|
\ . 'call feedkeys("'
|
2017-02-26 15:08:21 +01:00
|
|
|
\ . '\"+p'
|
|
|
|
\ . ':s/' . test_call . '/' . test_response . '/\<CR>'
|
|
|
|
\ . '\"+yis'
|
|
|
|
\ . ':q!\<CR>", "tx")'
|
2017-03-04 13:32:10 +01:00
|
|
|
let run_vimtest = printf(testee, cmd)
|
2017-02-26 15:08:21 +01:00
|
|
|
|
|
|
|
" Set the quoteplus register to test_call, and another gvim will launched.
|
|
|
|
" Then, it first tries to paste the content of its own quotedplus register
|
2018-05-14 21:31:08 +02:00
|
|
|
" onto it. Second, it tries to substitute test_response for the pasted
|
2017-02-26 15:08:21 +01:00
|
|
|
" sentence. If the sentence is identical to test_call, the substitution
|
|
|
|
" should succeed. Third, it tries to yank the result of the substitution
|
|
|
|
" to its own quoteplus register, and last it quits. When system()
|
|
|
|
" returns, the content of the quoteplus register should be identical to
|
|
|
|
" test_response if those quoteplus registers are synchronized properly
|
|
|
|
" with/through the X11 clipboard.
|
|
|
|
let @+ = test_call
|
|
|
|
call system(run_vimtest)
|
|
|
|
call assert_equal(test_response, @+)
|
|
|
|
|
|
|
|
let @+ = quoteplus_saved
|
|
|
|
endif
|
|
|
|
|
|
|
|
if !empty(skipped)
|
|
|
|
throw skipped
|
|
|
|
endif
|
|
|
|
endfunc
|
|
|
|
|
2017-03-12 17:10:33 +01:00
|
|
|
func Test_set_background()
|
|
|
|
let background_saved = &background
|
|
|
|
|
|
|
|
set background&
|
|
|
|
call assert_equal('light', &background)
|
|
|
|
|
|
|
|
set background=dark
|
|
|
|
call assert_equal('dark', &background)
|
|
|
|
|
|
|
|
let &background = background_saved
|
|
|
|
endfunc
|
|
|
|
|
2017-03-05 13:27:25 +01:00
|
|
|
func Test_set_balloondelay()
|
|
|
|
if !exists('+balloondelay')
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
|
|
|
|
let balloondelay_saved = &balloondelay
|
|
|
|
|
|
|
|
" Check if the default value is identical to that described in the manual.
|
|
|
|
set balloondelay&
|
|
|
|
call assert_equal(600, &balloondelay)
|
|
|
|
|
|
|
|
" Edge cases
|
|
|
|
|
|
|
|
" XXX This fact should be hidden so that people won't be tempted to write
|
|
|
|
" plugin/TimeMachine.vim. TODO Add reasonable range checks to the source
|
|
|
|
" code.
|
|
|
|
set balloondelay=-1
|
|
|
|
call assert_equal(-1, &balloondelay)
|
|
|
|
|
|
|
|
" Though it's possible to interpret the zero delay to be 'as soon as
|
|
|
|
" possible' or even 'indefinite', its actual meaning depends on the GUI
|
|
|
|
" toolkit in use after all.
|
|
|
|
set balloondelay=0
|
|
|
|
call assert_equal(0, &balloondelay)
|
|
|
|
|
|
|
|
set balloondelay=1
|
|
|
|
call assert_equal(1, &balloondelay)
|
|
|
|
|
|
|
|
" Since p_bdelay is of type long currently, the upper bound can be
|
|
|
|
" impractically huge and machine-dependent. Practically, it's sufficient
|
2017-03-05 13:48:13 +01:00
|
|
|
" to check if balloondelay works with 0x7fffffff (32 bits) for now.
|
|
|
|
set balloondelay=2147483647
|
|
|
|
call assert_equal(2147483647, &balloondelay)
|
2017-03-05 13:27:25 +01:00
|
|
|
|
|
|
|
let &balloondelay = balloondelay_saved
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
func Test_set_ballooneval()
|
|
|
|
if !exists('+ballooneval')
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
|
|
|
|
let ballooneval_saved = &ballooneval
|
|
|
|
|
|
|
|
set ballooneval&
|
|
|
|
call assert_equal(0, &ballooneval)
|
|
|
|
|
|
|
|
set ballooneval
|
|
|
|
call assert_notequal(0, &ballooneval)
|
|
|
|
|
|
|
|
set noballooneval
|
|
|
|
call assert_equal(0, &ballooneval)
|
|
|
|
|
|
|
|
let &ballooneval = ballooneval_saved
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
func Test_set_balloonexpr()
|
|
|
|
if !exists('+balloonexpr')
|
|
|
|
return
|
|
|
|
endif
|
|
|
|
|
|
|
|
let balloonexpr_saved = &balloonexpr
|
|
|
|
|
|
|
|
" Default value
|
|
|
|
set balloonexpr&
|
|
|
|
call assert_equal('', &balloonexpr)
|
|
|
|
|
|
|
|
" User-defined function
|
|
|
|
new
|
|
|
|
func MyBalloonExpr()
|
|
|
|
return 'Cursor is at line ' . v:beval_lnum .
|
|
|
|
\', column ' . v:beval_col .
|
|
|
|
\ ' of file ' . bufname(v:beval_bufnr) .
|
|
|
|
\ ' on word "' . v:beval_text . '"' .
|
|
|
|
\ ' in window ' . v:beval_winid . ' (#' . v:beval_winnr . ')'
|
|
|
|
endfunc
|
|
|
|
setl balloonexpr=MyBalloonExpr()
|
|
|
|
setl ballooneval
|
|
|
|
call assert_equal('MyBalloonExpr()', &balloonexpr)
|
|
|
|
" TODO Read non-empty text, place the pointer at a character of a word,
|
2018-05-14 21:31:08 +02:00
|
|
|
" and check if the content of the balloon is the same as what is expected.
|
2017-03-05 13:27:25 +01:00
|
|
|
" Also, check if textlock works as expected.
|
|
|
|
setl balloonexpr&
|
|
|
|
call assert_equal('', &balloonexpr)
|
|
|
|
delfunc MyBalloonExpr
|
|
|
|
bwipe!
|
|
|
|
|
|
|
|
" Multiline support
|
|
|
|
if has('balloon_multiline')
|
|
|
|
" Multiline balloon using NL
|
|
|
|
new
|
|
|
|
func MyBalloonFuncForMultilineUsingNL()
|
|
|
|
return "Multiline\nSuppported\nBalloon\nusing NL"
|
|
|
|
endfunc
|
|
|
|
setl balloonexpr=MyBalloonFuncForMultilineUsingNL()
|
|
|
|
setl ballooneval
|
|
|
|
call assert_equal('MyBalloonFuncForMultilineUsingNL()', &balloonexpr)
|
|
|
|
" TODO Read non-empty text, place the pointer at a character of a word,
|
2018-05-14 21:31:08 +02:00
|
|
|
" and check if the content of the balloon is the same as what is
|
2017-03-05 13:27:25 +01:00
|
|
|
" expected. Also, check if textlock works as expected.
|
|
|
|
setl balloonexpr&
|
|
|
|
delfunc MyBalloonFuncForMultilineUsingNL
|
|
|
|
bwipe!
|
|
|
|
|
|
|
|
" Multiline balloon using List
|
|
|
|
new
|
|
|
|
func MyBalloonFuncForMultilineUsingList()
|
|
|
|
return [ 'Multiline', 'Suppported', 'Balloon', 'using List' ]
|
|
|
|
endfunc
|
|
|
|
setl balloonexpr=MyBalloonFuncForMultilineUsingList()
|
|
|
|
setl ballooneval
|
|
|
|
call assert_equal('MyBalloonFuncForMultilineUsingList()', &balloonexpr)
|
|
|
|
" TODO Read non-empty text, place the pointer at a character of a word,
|
2018-05-14 21:31:08 +02:00
|
|
|
" and check if the content of the balloon is the same as what is
|
2017-03-05 13:27:25 +01:00
|
|
|
" expected. Also, check if textlock works as expected.
|
|
|
|
setl balloonexpr&
|
|
|
|
delfunc MyBalloonFuncForMultilineUsingList
|
|
|
|
bwipe!
|
|
|
|
endif
|
|
|
|
|
|
|
|
let &balloonexpr = balloonexpr_saved
|
|
|
|
endfunc
|
|
|
|
|
2017-03-12 17:10:33 +01:00
|
|
|
" Invalid arguments are tested with test_options in conjunction with segfaults
|
|
|
|
" caused by them (Patch 8.0.0357, 24922ec233).
|
|
|
|
func Test_set_guicursor()
|
|
|
|
let guicursor_saved = &guicursor
|
|
|
|
|
|
|
|
let default = [
|
|
|
|
\ "n-v-c:block-Cursor/lCursor",
|
|
|
|
\ "ve:ver35-Cursor",
|
|
|
|
\ "o:hor50-Cursor",
|
|
|
|
\ "i-ci:ver25-Cursor/lCursor",
|
|
|
|
\ "r-cr:hor20-Cursor/lCursor",
|
|
|
|
\ "sm:block-Cursor-blinkwait175-blinkoff150-blinkon175"
|
|
|
|
\ ]
|
|
|
|
|
|
|
|
" Default Value
|
|
|
|
set guicursor&
|
|
|
|
call assert_equal(join(default, ','), &guicursor)
|
|
|
|
|
|
|
|
" Argument List Example 1
|
|
|
|
let opt_list = copy(default)
|
|
|
|
let opt_list[0] = "n-c-v:block-nCursor"
|
|
|
|
exec "set guicursor=" . join(opt_list, ',')
|
|
|
|
call assert_equal(join(opt_list, ','), &guicursor)
|
|
|
|
unlet opt_list
|
|
|
|
|
|
|
|
" Argument List Example 2
|
|
|
|
let opt_list = copy(default)
|
|
|
|
let opt_list[3] = "i-ci:ver30-iCursor-blinkwait300-blinkon200-blinkoff150"
|
|
|
|
exec "set guicursor=" . join(opt_list, ',')
|
|
|
|
call assert_equal(join(opt_list, ','), &guicursor)
|
|
|
|
unlet opt_list
|
|
|
|
|
|
|
|
" 'a' Mode
|
|
|
|
set guicursor&
|
|
|
|
let &guicursor .= ',a:blinkon0'
|
|
|
|
call assert_equal(join(default, ',') . ",a:blinkon0", &guicursor)
|
|
|
|
|
|
|
|
let &guicursor = guicursor_saved
|
|
|
|
endfunc
|
|
|
|
|
2017-02-09 16:06:17 +01:00
|
|
|
func Test_set_guifont()
|
2017-02-17 13:44:48 +01:00
|
|
|
let skipped = ''
|
|
|
|
|
|
|
|
let guifont_saved = &guifont
|
2017-02-09 16:06:17 +01:00
|
|
|
if has('xfontset')
|
|
|
|
" Prevent 'guifontset' from canceling 'guifont'.
|
2017-02-17 13:44:48 +01:00
|
|
|
let guifontset_saved = &guifontset
|
2017-02-09 16:06:17 +01:00
|
|
|
set guifontset=
|
|
|
|
endif
|
|
|
|
|
2017-02-23 19:32:47 +01:00
|
|
|
if !g:x11_based_gui
|
|
|
|
let skipped = g:not_implemented
|
2017-02-17 13:44:48 +01:00
|
|
|
elseif has('gui_athena') || has('gui_motif')
|
2017-02-09 16:06:17 +01:00
|
|
|
" Non-empty font list with invalid font names.
|
|
|
|
"
|
|
|
|
" This test is twofold: (1) It checks if the command fails as expected
|
|
|
|
" when there are no loadable fonts found in the list. (2) It checks if
|
|
|
|
" 'guifont' remains the same after the command loads none of the fonts
|
|
|
|
" listed.
|
2017-02-17 13:44:48 +01:00
|
|
|
let flist = &guifont
|
2017-02-09 16:06:17 +01:00
|
|
|
call assert_fails('set guifont=-notexist1-*,-notexist2-*')
|
2017-02-17 13:44:48 +01:00
|
|
|
call assert_equal(flist, &guifont)
|
2017-02-09 16:06:17 +01:00
|
|
|
|
|
|
|
" Non-empty font list with a valid font name. Should pick up the first
|
|
|
|
" valid font.
|
|
|
|
set guifont=-notexist1-*,fixed,-notexist2-*
|
2017-03-12 17:10:33 +01:00
|
|
|
let pat = '\(fixed\)\|\(\c-Misc-Fixed-Medium-R-SemiCondensed--13-120-75-75-C-60-ISO8859-1\)'
|
|
|
|
call assert_match(pat, getfontname())
|
2017-02-09 16:06:17 +01:00
|
|
|
|
|
|
|
" Empty list. Should fallback to the built-in default.
|
|
|
|
set guifont=
|
2017-03-12 17:10:33 +01:00
|
|
|
let pat = '\(7x13\)\|\(\c-Misc-Fixed-Medium-R-Normal--13-120-75-75-C-70-ISO8859-1\)'
|
|
|
|
call assert_match(pat, getfontname())
|
2017-02-09 16:06:17 +01:00
|
|
|
|
|
|
|
elseif has('gui_gtk2') || has('gui_gnome') || has('gui_gtk3')
|
|
|
|
" For GTK, what we refer to as 'font names' in our manual are actually
|
|
|
|
" 'initial font patterns'. A valid font which matches the 'canonical font
|
|
|
|
" pattern' constructed from a given 'initial pattern' is to be looked up
|
|
|
|
" and loaded. That explains why the GTK GUIs appear to accept 'invalid
|
|
|
|
" font names'.
|
|
|
|
"
|
|
|
|
" Non-empty list. Should always pick up the first element, no matter how
|
|
|
|
" strange it is, as explained above.
|
|
|
|
set guifont=(´・ω・`)\ 12,Courier\ 12
|
|
|
|
call assert_equal('(´・ω・`) 12', getfontname())
|
|
|
|
|
|
|
|
" Empty list. Should fallback to the built-in default.
|
|
|
|
set guifont=
|
|
|
|
call assert_equal('Monospace 10', getfontname())
|
|
|
|
endif
|
|
|
|
|
2020-04-06 21:35:05 +02:00
|
|
|
if has('win32')
|
|
|
|
" Invalid font names are accepted in GTK GUI
|
|
|
|
call assert_fails('set guifont=xa1bc23d7f', 'E596:')
|
|
|
|
endif
|
|
|
|
|
2017-02-09 16:06:17 +01:00
|
|
|
if has('xfontset')
|
2017-02-17 13:44:48 +01:00
|
|
|
let &guifontset = guifontset_saved
|
2017-02-09 16:06:17 +01:00
|
|
|
endif
|
2017-02-17 13:44:48 +01:00
|
|
|
let &guifont = guifont_saved
|
2017-02-09 16:06:17 +01:00
|
|
|
|
2017-02-17 13:44:48 +01:00
|
|
|
if !empty(skipped)
|
|
|
|
throw skipped
|
2017-02-09 16:06:17 +01:00
|
|
|
endif
|
|
|
|
endfunc
|
|
|
|
|
2017-02-12 19:59:08 +01:00
|
|
|
func Test_set_guifontset()
|
2019-09-08 18:58:44 +02:00
|
|
|
CheckFeature xfontset
|
2017-02-17 13:44:48 +01:00
|
|
|
let skipped = ''
|
2017-02-12 19:59:08 +01:00
|
|
|
|
2020-04-06 21:35:05 +02:00
|
|
|
call assert_fails('set guifontset=*', 'E597:')
|
|
|
|
|
2019-09-08 18:58:44 +02:00
|
|
|
let ctype_saved = v:ctype
|
|
|
|
|
|
|
|
" First, since XCreateFontSet(3) is very sensitive to locale, fonts must
|
|
|
|
" be chosen meticulously.
|
|
|
|
let font_head = '-misc-fixed-medium-r-normal--14'
|
|
|
|
|
|
|
|
let font_aw70 = font_head . '-130-75-75-c-70'
|
|
|
|
let font_aw140 = font_head . '-130-75-75-c-140'
|
|
|
|
|
|
|
|
let font_jisx0201 = font_aw70 . '-jisx0201.1976-0'
|
|
|
|
let font_jisx0208 = font_aw140 . '-jisx0208.1983-0'
|
|
|
|
|
|
|
|
let full_XLFDs = join([ font_jisx0208, font_jisx0201 ], ',')
|
|
|
|
let short_XLFDs = join([ font_aw140, font_aw70 ], ',')
|
|
|
|
let singleton = font_head . '-*'
|
|
|
|
let aliases = 'k14,r14'
|
|
|
|
|
|
|
|
" Second, among 'locales', look up such a locale that gets 'set
|
|
|
|
" guifontset=' to work successfully with every fontset specified with
|
|
|
|
" 'fontsets'.
|
|
|
|
let locales = [ 'ja_JP.UTF-8', 'ja_JP.eucJP', 'ja_JP.SJIS' ]
|
|
|
|
let fontsets = [ full_XLFDs, short_XLFDs, singleton, aliases ]
|
|
|
|
|
|
|
|
let feasible = 0
|
|
|
|
for locale in locales
|
|
|
|
try
|
|
|
|
exec 'language ctype' locale
|
|
|
|
catch /^Vim\%((\a\+)\)\=:E197/
|
|
|
|
continue
|
|
|
|
endtry
|
|
|
|
let done = 0
|
|
|
|
for fontset in fontsets
|
2017-02-17 13:44:48 +01:00
|
|
|
try
|
2019-09-08 18:58:44 +02:00
|
|
|
exec 'set guifontset=' . fontset
|
|
|
|
catch /^Vim\%((\a\+)\)\=:E\%(250\|252\|234\|597\|598\)/
|
|
|
|
break
|
2017-02-17 13:44:48 +01:00
|
|
|
endtry
|
2019-09-08 18:58:44 +02:00
|
|
|
let done += 1
|
2017-02-17 13:44:48 +01:00
|
|
|
endfor
|
2019-09-08 18:58:44 +02:00
|
|
|
if done == len(fontsets)
|
|
|
|
let feasible = 1
|
|
|
|
break
|
2017-02-17 13:44:48 +01:00
|
|
|
endif
|
2019-09-08 18:58:44 +02:00
|
|
|
endfor
|
2017-02-12 19:59:08 +01:00
|
|
|
|
2019-09-08 18:58:44 +02:00
|
|
|
" Third, give a set of tests if it is found feasible.
|
|
|
|
if !feasible
|
|
|
|
let skipped = g:not_hosted
|
|
|
|
else
|
|
|
|
" N.B. 'v:ctype' has already been set to an appropriate value in the
|
|
|
|
" previous loop.
|
|
|
|
for fontset in fontsets
|
|
|
|
exec 'set guifontset=' . fontset
|
|
|
|
call assert_equal(fontset, &guifontset)
|
|
|
|
endfor
|
2017-02-12 19:59:08 +01:00
|
|
|
endif
|
|
|
|
|
2019-09-08 18:58:44 +02:00
|
|
|
" Finally, restore ctype.
|
|
|
|
exec 'language ctype' ctype_saved
|
|
|
|
|
2017-02-17 13:44:48 +01:00
|
|
|
if !empty(skipped)
|
|
|
|
throw skipped
|
2017-02-12 19:59:08 +01:00
|
|
|
endif
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
func Test_set_guifontwide()
|
2020-04-06 21:35:05 +02:00
|
|
|
call assert_fails('set guifontwide=*', 'E533:')
|
2017-02-17 13:44:48 +01:00
|
|
|
let skipped = ''
|
|
|
|
|
2017-02-23 19:32:47 +01:00
|
|
|
if !g:x11_based_gui
|
|
|
|
let skipped = g:not_implemented
|
2017-02-17 13:44:48 +01:00
|
|
|
elseif has('gui_gtk')
|
|
|
|
let guifont_saved = &guifont
|
|
|
|
let guifontwide_saved = &guifontwide
|
|
|
|
|
|
|
|
let fc_match = exepath('fc-match')
|
|
|
|
if empty(fc_match)
|
2017-02-23 19:32:47 +01:00
|
|
|
let skipped = g:not_hosted
|
2017-02-12 19:59:08 +01:00
|
|
|
else
|
2017-02-17 13:44:48 +01:00
|
|
|
let &guifont = system('fc-match -f "%{family[0]} %{size}" monospace:size=10:lang=en')
|
|
|
|
let wide = system('fc-match -f "%{family[0]} %{size}" monospace:size=10:lang=ja')
|
|
|
|
exec 'set guifontwide=' . fnameescape(wide)
|
|
|
|
call assert_equal(wide, &guifontwide)
|
2017-02-12 19:59:08 +01:00
|
|
|
endif
|
|
|
|
|
2017-02-17 13:44:48 +01:00
|
|
|
let &guifontwide = guifontwide_saved
|
|
|
|
let &guifont = guifont_saved
|
2017-02-12 19:59:08 +01:00
|
|
|
|
|
|
|
elseif has('gui_athena') || has('gui_motif')
|
|
|
|
" guifontwide is premised upon the xfontset feature.
|
2017-02-17 13:44:48 +01:00
|
|
|
if !has('xfontset')
|
2017-02-23 19:32:47 +01:00
|
|
|
let skipped = g:not_supported . 'xfontset'
|
2017-02-17 13:44:48 +01:00
|
|
|
else
|
|
|
|
let encoding_saved = &encoding
|
|
|
|
let guifont_saved = &guifont
|
|
|
|
let guifontset_saved = &guifontset
|
|
|
|
let guifontwide_saved = &guifontwide
|
2017-02-12 19:59:08 +01:00
|
|
|
|
2017-02-17 13:44:48 +01:00
|
|
|
let nfont = '-misc-fixed-medium-r-normal-*-18-120-100-100-c-90-iso10646-1'
|
|
|
|
let wfont = '-misc-fixed-medium-r-normal-*-18-120-100-100-c-180-iso10646-1'
|
2017-02-12 19:59:08 +01:00
|
|
|
|
|
|
|
set encoding=utf-8
|
|
|
|
|
|
|
|
" Case 1: guifontset is empty
|
|
|
|
set guifontset=
|
|
|
|
|
|
|
|
" Case 1-1: Automatic selection
|
|
|
|
set guifontwide=
|
2017-02-17 13:44:48 +01:00
|
|
|
exec 'set guifont=' . nfont
|
|
|
|
call assert_equal(wfont, &guifontwide)
|
2017-02-12 19:59:08 +01:00
|
|
|
|
|
|
|
" Case 1-2: Manual selection
|
2017-02-17 13:44:48 +01:00
|
|
|
exec 'set guifontwide=' . wfont
|
|
|
|
exec 'set guifont=' . nfont
|
|
|
|
call assert_equal(wfont, &guifontwide)
|
2017-02-12 19:59:08 +01:00
|
|
|
|
|
|
|
" Case 2: guifontset is invalid
|
|
|
|
try
|
|
|
|
set guifontset=-*-notexist-*
|
2017-03-18 20:18:45 +01:00
|
|
|
call assert_report("'set guifontset=-*-notexist-*' should have failed")
|
2017-02-12 19:59:08 +01:00
|
|
|
catch
|
|
|
|
call assert_exception('E598')
|
|
|
|
endtry
|
|
|
|
" Set it to an invalid value brutally for preparation.
|
|
|
|
let &guifontset = '-*-notexist-*'
|
|
|
|
|
|
|
|
" Case 2-1: Automatic selection
|
|
|
|
set guifontwide=
|
2017-02-17 13:44:48 +01:00
|
|
|
exec 'set guifont=' . nfont
|
|
|
|
call assert_equal(wfont, &guifontwide)
|
2017-02-12 19:59:08 +01:00
|
|
|
|
|
|
|
" Case 2-2: Manual selection
|
2017-02-17 13:44:48 +01:00
|
|
|
exec 'set guifontwide=' . wfont
|
|
|
|
exec 'set guifont=' . nfont
|
|
|
|
call assert_equal(wfont, &guifontwide)
|
|
|
|
|
|
|
|
let &guifontwide = guifontwide_saved
|
|
|
|
let &guifontset = guifontset_saved
|
|
|
|
let &guifont = guifont_saved
|
|
|
|
let &encoding = encoding_saved
|
2017-02-12 19:59:08 +01:00
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
2017-02-17 13:44:48 +01:00
|
|
|
if !empty(skipped)
|
|
|
|
throw skipped
|
2017-02-12 19:59:08 +01:00
|
|
|
endif
|
|
|
|
endfunc
|
|
|
|
|
2017-02-23 19:32:47 +01:00
|
|
|
func Test_set_guiheadroom()
|
|
|
|
let skipped = ''
|
|
|
|
|
|
|
|
if !g:x11_based_gui
|
|
|
|
let skipped = g:not_supported . 'guiheadroom'
|
|
|
|
else
|
|
|
|
" Since this script is to be read together with '-U NONE', the default
|
|
|
|
" value must be preserved.
|
|
|
|
call assert_equal(50, &guiheadroom)
|
|
|
|
endif
|
|
|
|
|
|
|
|
if !empty(skipped)
|
|
|
|
throw skipped
|
|
|
|
endif
|
|
|
|
endfunc
|
|
|
|
|
2017-03-12 17:10:33 +01:00
|
|
|
func Test_set_guioptions()
|
|
|
|
let guioptions_saved = &guioptions
|
|
|
|
let duration = '200m'
|
|
|
|
|
|
|
|
if has('win32')
|
|
|
|
" Default Value
|
|
|
|
set guioptions&
|
|
|
|
call assert_equal('egmrLtT', &guioptions)
|
|
|
|
|
|
|
|
else
|
|
|
|
" Default Value
|
|
|
|
set guioptions&
|
|
|
|
call assert_equal('aegimrLtT', &guioptions)
|
|
|
|
|
|
|
|
" To activate scrollbars of type 'L' or 'R'.
|
|
|
|
wincmd v
|
|
|
|
redraw!
|
|
|
|
|
|
|
|
" Remove all default GUI ornaments
|
|
|
|
set guioptions-=T
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal('aegimrLt', &guioptions)
|
|
|
|
set guioptions-=t
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal('aegimrL', &guioptions)
|
|
|
|
set guioptions-=L
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal('aegimr', &guioptions)
|
|
|
|
set guioptions-=r
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal('aegim', &guioptions)
|
|
|
|
set guioptions-=m
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal('aegi', &guioptions)
|
|
|
|
|
|
|
|
" Try non-default GUI ornaments
|
|
|
|
set guioptions+=l
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal('aegil', &guioptions)
|
|
|
|
set guioptions-=l
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal('aegi', &guioptions)
|
|
|
|
|
|
|
|
set guioptions+=R
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal('aegiR', &guioptions)
|
|
|
|
set guioptions-=R
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal('aegi', &guioptions)
|
|
|
|
|
|
|
|
set guioptions+=b
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal('aegib', &guioptions)
|
|
|
|
set guioptions+=h
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal('aegibh', &guioptions)
|
|
|
|
set guioptions-=h
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal('aegib', &guioptions)
|
|
|
|
set guioptions-=b
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal('aegi', &guioptions)
|
|
|
|
|
|
|
|
set guioptions+=v
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal('aegiv', &guioptions)
|
|
|
|
set guioptions-=v
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal('aegi', &guioptions)
|
|
|
|
|
|
|
|
if has('gui_motif')
|
|
|
|
set guioptions+=F
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal('aegiF', &guioptions)
|
|
|
|
set guioptions-=F
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal('aegi', &guioptions)
|
|
|
|
endif
|
|
|
|
|
2019-09-15 13:17:00 +02:00
|
|
|
if has('gui_gtk3')
|
|
|
|
set guioptions+=d
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal('aegid', &guioptions)
|
|
|
|
set guioptions-=d
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal('aegi', &guioptions)
|
|
|
|
endif
|
|
|
|
|
2017-03-12 17:10:33 +01:00
|
|
|
" Restore GUI ornaments to the default state.
|
|
|
|
set guioptions+=m
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal('aegim', &guioptions)
|
|
|
|
set guioptions+=r
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal('aegimr', &guioptions)
|
|
|
|
set guioptions+=L
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal('aegimrL', &guioptions)
|
|
|
|
set guioptions+=t
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal('aegimrLt', &guioptions)
|
|
|
|
set guioptions+=T
|
|
|
|
exec 'sleep' . duration
|
|
|
|
call assert_equal("aegimrLtT", &guioptions)
|
|
|
|
|
|
|
|
wincmd o
|
|
|
|
redraw!
|
|
|
|
endif
|
|
|
|
|
|
|
|
let &guioptions = guioptions_saved
|
|
|
|
endfunc
|
|
|
|
|
2018-09-14 21:27:06 +02:00
|
|
|
func Test_scrollbars()
|
|
|
|
new
|
|
|
|
" buffer with 200 lines
|
|
|
|
call setline(1, repeat(['one', 'two'], 100))
|
|
|
|
set guioptions+=rlb
|
|
|
|
|
|
|
|
" scroll to move line 11 at top, moves the cursor there
|
2019-09-08 18:58:44 +02:00
|
|
|
eval 10->test_scrollbar('left', 0)
|
2018-09-14 21:27:06 +02:00
|
|
|
redraw
|
|
|
|
call assert_equal(1, winline())
|
|
|
|
call assert_equal(11, line('.'))
|
|
|
|
|
|
|
|
" scroll to move line 1 at top, cursor stays in line 11
|
|
|
|
call test_scrollbar('right', 0, 0)
|
|
|
|
redraw
|
|
|
|
call assert_equal(11, winline())
|
|
|
|
call assert_equal(11, line('.'))
|
|
|
|
|
|
|
|
set nowrap
|
|
|
|
call setline(11, repeat('x', 150))
|
|
|
|
redraw
|
|
|
|
call assert_equal(1, wincol())
|
2019-06-06 15:40:08 +02:00
|
|
|
set number
|
|
|
|
redraw
|
|
|
|
call assert_equal(5, wincol())
|
|
|
|
set nonumber
|
|
|
|
redraw
|
2018-09-14 21:27:06 +02:00
|
|
|
call assert_equal(1, col('.'))
|
|
|
|
|
|
|
|
" scroll to character 11, cursor is moved
|
|
|
|
call test_scrollbar('hor', 10, 0)
|
|
|
|
redraw
|
|
|
|
call assert_equal(1, wincol())
|
2019-06-06 15:40:08 +02:00
|
|
|
set number
|
|
|
|
redraw
|
|
|
|
call assert_equal(5, wincol())
|
|
|
|
set nonumber
|
|
|
|
redraw
|
2018-09-14 21:27:06 +02:00
|
|
|
call assert_equal(11, col('.'))
|
|
|
|
|
|
|
|
set guioptions&
|
|
|
|
set wrap&
|
|
|
|
bwipe!
|
|
|
|
endfunc
|
|
|
|
|
2019-03-28 22:04:56 +01:00
|
|
|
func Test_menu()
|
2019-12-01 15:23:11 +01:00
|
|
|
CheckFeature quickfix
|
|
|
|
|
2019-03-28 22:04:56 +01:00
|
|
|
" Check Help menu exists
|
|
|
|
let help_menu = execute('menu Help')
|
|
|
|
call assert_match('Overview', help_menu)
|
|
|
|
|
|
|
|
" Check Help menu works
|
|
|
|
emenu Help.Overview
|
|
|
|
call assert_equal('help', &buftype)
|
|
|
|
close
|
|
|
|
|
|
|
|
" Check deleting menu doesn't cause trouble.
|
|
|
|
aunmenu Help
|
|
|
|
call assert_fails('menu Help', 'E329:')
|
|
|
|
endfunc
|
|
|
|
|
2017-03-12 17:10:33 +01:00
|
|
|
func Test_set_guipty()
|
|
|
|
let guipty_saved = &guipty
|
|
|
|
|
|
|
|
" Default Value
|
|
|
|
set guipty&
|
|
|
|
call assert_equal(1, &guipty)
|
|
|
|
|
|
|
|
set noguipty
|
|
|
|
call assert_equal(0, &guipty)
|
|
|
|
|
|
|
|
let &guipty = guipty_saved
|
2017-02-06 22:11:55 +01:00
|
|
|
endfunc
|
2017-02-05 20:54:26 +01:00
|
|
|
|
2019-03-28 21:49:21 +01:00
|
|
|
func Test_encoding_conversion()
|
|
|
|
" GTK supports conversion between 'encoding' and "utf-8"
|
|
|
|
if has('gui_gtk')
|
|
|
|
let encoding_saved = &encoding
|
|
|
|
set encoding=latin1
|
|
|
|
|
|
|
|
" would be nice if we could take a screenshot
|
|
|
|
intro
|
|
|
|
" sets the window title
|
|
|
|
edit SomeFile
|
|
|
|
|
|
|
|
let &encoding = encoding_saved
|
|
|
|
endif
|
|
|
|
endfunc
|
|
|
|
|
2016-08-04 20:05:50 +02:00
|
|
|
func Test_shell_command()
|
|
|
|
new
|
2016-08-04 21:21:13 +02:00
|
|
|
r !echo hello
|
|
|
|
call assert_equal('hello', substitute(getline(2), '\W', '', 'g'))
|
2016-08-04 20:05:50 +02:00
|
|
|
bwipe!
|
|
|
|
endfunc
|
2017-02-05 20:54:26 +01:00
|
|
|
|
2017-03-12 17:10:33 +01:00
|
|
|
func Test_syntax_colortest()
|
|
|
|
runtime syntax/colortest.vim
|
|
|
|
redraw!
|
|
|
|
sleep 200m
|
|
|
|
bwipe!
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
func Test_set_term()
|
|
|
|
" It's enough to check the current value since setting 'term' to anything
|
|
|
|
" other than builtin_gui makes no sense at all.
|
|
|
|
call assert_equal('builtin_gui', &term)
|
2020-04-06 21:35:05 +02:00
|
|
|
call assert_fails('set term=xterm', 'E530:')
|
2017-03-12 17:10:33 +01:00
|
|
|
endfunc
|
|
|
|
|
2017-02-05 20:54:26 +01:00
|
|
|
func Test_windowid_variable()
|
2017-02-23 19:32:47 +01:00
|
|
|
if g:x11_based_gui || has('win32')
|
2017-02-05 20:54:26 +01:00
|
|
|
call assert_true(v:windowid > 0)
|
|
|
|
else
|
|
|
|
call assert_equal(0, v:windowid)
|
|
|
|
endif
|
2017-02-06 22:11:55 +01:00
|
|
|
endfunc
|
2018-05-05 15:47:19 +02:00
|
|
|
|
|
|
|
" Test "vim -g" and also the GUIEnter autocommand.
|
|
|
|
func Test_gui_dash_g()
|
|
|
|
let cmd = GetVimCommand('Xscriptgui')
|
|
|
|
call writefile([""], "Xtestgui")
|
2019-06-24 00:58:07 +02:00
|
|
|
let lines =<< trim END
|
|
|
|
au GUIEnter * call writefile(["insertmode: " . &insertmode], "Xtestgui")
|
|
|
|
au GUIEnter * qall
|
|
|
|
END
|
|
|
|
call writefile(lines, 'Xscriptgui')
|
2018-05-05 15:47:19 +02:00
|
|
|
call system(cmd . ' -g')
|
|
|
|
call WaitForAssert({-> assert_equal(['insertmode: 0'], readfile('Xtestgui'))})
|
|
|
|
|
|
|
|
call delete('Xscriptgui')
|
|
|
|
call delete('Xtestgui')
|
|
|
|
endfunc
|
|
|
|
|
|
|
|
" Test "vim -7" and also the GUIEnter autocommand.
|
|
|
|
func Test_gui_dash_y()
|
|
|
|
let cmd = GetVimCommand('Xscriptgui')
|
|
|
|
call writefile([""], "Xtestgui")
|
2019-06-24 00:58:07 +02:00
|
|
|
let lines =<< trim END
|
|
|
|
au GUIEnter * call writefile(["insertmode: " . &insertmode], "Xtestgui")
|
|
|
|
au GUIEnter * qall
|
|
|
|
END
|
|
|
|
call writefile(lines, 'Xscriptgui')
|
2018-05-05 15:47:19 +02:00
|
|
|
call system(cmd . ' -y')
|
|
|
|
call WaitForAssert({-> assert_equal(['insertmode: 1'], readfile('Xtestgui'))})
|
|
|
|
|
|
|
|
call delete('Xscriptgui')
|
|
|
|
call delete('Xtestgui')
|
|
|
|
endfunc
|
2020-03-25 22:23:46 +01:00
|
|
|
|
2020-05-11 22:04:53 +02:00
|
|
|
" Test for "!" option in 'guioptions'. Use a terminal for running external
|
|
|
|
" commands
|
|
|
|
func Test_gui_run_cmd_in_terminal()
|
2020-05-15 22:46:44 +02:00
|
|
|
CheckFeature terminal
|
2020-05-11 22:04:53 +02:00
|
|
|
let save_guioptions = &guioptions
|
|
|
|
set guioptions+=!
|
|
|
|
if has('win32')
|
|
|
|
let cmd = 'type'
|
|
|
|
else
|
|
|
|
" assume all the other systems have a cat command
|
|
|
|
let cmd = 'cat'
|
|
|
|
endif
|
|
|
|
let cmd = ':silent !' . cmd . " test_gui.vim\<CR>\<CR>"
|
|
|
|
call feedkeys(cmd, 'xt')
|
|
|
|
" TODO: how to check that the command ran in a separate terminal?
|
|
|
|
" Maybe check for $TERM (dumb vs xterm) in the spawned shell?
|
|
|
|
let &guioptions = save_guioptions
|
|
|
|
endfunc
|
|
|
|
|
2020-03-25 22:23:46 +01:00
|
|
|
" vim: shiftwidth=2 sts=2 expandtab
|