-
Notifications
You must be signed in to change notification settings - Fork 95
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Background subshells may finalize session #25
Comments
@davefx Could you also post the version of bash you're using? echo "$BASH_VERSION" |
Believe this is impacting bash versions > 4.2.46 |
I've reproduced this problem with bash 4.3.42(1) and 4.3.30(1). As some other tips: |
Was able to boil this down to a simple code block to recreate. Still not sure the best way to handle this # Causes login shells to logout
# Look like bash versions > 4.2.46
set -o functrace > /dev/null 2>&1
no_op() { :;}
trap 'no_op' DEBUG;
# Any command in a subshell and background
( pwd ) & |
@davefx was this occurring on a box you were ssh'd into? I can't recreate this locally regardless of the version. I can only recreate when ssh'd onto a box. |
No. This happens also locally in X terminals in my Ubuntu 16.04 system with bash 4.3.46(1)-release. |
- it can be enabled by setting __bp_enable_subshells
- it can be enabled by setting __bp_enable_subshells
Add option to disable subshells to help with #25
Looks like this got mentioned to some folks on the GNU mailing list. Looking into this as a bug in bash. http://lists.gnu.org/archive/html/bug-bash/2016-09/msg00006.html |
When the DEBUG trap is set with functrace on, it causes other problems too. E.g., certain command groups piped to a pager program will get stopped (via SIGTTOU/SIGTTIN when the pager accesses the tty):
In general (with functrace on and the DEBUG trap set) a group of command pipelines in the form below will get stopped:
This happens if the first command of the group (cmd_a) is not a bash builtin AND a pipeline occurs later in the group (cmd_b | cmd_c). (Puzzlingly, the issue does not arise if in the command group either the first command (cmd_a) is a bash builtin or if none of the later commands contains a pipe.) |
Just for reference, I originally reported this as bash bug [1] without realizing that I actually had functrace/DEBUG on, but when the bash maintainers could not reproduce it, I traced it to my preexec setup and eventually on to functrace/DEBUG [2]. [1] http://lists.gnu.org/archive/html/bug-bash/2016-09/msg00127.html |
@adggit thanks for posting for reference! This issue is a real pain. The good news is, preexec can now be implemented with $PS0 in bash 4.4. I'd love to add version detection to bash-preexec and install hooks to $PS0 if you're using the latest versions of Bash. Mentioned originally in #28 Would love a PR from someone on this. |
bash 5.2.15(1) (debian stable) - this particular problem doesn't appear to be a problem anymore? 5 minutes of testing hasn't popped anything up anyway. Time to reenable it by default for $BASH_VERSINFO[...] > ...? But I'll put a caution regarding $PS0 against #28. |
I now tried. The problem reproduces with 4.3 and 4.4, but it doesn't with 5.0, 5.1, 5.2, and the devel version. |
Not so fast! I have found a pretty reliable reproducer, but I haven't yet whittled it down to something simple (the shell function I'm using as a wrapper around sudo isn't reproducing when I just run the simple sudo it boils down to!
vs
I've got to go to bed because it's 3am (goddamit 2300 nT auroral substorm guarantees 100% cloud coverage), but here's my sillysu() function if you want to see whether you can see a reproducer in there. Who knows whether it's pulling in something else in my environment that means you won't be able to trigger it:
|
Hah! Here I was getting sidetracked by sudo and it failing to reproduce in my remote testing sessions because $DISPLAY wasn't set, and then finally by all of my testing been done with the echo command which is a bash builtin except when being invoked through sudo. Is this reproducing for others with bash 5.15 versions?
No setup needed except:
|
After loading bash-preexec.sh, if I launch, for example:
$ ( ls ) &
most of the times, bash exits (not always).
The text was updated successfully, but these errors were encountered: