diff options
Diffstat (limited to 'test/reline/test_ansi_with_terminfo.rb')
-rw-r--r-- | test/reline/test_ansi_with_terminfo.rb | 38 |
1 files changed, 34 insertions, 4 deletions
diff --git a/test/reline/test_ansi_with_terminfo.rb b/test/reline/test_ansi_with_terminfo.rb index a6c3a5e500..3adda10716 100644 --- a/test/reline/test_ansi_with_terminfo.rb +++ b/test/reline/test_ansi_with_terminfo.rb @@ -1,11 +1,11 @@ require_relative 'helper' -require 'reline/ansi' +require 'reline' -class Reline::ANSI::TestWithTerminfo < Reline::TestCase +class Reline::ANSI::WithTerminfoTest < Reline::TestCase def setup Reline.send(:test_mode, ansi: true) @config = Reline::Config.new - Reline::IOGate.set_default_key_bindings(@config, allow_terminfo: true) + Reline.core.io_gate.set_default_key_bindings(@config, allow_terminfo: true) end def teardown @@ -33,6 +33,20 @@ class Reline::ANSI::TestWithTerminfo < Reline::TestCase omit e.message end + # PgUp key + def test_kpp + assert_key_binding(Reline::Terminfo.tigetstr('kpp'), :ed_search_prev_history) + rescue Reline::Terminfo::TerminfoError => e + omit e.message + end + + # PgDn key + def test_knp + assert_key_binding(Reline::Terminfo.tigetstr('knp'), :ed_search_next_history) + rescue Reline::Terminfo::TerminfoError => e + omit e.message + end + # Up arrow key def test_kcuu1 assert_key_binding(Reline::Terminfo.tigetstr('kcuu1'), :ed_prev_history) @@ -61,12 +75,28 @@ class Reline::ANSI::TestWithTerminfo < Reline::TestCase omit e.message end + # Home and End; always mapped regardless of terminfo enabled or not + def test_home_end + assert_key_binding("\e[H", :ed_move_to_beg) + assert_key_binding("\e[F", :ed_move_to_end) + end + + # Arrow; always mapped regardless of terminfo enabled or not + def test_arrow + assert_key_binding("\e[A", :ed_prev_history) + assert_key_binding("\e[B", :ed_next_history) + assert_key_binding("\e[C", :ed_next_char) + assert_key_binding("\e[D", :ed_prev_char) + end + # Ctrl+arrow and Meta+arrow; always mapped regardless of terminfo enabled or not def test_extended assert_key_binding("\e[1;5C", :em_next_word) # Ctrl+→ assert_key_binding("\e[1;5D", :ed_prev_word) # Ctrl+← assert_key_binding("\e[1;3C", :em_next_word) # Meta+→ assert_key_binding("\e[1;3D", :ed_prev_word) # Meta+← + assert_key_binding("\e\e[C", :em_next_word) # Meta+→ + assert_key_binding("\e\e[D", :ed_prev_word) # Meta+← end # Shift-Tab; always mapped regardless of terminfo enabled or not @@ -79,4 +109,4 @@ class Reline::ANSI::TestWithTerminfo < Reline::TestCase assert_key_binding("\e ", :em_set_mark, [:emacs]) assert_key_binding("\C-x\C-x", :em_exchange_mark, [:emacs]) end -end if Reline::Terminfo.enabled? +end if Reline::Terminfo.enabled? && Reline::Terminfo.term_supported? |