diff options
author | Thiago de Arruda <tpadilha84@gmail.com> | 2015-03-25 09:14:47 -0300 |
---|---|---|
committer | Thiago de Arruda <tpadilha84@gmail.com> | 2015-03-25 18:57:36 -0300 |
commit | 2aa2513b8e023a0d7bd2071299f0ea59a4d4ce25 (patch) | |
tree | b684785ba9c769491e6ebdac8e21495cf22dbdd3 /test/functional/terminal/helpers.lua | |
parent | 710002c820e5a55e3b234074fefb84ab745e11a3 (diff) | |
download | rneovim-2aa2513b8e023a0d7bd2071299f0ea59a4d4ce25.tar.gz rneovim-2aa2513b8e023a0d7bd2071299f0ea59a4d4ce25.tar.bz2 rneovim-2aa2513b8e023a0d7bd2071299f0ea59a4d4ce25.zip |
test: Add terminal tests
- Modify tty-test to allow easier control over the terminal
- Add a new directory with various terminal tests/specifications
- Remove a pending job/pty test.
- Flush stdout in Screen:snapshot_util() (avoid waiting for the test to finish)
- Replace libuv sigwinch watcher by a sigaction handler. libuv randomly fails to
deliver signals on OSX. Might be related to the problem fixed by
@bbcddc55ee1e5605657592644be0102ed3a5f104 (under the hoods, libuv uses a pipe
to deliver signals to the main thread, which might be blocking in some
situations)
Diffstat (limited to 'test/functional/terminal/helpers.lua')
-rw-r--r-- | test/functional/terminal/helpers.lua | 95 |
1 files changed, 95 insertions, 0 deletions
diff --git a/test/functional/terminal/helpers.lua b/test/functional/terminal/helpers.lua new file mode 100644 index 0000000000..631dc579d3 --- /dev/null +++ b/test/functional/terminal/helpers.lua @@ -0,0 +1,95 @@ +local helpers = require('test.functional.helpers') +local Screen = require('test.functional.ui.screen') +local nvim_dir = helpers.nvim_dir +local execute, nvim = helpers.execute, helpers.nvim + +local function feed_data(data) + nvim('set_var', 'term_data', data) + nvim('command', 'call jobsend(b:terminal_job_id, term_data)') +end + +local function feed_termcode(data) + -- feed with the job API + nvim('command', 'call jobsend(b:terminal_job_id, "\\x1b'..data..'")') +end +-- some helpers for controlling the terminal. the codes were taken from +-- infocmp xterm-256color which is less what libvterm understands +-- civis/cnorm +local function hide_cursor() feed_termcode('[?25l') end +local function show_cursor() feed_termcode('[?25h') end +-- smcup/rmcup +local function enter_altscreen() feed_termcode('[?1049h') end +local function exit_altscreen() feed_termcode('[?1049l') end +-- character attributes +local function set_fg(num) feed_termcode('[38;5;'..num..'m') end +local function set_bg(num) feed_termcode('[48;5;'..num..'m') end +local function set_bold() feed_termcode('[1m') end +local function set_italic() feed_termcode('[3m') end +local function set_underline() feed_termcode('[4m') end +local function clear_attrs() feed_termcode('[0;10m') end +-- mouse +local function enable_mouse() feed_termcode('[?1002h') end +local function disable_mouse() feed_termcode('[?1002l') end + + + +local function screen_setup(extra_height) + nvim('set_var', 'terminal_scrollback_buffer_size', 10) + if not extra_height then extra_height = 0 end + local screen = Screen.new(50, 7 + extra_height) + screen:set_default_attr_ids({ + [1] = {reverse = true}, -- focused cursor + [2] = {background = 11}, -- unfocused cursor + }) + screen:set_default_attr_ignore({ + [1] = {bold = true}, + [2] = {foreground = 12}, + [3] = {bold = true, reverse = true}, + [5] = {background = 11}, + [6] = {foreground = 130}, + [7] = {foreground = 15, background = 1}, -- error message + }) + + screen:attach(false) + -- tty-test puts the terminal into raw mode and echoes all input. tests are + -- done by feeding it with terminfo codes to control the display and + -- verifying output with screen:expect. + execute('term ' ..nvim_dir.. '/tty-test') + -- wait for "tty ready" to be printed before each test or the terminal may + -- still be in canonical mode(will echo characters for example) + -- + local empty_line = ' ' + local expected = { + 'tty ready ', + '{1: } ', + empty_line, + empty_line, + empty_line, + empty_line, + } + for i = 1, extra_height do + table.insert(expected, empty_line) + end + + table.insert(expected, '-- TERMINAL -- ') + screen:expect(table.concat(expected, '\n')) + return screen +end + +return { + feed_data = feed_data, + feed_termcode = feed_termcode, + hide_cursor = hide_cursor, + show_cursor = show_cursor, + enter_altscreen = enter_altscreen, + exit_altscreen = exit_altscreen, + set_fg = set_fg, + set_bg = set_bg, + set_bold = set_bold, + set_italic = set_italic, + set_underline = set_underline, + clear_attrs = clear_attrs, + enable_mouse = enable_mouse, + disable_mouse = disable_mouse, + screen_setup = screen_setup +} |