[gdb/testsuite] Handle PS1 quirk in gdb.base/multi-line-starts-subshell.exp
authorTom de Vries <tdevries@suse.de>
Tue, 15 Dec 2020 09:18:23 +0000 (10:18 +0100)
committerTom de Vries <tdevries@suse.de>
Tue, 15 Dec 2020 09:18:23 +0000 (10:18 +0100)
On SLE-11, I run into:
...
(gdb) if 1^M
 >shell HOME=/dev/null PS1="gdb-subshell$ " /bin/sh^M
 >end^M
hostname:/dir> FAIL: gdb.base/multi-line-starts-subshell.exp: \
  spawn subshell from multi-line (timeout)
...

The problem is that the PS1 setting has no effect, due to a bug on older
openSUSE/SLE version.  The mechanism there is:
- /etc/profile sets ENV=/etc/bash.bashrc
- /bin/sh is started
- /bin/sh executes ENV, in other words /etc/bash.bashrc
- during the execution of /etc/bash.bashrc, PS1 is set unconditionally

Fix this by setting PS1 after spawning the subshell.

Tested on x86_64-linux.

2020-12-15  Tom de Vries  <tdevries@suse.de>

PR testsuite/26952
* gdb.base/multi-line-starts-subshell.exp: Set PS1 after spawning
shell.

gdb/testsuite/gdb.base/multi-line-starts-subshell.exp

index 710c3916c6ec90b50971953fe31523b2dad2ea52..dc6d70582a8ec0dd98365b3d657b60358ef5564a 100644 (file)
@@ -27,11 +27,11 @@ set shell_prompt_re [string_to_regexp $shell_prompt]
 
 # Point HOME nowhere to avoid the shell sourcing the user's init
 # scripts.
-set shell_cmd "HOME=/dev/null PS1=\"$shell_prompt\" /bin/sh"
+set shell_cmd "HOME=/dev/null /bin/sh"
 
 set test "spawn subshell from multi-line"
-gdb_test_multiple "if 1\nshell ${shell_cmd}\nend" $test {
-    -re "$shell_prompt_re$" {
+gdb_test_multiple "if 1\nshell ${shell_cmd}\nend\nPS1=\"$shell_prompt\"" $test {
+    -re "PS1=\[^\r\n\]*\r\n$shell_prompt_re$" {
        pass $test
 
        # Now check that shell input works and that echo is enabled.