mirror of
https://github.com/fish-shell/fish-shell.git
synced 2024-11-25 18:03:37 +08:00
ab5d7f80d0
And again clang-format does something I don't like: - if (found != end && std::strncmp(found->name, name, len) == 0 && found->name[len] == 0) return found; + if (found != end && std::strncmp(found->name, name, len) == 0 && found->name[len] == 0) + return found; I *know* this is a bit of a long line. I would still quite like having no brace-less multi-line if *ever*. Either put the body on the same line, or add braces. Blergh
43 lines
1.3 KiB
Python
43 lines
1.3 KiB
Python
#!/usr/bin/env python3
|
|
from pexpect_helper import SpawnedProc
|
|
|
|
sp = SpawnedProc()
|
|
send, sendline, expect_prompt, expect_str = (
|
|
sp.send,
|
|
sp.sendline,
|
|
sp.expect_prompt,
|
|
sp.expect_str,
|
|
)
|
|
|
|
expect_prompt()
|
|
sendline("function echo_wrap ; /bin/echo $argv ; sleep 0.1; end")
|
|
expect_prompt()
|
|
|
|
for i in range(5):
|
|
sendline(
|
|
"echo_wrap 1 2 3 4 | $fish_test_helper become_foreground_then_print_stderr ; or exit 1"
|
|
)
|
|
expect_prompt("become_foreground_then_print_stderr done")
|
|
|
|
# 'not' because we expect to have no jobs, in which case `jobs` will return false
|
|
sendline("not jobs")
|
|
expect_prompt("jobs: There are no jobs")
|
|
|
|
sendline("function inner ; command true ; end; function outer; inner; end")
|
|
expect_prompt()
|
|
for i in range(5):
|
|
sendline(
|
|
"outer | $fish_test_helper become_foreground_then_print_stderr ; or exit 1"
|
|
)
|
|
expect_prompt("become_foreground_then_print_stderr done")
|
|
|
|
sendline("not jobs")
|
|
expect_prompt("jobs: There are no jobs", unmatched="Should be no jobs")
|
|
|
|
# Check that this weird invalid double-redirection doesn't crash fish.
|
|
sendline("cat | cat </non/existent/file")
|
|
expect_str("warning: An error occurred while redirecting file '/non/existent/file'")
|
|
expect_str("open: No such file or directory")
|
|
send("\x04")
|
|
expect_prompt()
|