aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorzeertzjq <zeertzjq@outlook.com>2023-11-17 08:55:36 +0800
committerzeertzjq <zeertzjq@outlook.com>2023-11-17 09:54:03 +0800
commit748198f5bf3048c06993efe4b048a6e39e4b1658 (patch)
tree5c22621975c28601eee25c593537a3f63517f87a
parent86c2213b5e451b0c80c2d7adc356c7cebe4bb7f8 (diff)
downloadrneovim-748198f5bf3048c06993efe4b048a6e39e4b1658.tar.gz
rneovim-748198f5bf3048c06993efe4b048a6e39e4b1658.tar.bz2
rneovim-748198f5bf3048c06993efe4b048a6e39e4b1658.zip
vim-patch:9.0.1854: test_crash1() fails on CI
Problem: test_crash1() fails on CI Solution: don't run Screendump test, verify that it doesn't crash by running it through a shell command line, testing the exit value and concatenating success cmd using '&&' https://github.com/vim/vim/commit/db510ca8052884fd260f425025bacf44f6c92fa9 Co-authored-by: Christian Brabandt <cb@256bit.org>
-rw-r--r--test/old/testdir/test_crash.vim40
1 files changed, 30 insertions, 10 deletions
diff --git a/test/old/testdir/test_crash.vim b/test/old/testdir/test_crash.vim
index 445fe8d5a7..eb3c0a37fb 100644
--- a/test/old/testdir/test_crash.vim
+++ b/test/old/testdir/test_crash.vim
@@ -6,20 +6,40 @@ CheckScreendump
func Test_crash1()
" The following used to crash Vim
- let opts = #{wait_for_ruler: 0, rows: 20}
- let args = ' -u NONE -i NONE -n -e -s -S '
- let buf = RunVimInTerminal(args .. ' crash/poc_huaf1', opts)
- call VerifyScreenDump(buf, 'Test_crash_01', {})
- exe buf .. "bw!"
+ " let opts = #{wait_for_ruler: 0, rows: 20, cmd: 'sh'}
+ let opts = #{cmd: 'sh'}
+ let args = 'bash'
+ let vim = GetVimProg()
- let buf = RunVimInTerminal(args .. ' crash/poc_huaf2', opts)
- call VerifyScreenDump(buf, 'Test_crash_01', {})
- exe buf .. "bw!"
+ let buf = RunVimInTerminal(args, opts)
- let buf = RunVimInTerminal(args .. ' crash/poc_huaf3', opts)
- call VerifyScreenDump(buf, 'Test_crash_01', {})
+ let file = 'crash/poc_huaf1'
+ let cmn_args = "%s -u NONE -i NONE -n -e -s -S %s -c ':qa!'"
+ let args = printf(cmn_args, vim, file)
+ call term_sendkeys(buf, args ..
+ \ ' && echo "crash 1: [OK]" >> X_crash1_result.txt' .. "\<cr>")
+
+ let file = 'crash/poc_huaf2'
+ let args = printf(cmn_args, vim, file)
+ call term_sendkeys(buf, args ..
+ \ ' && echo "crash 2: [OK]" >> X_crash1_result.txt' .. "\<cr>")
+
+ let file = 'crash/poc_huaf3'
+ let args = printf(cmn_args, vim, file)
+ call term_sendkeys(buf, args ..
+ \ ' && echo "crash 3: [OK]" >> X_crash1_result.txt' .. "\<cr>")
+
+ call TermWait(buf, 50)
+
+ " clean up
exe buf .. "bw!"
+ sp X_crash1_result.txt
+ call assert_equal(['crash 1: [OK]', 'crash 2: [OK]', 'crash 3: [OK]'],
+ \ getline(1, '$'))
+ bw!
+
+ call delete('X_crash1_result.txt')
endfunc
func Test_crash2()