changeset 15186:2b15ee496cbd v8.1.0603

patch 8.1.0603: the :stop command is not tested commit https://github.com/vim/vim/commit/e751a5f531c1ceb58dacc7c280fdaae0df2c71c7 Author: Bram Moolenaar <Bram@vim.org> Date: Sun Dec 16 16:16:10 2018 +0100 patch 8.1.0603: the :stop command is not tested Problem: The :stop command is not tested. Solution: Test :stop using a terminal window.
author Bram Moolenaar <Bram@vim.org>
date Sun, 16 Dec 2018 16:30:06 +0100
parents 33f5df5e19f2
children 0cfd0fb15db0
files src/testdir/shared.vim src/testdir/test_terminal.vim src/version.c
diffstat 3 files changed, 43 insertions(+), 0 deletions(-) [+]
line wrap: on
line diff
--- a/src/testdir/shared.vim
+++ b/src/testdir/shared.vim
@@ -345,3 +345,13 @@ func Stop_shell_in_terminal(buf)
   let job = term_getjob(a:buf)
   call WaitFor({-> job_status(job) == "dead"})
 endfunc
+
+" Gets the text of a terminal line, using term_scrape()
+func Get_terminal_text(bufnr, row)
+  let list = term_scrape(a:bufnr, a:row)
+  let text = ''
+  for item in list
+    let text .= item.chars
+  endfor
+  return text
+endfunc
--- a/src/testdir/test_terminal.vim
+++ b/src/testdir/test_terminal.vim
@@ -1683,3 +1683,34 @@ func Test_terminal_does_not_truncate_las
 
   call delete('Xfile')
 endfunc
+
+func Test_stop_in_terminal()
+  " We can't expect this to work on all systems, just test on Linux for now.
+  if !has('unix') || system('uname') !~ 'Linux'
+    return
+  endif
+  term /bin/sh
+  let bufnr = bufnr('')
+  call WaitForAssert({-> assert_equal('running', term_getstatus(bufnr))})
+  let lastrow = term_getsize(bufnr)[0]
+
+  call term_sendkeys(bufnr, GetVimCommandClean() . "\r")
+  call term_sendkeys(bufnr, ":echo 'ready'\r")
+  call WaitForAssert({-> assert_match('ready', Get_terminal_text(bufnr, lastrow))})
+
+  call term_sendkeys(bufnr, ":stop\r")
+  " Not sure where "Stopped" shows up, assume in the first three lines.
+  call WaitForAssert({-> assert_match('Stopped',
+	\ Get_terminal_text(bufnr, 1) . 
+	\ Get_terminal_text(bufnr, 2) . 
+	\ Get_terminal_text(bufnr, 3))})
+
+  call term_sendkeys(bufnr, "fg\r")
+  call term_sendkeys(bufnr, ":echo 'back again'\r")
+  call WaitForAssert({-> assert_match('back again', Get_terminal_text(bufnr, lastrow))})
+
+  call term_sendkeys(bufnr, ":quit\r")
+  call term_wait(bufnr)
+  call Stop_shell_in_terminal(bufnr)
+  exe bufnr . 'bwipe'
+endfunc
--- a/src/version.c
+++ b/src/version.c
@@ -800,6 +800,8 @@ static char *(features[]) =
 static int included_patches[] =
 {   /* Add new patch number below this line */
 /**/
+    603,
+/**/
     602,
 /**/
     601,