2016-08-04 20:05:50 +02:00
|
|
|
" Tests specifically for the GUI
|
|
|
|
|
|
|
|
if !has('gui') || ($DISPLAY == "" && !has('gui_running'))
|
|
|
|
finish
|
|
|
|
endif
|
|
|
|
|
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.
|
|
|
|
" Must be run first.
|
|
|
|
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()
|
|
|
|
let colorscheme_saved = exists('g:colors_name') ? g:colors_name : 'default'
|
|
|
|
|
|
|
|
colorscheme torte
|
|
|
|
redraw!
|
|
|
|
sleep 200m
|
|
|
|
call assert_equal('dark', &background)
|
|
|
|
|
|
|
|
exec 'colorscheme' colorscheme_saved
|
|
|
|
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'))
|
|
|
|
|
|
|
|
" 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)
|
|
|
|
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.'
|
|
|
|
let vim_exe = exepath(v:progpath)
|
|
|
|
let testee = 'VIMRUNTIME=' . $VIMRUNTIME . '; export VIMRUNTIME;'
|
2017-03-01 18:30:34 +01:00
|
|
|
\ . vim_exe
|
2017-03-04 13:32:10 +01:00
|
|
|
\ . ' -u NONE -U NONE --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
|
|
|
|
" onto it. Second, it tries to substitute test_responce for the pasted
|
|
|
|
" 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,
|
|
|
|
" and check if the content of the balloon is the smae as what is expected.
|
|
|
|
" 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,
|
|
|
|
" and check if the content of the balloon is the smae as what is
|
|
|
|
" 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,
|
|
|
|
" and check if the content of the balloon is the smae as what is
|
|
|
|
" 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
|
|
|
|
|
|
|
|
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()
|
2017-02-17 13:44:48 +01:00
|
|
|
let skipped = ''
|
2017-02-12 19:59:08 +01:00
|
|
|
|
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 ctype_saved = v:ctype
|
2017-02-12 19:59:08 +01:00
|
|
|
|
2017-02-17 13:44:48 +01:00
|
|
|
" First, since XCreateFontSet(3) is very sensitive to locale, fonts must
|
|
|
|
" be chosen meticulously.
|
|
|
|
let font_head = '-misc-fixed-medium-r-normal--14'
|
2017-02-12 19:59:08 +01:00
|
|
|
|
2017-02-17 13:44:48 +01:00
|
|
|
let font_aw70 = font_head . '-130-75-75-c-70'
|
|
|
|
let font_aw140 = font_head . '-130-75-75-c-140'
|
2017-02-12 19:59:08 +01:00
|
|
|
|
2017-02-17 13:44:48 +01:00
|
|
|
let font_jisx0201 = font_aw70 . '-jisx0201.1976-0'
|
|
|
|
let font_jisx0208 = font_aw140 . '-jisx0208.1983-0'
|
2017-02-12 19:59:08 +01:00
|
|
|
|
2017-02-17 13:44:48 +01:00
|
|
|
let full_XLFDs = join([ font_jisx0208, font_jisx0201 ], ',')
|
|
|
|
let short_XLFDs = join([ font_aw140, font_aw70 ], ',')
|
|
|
|
let singleton = font_head . '-*'
|
|
|
|
let aliases = 'k14,r14'
|
2017-02-12 19:59:08 +01:00
|
|
|
|
2017-02-17 13:44:48 +01:00
|
|
|
" 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 ]
|
2017-02-12 19:59:08 +01:00
|
|
|
|
2017-02-17 13:44:48 +01:00
|
|
|
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
|
|
|
|
try
|
|
|
|
exec 'set guifontset=' . fontset
|
|
|
|
catch /^Vim\%((\a\+)\)\=:E\%(250\|252\|234\|597\|598\)/
|
|
|
|
break
|
|
|
|
endtry
|
|
|
|
let done += 1
|
|
|
|
endfor
|
|
|
|
if done == len(fontsets)
|
|
|
|
let feasible = 1
|
|
|
|
break
|
|
|
|
endif
|
|
|
|
endfor
|
|
|
|
|
|
|
|
" Third, give a set of tests if it is found feasible.
|
|
|
|
if !feasible
|
2017-02-23 19:32:47 +01:00
|
|
|
let skipped = g:not_hosted
|
2017-02-17 13:44:48 +01:00
|
|
|
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
|
|
|
|
endif
|
2017-02-12 19:59:08 +01:00
|
|
|
|
2017-02-17 13:44:48 +01:00
|
|
|
" Finally, restore ctype.
|
|
|
|
exec 'language ctype' ctype_saved
|
2017-02-12 19:59:08 +01:00
|
|
|
endif
|
|
|
|
|
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()
|
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
|
|
|
|
|
|
|
|
" 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
|
|
|
|
|
|
|
|
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
|
|
|
|
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)
|
|
|
|
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
|