2020-03-02 23:20:29 +00:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
from pexpect_helper import SpawnedProc
|
2021-05-23 13:25:12 +00:00
|
|
|
import os
|
|
|
|
import platform
|
|
|
|
import sys
|
|
|
|
|
|
|
|
# Skip on macOS on Github Actions because it's too resource-starved
|
|
|
|
# and fails this a lot.
|
|
|
|
#
|
|
|
|
# Presumably we still have users on macOS that would notice binding errors
|
|
|
|
if "GITHUB_WORKFLOW" in os.environ and platform.system() == "Darwin":
|
|
|
|
sys.exit(127)
|
2020-03-02 23:20:29 +00:00
|
|
|
|
|
|
|
sp = SpawnedProc()
|
2020-10-14 17:26:13 +00:00
|
|
|
send, sendline, sleep, expect_prompt, expect_re, expect_str = (
|
|
|
|
sp.send,
|
|
|
|
sp.sendline,
|
|
|
|
sp.sleep,
|
|
|
|
sp.expect_prompt,
|
|
|
|
sp.expect_re,
|
|
|
|
sp.expect_str,
|
|
|
|
)
|
2020-10-06 21:22:35 +00:00
|
|
|
expect_prompt()
|
2020-08-24 20:19:57 +00:00
|
|
|
|
|
|
|
# Clear twice (regression test for #7280).
|
|
|
|
send("\f")
|
|
|
|
expect_prompt(increment=False)
|
|
|
|
send("\f")
|
|
|
|
expect_prompt(increment=False)
|
2020-03-02 23:20:29 +00:00
|
|
|
|
|
|
|
# Fish should start in default-mode (i.e., emacs) bindings. The default escape
|
|
|
|
# timeout is 30ms.
|
2020-11-07 06:42:40 +00:00
|
|
|
#
|
|
|
|
# Because common CI systems are awful, we have to increase this:
|
|
|
|
|
2021-05-03 09:26:02 +00:00
|
|
|
sendline("set -g fish_escape_delay_ms 120")
|
2020-11-07 06:42:40 +00:00
|
|
|
expect_prompt("")
|
2020-03-02 23:20:29 +00:00
|
|
|
|
|
|
|
# Verify the emacs transpose word (\et) behavior using various delays,
|
|
|
|
# including none, after the escape character.
|
|
|
|
|
|
|
|
# Start by testing with no delay. This should transpose the words.
|
2020-06-05 01:13:39 +00:00
|
|
|
send("echo abc def")
|
|
|
|
send("\033t\r")
|
|
|
|
expect_prompt("\r\ndef abc\r\n") # emacs transpose words, default timeout: no delay
|
2020-03-02 23:20:29 +00:00
|
|
|
|
|
|
|
# Now test with a delay > 0 and < the escape timeout. This should transpose
|
|
|
|
# the words.
|
2020-06-05 01:13:39 +00:00
|
|
|
send("echo ghi jkl")
|
|
|
|
send("\033")
|
|
|
|
sleep(0.010)
|
|
|
|
send("t\r")
|
2020-03-02 23:20:29 +00:00
|
|
|
# emacs transpose words, default timeout: short delay
|
2020-06-05 01:13:39 +00:00
|
|
|
expect_prompt("\r\njkl ghi\r\n")
|
2020-03-02 23:20:29 +00:00
|
|
|
|
|
|
|
# Now test with a delay > the escape timeout. The transposition should not
|
|
|
|
# occur and the "t" should become part of the text that is echoed.
|
2020-06-05 01:13:39 +00:00
|
|
|
send("echo mno pqr")
|
|
|
|
send("\033")
|
2020-12-09 16:52:17 +00:00
|
|
|
sleep(0.250)
|
2020-06-05 01:13:39 +00:00
|
|
|
send("t\r")
|
2020-03-02 23:20:29 +00:00
|
|
|
# emacs transpose words, default timeout: long delay
|
2020-06-05 01:13:39 +00:00
|
|
|
expect_prompt("\r\nmno pqrt\r\n")
|
2020-03-02 23:20:29 +00:00
|
|
|
|
|
|
|
# Now test that exactly the expected bind modes are defined
|
2020-06-05 01:13:39 +00:00
|
|
|
sendline("bind --list-modes")
|
|
|
|
expect_prompt("\r\ndefault\r\npaste", unmatched="Unexpected bind modes")
|
2020-03-02 23:20:29 +00:00
|
|
|
|
|
|
|
# Test vi key bindings.
|
|
|
|
# This should leave vi mode in the insert state.
|
2020-06-05 01:13:39 +00:00
|
|
|
sendline("set -g fish_key_bindings fish_vi_key_bindings")
|
|
|
|
expect_prompt()
|
2020-03-02 23:20:29 +00:00
|
|
|
|
|
|
|
# Go through a prompt cycle to let fish catch up, it may be slow due to ASAN
|
2020-06-05 01:13:39 +00:00
|
|
|
sendline("echo success: default escape timeout")
|
|
|
|
expect_prompt(
|
2020-03-02 23:20:29 +00:00
|
|
|
"\r\nsuccess: default escape timeout", unmatched="prime vi mode, default timeout"
|
|
|
|
)
|
|
|
|
|
2020-06-05 01:13:39 +00:00
|
|
|
send("echo fail: default escape timeout")
|
2021-04-22 19:43:04 +00:00
|
|
|
expect_str("echo fail: default escape timeout")
|
2020-06-05 01:13:39 +00:00
|
|
|
send("\033")
|
2020-03-02 23:20:29 +00:00
|
|
|
|
|
|
|
# Delay needed to allow fish to transition to vi "normal" mode. The delay is
|
|
|
|
# longer than strictly necessary to let fish catch up as it may be slow due to
|
|
|
|
# ASAN.
|
2020-11-09 18:08:00 +00:00
|
|
|
sleep(0.250)
|
2020-06-05 01:13:39 +00:00
|
|
|
send("ddi")
|
|
|
|
sendline("echo success: default escape timeout")
|
|
|
|
expect_prompt(
|
2020-03-02 23:20:29 +00:00
|
|
|
"\r\nsuccess: default escape timeout\r\n",
|
|
|
|
unmatched="vi replace line, default timeout: long delay",
|
|
|
|
)
|
|
|
|
|
|
|
|
# Test replacing a single character.
|
2020-06-05 01:13:39 +00:00
|
|
|
send("echo TEXT")
|
|
|
|
send("\033")
|
2020-03-02 23:20:29 +00:00
|
|
|
# Delay needed to allow fish to transition to vi "normal" mode.
|
2021-05-03 10:13:18 +00:00
|
|
|
sleep(0.300)
|
2020-06-05 01:13:39 +00:00
|
|
|
send("hhrAi\r")
|
|
|
|
expect_prompt(
|
2020-03-02 23:20:29 +00:00
|
|
|
"\r\nTAXT\r\n", unmatched="vi mode replace char, default timeout: long delay"
|
|
|
|
)
|
|
|
|
|
|
|
|
# Test deleting characters with 'x'.
|
2020-06-05 01:13:39 +00:00
|
|
|
send("echo MORE-TEXT")
|
|
|
|
send("\033")
|
2020-03-02 23:20:29 +00:00
|
|
|
# Delay needed to allow fish to transition to vi "normal" mode.
|
2021-05-03 10:13:18 +00:00
|
|
|
sleep(0.300)
|
2020-06-05 01:13:39 +00:00
|
|
|
send("xxxxx\r")
|
2020-03-02 23:20:29 +00:00
|
|
|
|
|
|
|
# vi mode delete char, default timeout: long delay
|
2020-06-05 01:13:39 +00:00
|
|
|
expect_prompt(
|
2020-03-02 23:20:29 +00:00
|
|
|
"\r\nMORE\r\n", unmatched="vi mode delete char, default timeout: long delay"
|
|
|
|
)
|
|
|
|
|
|
|
|
# Test jumping forward til before a character with t
|
2020-06-05 01:13:39 +00:00
|
|
|
send("echo MORE-TEXT-IS-NICE")
|
|
|
|
send("\033")
|
2020-03-02 23:20:29 +00:00
|
|
|
# Delay needed to allow fish to transition to vi "normal" mode.
|
2020-06-05 01:13:39 +00:00
|
|
|
sleep(0.250)
|
|
|
|
send("0tTD\r")
|
2020-03-02 23:20:29 +00:00
|
|
|
|
|
|
|
# vi mode forward-jump-till character, default timeout: long delay
|
2020-06-05 01:13:39 +00:00
|
|
|
expect_prompt(
|
2020-03-02 23:20:29 +00:00
|
|
|
"\r\nMORE\r\n",
|
|
|
|
unmatched="vi mode forward-jump-till character, default timeout: long delay",
|
|
|
|
)
|
|
|
|
|
2021-09-24 18:41:09 +00:00
|
|
|
# DISABLED BECAUSE IT FAILS ON GITHUB ACTIONS
|
2020-03-02 23:20:29 +00:00
|
|
|
# Test jumping backward til before a character with T
|
2021-09-24 18:41:09 +00:00
|
|
|
# send("echo MORE-TEXT-IS-NICE")
|
|
|
|
# send("\033")
|
|
|
|
# # Delay needed to allow fish to transition to vi "normal" mode.
|
|
|
|
# sleep(0.250)
|
|
|
|
# send("TSD\r")
|
|
|
|
# # vi mode backward-jump-till character, default timeout: long delay
|
|
|
|
# expect_prompt(
|
|
|
|
# "\r\nMORE-TEXT-IS\r\n",
|
|
|
|
# unmatched="vi mode backward-jump-till character, default timeout: long delay",
|
|
|
|
# )
|
2020-03-02 23:20:29 +00:00
|
|
|
|
|
|
|
# Test jumping backward with F and repeating
|
2020-06-05 01:13:39 +00:00
|
|
|
send("echo MORE-TEXT-IS-NICE")
|
|
|
|
send("\033")
|
2020-03-02 23:20:29 +00:00
|
|
|
# Delay needed to allow fish to transition to vi "normal" mode.
|
2020-06-05 01:13:39 +00:00
|
|
|
sleep(0.250)
|
|
|
|
send("F-;D\r")
|
2020-03-02 23:20:29 +00:00
|
|
|
# vi mode backward-jump-to character and repeat, default timeout: long delay
|
2020-06-05 01:13:39 +00:00
|
|
|
expect_prompt(
|
2020-03-02 23:20:29 +00:00
|
|
|
"\r\nMORE-TEXT\r\n",
|
|
|
|
unmatched="vi mode backward-jump-to character and repeat, default timeout: long delay",
|
|
|
|
)
|
|
|
|
|
|
|
|
# Test jumping backward with F w/reverse jump
|
2020-06-05 01:13:39 +00:00
|
|
|
send("echo MORE-TEXT-IS-NICE")
|
|
|
|
send("\033")
|
2020-03-02 23:20:29 +00:00
|
|
|
# Delay needed to allow fish to transition to vi "normal" mode.
|
2020-06-05 01:13:39 +00:00
|
|
|
sleep(0.250)
|
|
|
|
send("F-F-,D\r")
|
2020-03-02 23:20:29 +00:00
|
|
|
# vi mode backward-jump-to character, and reverse, default timeout: long delay
|
2020-06-05 01:13:39 +00:00
|
|
|
expect_prompt(
|
2020-03-02 23:20:29 +00:00
|
|
|
"\r\nMORE-TEXT-IS\r\n",
|
|
|
|
unmatched="vi mode backward-jump-to character, and reverse, default timeout: long delay",
|
|
|
|
)
|
|
|
|
|
|
|
|
# Verify that changing the escape timeout has an effect.
|
2020-12-09 16:52:17 +00:00
|
|
|
send("set -g fish_escape_delay_ms 100\r")
|
2020-06-05 01:13:39 +00:00
|
|
|
expect_prompt()
|
|
|
|
|
|
|
|
send("echo fail: lengthened escape timeout")
|
|
|
|
send("\033")
|
2021-05-03 10:13:18 +00:00
|
|
|
sleep(0.300)
|
2020-06-05 01:13:39 +00:00
|
|
|
send("ddi")
|
2021-05-03 10:13:18 +00:00
|
|
|
sleep(0.15)
|
2020-06-05 01:13:39 +00:00
|
|
|
send("echo success: lengthened escape timeout\r")
|
|
|
|
expect_prompt(
|
2020-03-02 23:20:29 +00:00
|
|
|
"\r\nsuccess: lengthened escape timeout\r\n",
|
2020-12-09 16:52:17 +00:00
|
|
|
unmatched="vi replace line, 100ms timeout: long delay",
|
2020-03-02 23:20:29 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
# Verify that we don't switch to vi normal mode if we don't wait long enough
|
|
|
|
# after sending escape.
|
2020-06-05 01:13:39 +00:00
|
|
|
send("echo fail: no normal mode")
|
|
|
|
send("\033")
|
2020-11-11 18:00:49 +00:00
|
|
|
sleep(0.010)
|
2020-06-05 01:13:39 +00:00
|
|
|
send("ddi")
|
|
|
|
send("inserted\r")
|
|
|
|
expect_prompt(
|
2020-03-02 23:20:29 +00:00
|
|
|
"\r\nfail: no normal modediinserted\r\n",
|
2020-12-09 16:52:17 +00:00
|
|
|
unmatched="vi replace line, 100ms timeout: short delay",
|
2020-03-02 23:20:29 +00:00
|
|
|
)
|
|
|
|
|
2020-11-11 18:54:25 +00:00
|
|
|
# Now set it back to speed up the tests - these don't use any escape+thing bindings!
|
|
|
|
send("set -g fish_escape_delay_ms 50\r")
|
|
|
|
expect_prompt()
|
|
|
|
|
2020-03-02 23:20:29 +00:00
|
|
|
# Test 't' binding that contains non-zero arity function (forward-jump) followed
|
|
|
|
# by another function (and) https://github.com/fish-shell/fish-shell/issues/2357
|
2020-06-05 01:13:39 +00:00
|
|
|
send("\033")
|
2020-11-11 18:54:25 +00:00
|
|
|
sleep(0.200)
|
2021-04-22 19:43:04 +00:00
|
|
|
send("ddiecho TEXT")
|
|
|
|
expect_str("echo TEXT")
|
|
|
|
send("\033")
|
2020-11-11 18:54:25 +00:00
|
|
|
sleep(0.200)
|
2020-06-05 01:13:39 +00:00
|
|
|
send("hhtTrN\r")
|
|
|
|
expect_prompt("\r\nTENT\r\n", unmatched="Couldn't find expected output 'TENT'")
|
2020-03-02 23:20:29 +00:00
|
|
|
|
|
|
|
# Test '~' (togglecase-char)
|
2021-01-26 06:07:51 +00:00
|
|
|
# HACK: Deactivated because it keeps failing on CI
|
|
|
|
# send("\033")
|
|
|
|
# sleep(0.100)
|
|
|
|
# send("cc")
|
|
|
|
# sleep(0.50)
|
|
|
|
# send("echo some TExT\033")
|
|
|
|
# sleep(0.300)
|
|
|
|
# send("hh~~bbve~\r")
|
|
|
|
# expect_prompt("\r\nSOME TeXT\r\n", unmatched="Couldn't find expected output 'SOME TeXT")
|
2020-03-02 23:20:29 +00:00
|
|
|
|
|
|
|
# Now test that exactly the expected bind modes are defined
|
2020-06-05 01:13:39 +00:00
|
|
|
sendline("bind --list-modes")
|
|
|
|
expect_prompt(
|
2020-03-02 23:20:29 +00:00
|
|
|
"\r\ndefault\r\ninsert\r\npaste\r\nreplace\r\nreplace_one\r\nvisual\r\n",
|
|
|
|
unmatched="Unexpected vi bind modes",
|
|
|
|
)
|
|
|
|
|
|
|
|
# Switch back to regular (emacs mode) key bindings.
|
2020-06-05 01:13:39 +00:00
|
|
|
sendline("set -g fish_key_bindings fish_default_key_bindings")
|
|
|
|
expect_prompt()
|
2020-03-02 23:20:29 +00:00
|
|
|
|
2020-11-11 18:54:25 +00:00
|
|
|
# Verify the custom escape timeout set earlier is still in effect.
|
2020-06-05 01:13:39 +00:00
|
|
|
sendline("echo fish_escape_delay_ms=$fish_escape_delay_ms")
|
|
|
|
expect_prompt(
|
2020-11-11 18:54:25 +00:00
|
|
|
"\r\nfish_escape_delay_ms=50\r\n",
|
2020-03-02 23:20:29 +00:00
|
|
|
unmatched="default-mode custom timeout not set correctly",
|
|
|
|
)
|
|
|
|
|
2020-12-09 16:52:17 +00:00
|
|
|
sendline("set -g fish_escape_delay_ms 200")
|
2020-06-05 01:13:39 +00:00
|
|
|
expect_prompt()
|
2020-03-02 23:20:29 +00:00
|
|
|
|
|
|
|
# Verify the emacs transpose word (\et) behavior using various delays,
|
|
|
|
# including none, after the escape character.
|
|
|
|
|
|
|
|
# Start by testing with no delay. This should transpose the words.
|
2020-06-05 01:13:39 +00:00
|
|
|
send("echo abc def")
|
|
|
|
send("\033")
|
|
|
|
send("t\r")
|
|
|
|
expect_prompt(
|
2020-12-09 16:52:17 +00:00
|
|
|
"\r\ndef abc\r\n", unmatched="emacs transpose words fail, 200ms timeout: no delay"
|
2020-03-02 23:20:29 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
# Same test as above but with a slight delay less than the escape timeout.
|
2020-06-05 01:13:39 +00:00
|
|
|
send("echo ghi jkl")
|
|
|
|
send("\033")
|
2020-11-09 18:53:27 +00:00
|
|
|
sleep(0.020)
|
2020-06-05 01:13:39 +00:00
|
|
|
send("t\r")
|
|
|
|
expect_prompt(
|
2020-03-02 23:20:29 +00:00
|
|
|
"\r\njkl ghi\r\n",
|
2020-12-09 16:52:17 +00:00
|
|
|
unmatched="emacs transpose words fail, 200ms timeout: short delay",
|
2020-03-02 23:20:29 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
# Now test with a delay > the escape timeout. The transposition should not
|
|
|
|
# occur and the "t" should become part of the text that is echoed.
|
2020-06-05 01:13:39 +00:00
|
|
|
send("echo mno pqr")
|
|
|
|
send("\033")
|
2020-12-13 13:57:37 +00:00
|
|
|
sleep(0.350)
|
2020-06-05 01:13:39 +00:00
|
|
|
send("t\r")
|
2020-03-02 23:20:29 +00:00
|
|
|
# emacs transpose words, 100ms timeout: long delay
|
2020-06-05 01:13:39 +00:00
|
|
|
expect_prompt(
|
2020-03-02 23:20:29 +00:00
|
|
|
"\r\nmno pqrt\r\n",
|
2020-12-09 16:52:17 +00:00
|
|
|
unmatched="emacs transpose words fail, 200ms timeout: long delay",
|
2020-03-02 23:20:29 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
# Verify special characters, such as \cV, are not intercepted by the kernel
|
|
|
|
# tty driver. Rather, they can be bound and handled by fish.
|
2020-06-05 01:13:39 +00:00
|
|
|
sendline("bind \\cV 'echo ctrl-v seen'")
|
|
|
|
expect_prompt()
|
|
|
|
send("\026\r")
|
|
|
|
expect_prompt("ctrl-v seen", unmatched="ctrl-v not seen")
|
2020-03-02 23:20:29 +00:00
|
|
|
|
2020-06-05 01:13:39 +00:00
|
|
|
send("bind \\cO 'echo ctrl-o seen'\r")
|
|
|
|
expect_prompt()
|
|
|
|
send("\017\r")
|
|
|
|
expect_prompt("ctrl-o seen", unmatched="ctrl-o not seen")
|
2020-03-02 23:20:29 +00:00
|
|
|
|
|
|
|
# \x17 is ctrl-w.
|
2020-06-05 01:13:39 +00:00
|
|
|
send("echo git@github.com:fish-shell/fish-shell")
|
|
|
|
send("\x17\x17\r")
|
|
|
|
expect_prompt("git@github.com:", unmatched="ctrl-w does not stop at :")
|
2020-03-02 23:20:29 +00:00
|
|
|
|
2020-06-05 01:13:39 +00:00
|
|
|
send("echo git@github.com:fish-shell/fish-shell")
|
|
|
|
send("\x17\x17\x17\r")
|
|
|
|
expect_prompt("git@", unmatched="ctrl-w does not stop at @")
|
2020-03-02 23:20:29 +00:00
|
|
|
|
|
|
|
# Ensure that nul can be bound properly (#3189).
|
2020-06-05 01:13:39 +00:00
|
|
|
send("bind -k nul 'echo nul seen'\r")
|
2020-08-23 00:48:50 +00:00
|
|
|
expect_prompt()
|
2020-06-05 01:13:39 +00:00
|
|
|
send("\0" * 3)
|
2020-11-20 03:15:37 +00:00
|
|
|
# We need to sleep briefly before emitting a newline, because when we execute the
|
|
|
|
# key bindings above we place the tty in external-proc mode (see #7483) and restoring
|
|
|
|
# the mode to shell-mode races with the newline emitted below (i.e. sometimes it may
|
|
|
|
# be echoed).
|
|
|
|
sleep(0.1)
|
2020-06-05 01:13:39 +00:00
|
|
|
send("\r")
|
|
|
|
expect_prompt("nul seen\r\nnul seen\r\nnul seen", unmatched="nul not seen")
|
2020-03-02 23:20:29 +00:00
|
|
|
|
|
|
|
# Test self-insert-notfirst. (#6603)
|
|
|
|
# Here the leading 'q's should be stripped, but the trailing ones not.
|
2020-06-05 01:13:39 +00:00
|
|
|
sendline("bind q self-insert-notfirst")
|
|
|
|
expect_prompt()
|
|
|
|
sendline("qqqecho qqq")
|
|
|
|
expect_prompt("qqq", unmatched="Leading qs not stripped")
|
2020-09-11 18:13:06 +00:00
|
|
|
|
|
|
|
# Test bigword with single-character words.
|
|
|
|
sendline("bind \cg kill-bigword")
|
|
|
|
expect_prompt()
|
2020-10-06 21:22:35 +00:00
|
|
|
send("a b c d\x01") # ctrl-a, move back to the beginning of the line
|
|
|
|
send("\x07") # ctrl-g, kill bigword
|
2020-09-11 18:13:06 +00:00
|
|
|
sendline("echo")
|
2020-10-06 23:03:06 +00:00
|
|
|
expect_prompt("\nb c d")
|
2020-09-11 18:13:06 +00:00
|
|
|
|
2020-10-06 21:22:35 +00:00
|
|
|
send(" a b c d\x01") # ctrl-a, move back to the beginning of the line
|
|
|
|
send("\x07") # ctrl-g, kill bigword
|
2020-09-11 18:13:06 +00:00
|
|
|
sendline("echo")
|
2020-10-06 23:03:06 +00:00
|
|
|
expect_prompt("\nb c d")
|
2020-10-14 17:26:13 +00:00
|
|
|
|
|
|
|
# Check that ctrl-z can be bound
|
|
|
|
sendline('bind \cz "echo bound ctrl-z"')
|
|
|
|
expect_prompt()
|
2020-11-22 13:39:48 +00:00
|
|
|
send("\x1A")
|
2020-10-14 17:26:13 +00:00
|
|
|
expect_str("bound ctrl-z")
|
2021-05-02 18:20:48 +00:00
|
|
|
|
|
|
|
# Check that the builtin version of `exit` works
|
|
|
|
# (for obvious reasons this MUST BE LAST)
|
|
|
|
sendline('function myexit; echo exit; exit; end; bind \cz myexit')
|
|
|
|
expect_prompt()
|
|
|
|
send("\x1A")
|
|
|
|
expect_str("exit")
|
|
|
|
|
2021-05-03 09:26:41 +00:00
|
|
|
for t in range(0, 50):
|
2021-05-02 18:20:48 +00:00
|
|
|
if not sp.spawn.isalive():
|
|
|
|
break
|
|
|
|
# This is cheesy, but on CI with thread-sanitizer this can be slow enough that the process is still running, so we sleep for a bit.
|
2021-05-03 09:26:41 +00:00
|
|
|
sleep(0.1)
|
2021-05-02 18:20:48 +00:00
|
|
|
else:
|
|
|
|
print("Fish did not exit via binding!")
|
|
|
|
sys.exit(1)
|