use a perl test for fd-cloexec to avoid testing the tester with the tester; improve fd-cloexec description
This commit is contained in:
parent
1351c5eb0f
commit
0947d274f6
42
check.t
42
check.t
@ -1,4 +1,4 @@
|
|||||||
# $MirOS: src/bin/mksh/check.t,v 1.685 2015/03/14 05:23:12 tg Exp $
|
# $MirOS: src/bin/mksh/check.t,v 1.686 2015/03/20 23:37:27 tg Exp $
|
||||||
# -*- mode: sh -*-
|
# -*- mode: sh -*-
|
||||||
#-
|
#-
|
||||||
# Copyright © 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010,
|
# Copyright © 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010,
|
||||||
@ -9756,25 +9756,33 @@ description:
|
|||||||
Verify that file descriptors > 2 are private for Korn shells
|
Verify that file descriptors > 2 are private for Korn shells
|
||||||
AT&T ksh93 does this still, which means we must keep it as well
|
AT&T ksh93 does this still, which means we must keep it as well
|
||||||
category: shell:legacy-no
|
category: shell:legacy-no
|
||||||
file-setup: file 644 "test.sh"
|
|
||||||
echo >&3 Fowl
|
|
||||||
stdin:
|
stdin:
|
||||||
exec 3>&1
|
cat >cld <<-EOF
|
||||||
"$__progname" test.sh
|
#!$__perlname
|
||||||
|
open(my \$fh, ">&", 9) or die "E: open \$!";
|
||||||
|
syswrite(\$fh, "Fowl\\n", 5) or die "E: write \$!";
|
||||||
|
EOF
|
||||||
|
chmod +x cld
|
||||||
|
exec 9>&1
|
||||||
|
./cld
|
||||||
expected-exit: e != 0
|
expected-exit: e != 0
|
||||||
expected-stderr-pattern:
|
expected-stderr-pattern:
|
||||||
/bad file descriptor/
|
/E: open /
|
||||||
---
|
---
|
||||||
name: fd-cloexec-2
|
name: fd-cloexec-2
|
||||||
description:
|
description:
|
||||||
Verify that file descriptors > 2 are not private for POSIX shells
|
Verify that file descriptors > 2 are not private for POSIX shells
|
||||||
See Debian Bug #154540, Closes: #499139
|
See Debian Bug #154540, Closes: #499139
|
||||||
file-setup: file 644 "test.sh"
|
|
||||||
echo >&3 Fowl
|
|
||||||
stdin:
|
stdin:
|
||||||
test -n "$POSH_VERSION" || set -o sh
|
cat >cld <<-EOF
|
||||||
exec 3>&1
|
#!$__perlname
|
||||||
"$__progname" test.sh
|
open(my \$fh, ">&", 9) or die "E: open \$!";
|
||||||
|
syswrite(\$fh, "Fowl\\n", 5) or die "E: write \$!";
|
||||||
|
EOF
|
||||||
|
chmod +x cld
|
||||||
|
test -n "$POSH_VERSION" || set -o posix
|
||||||
|
exec 9>&1
|
||||||
|
./cld
|
||||||
expected-stdout:
|
expected-stdout:
|
||||||
Fowl
|
Fowl
|
||||||
---
|
---
|
||||||
@ -9782,11 +9790,15 @@ name: fd-cloexec-3
|
|||||||
description:
|
description:
|
||||||
Verify that file descriptors > 2 are not private for LEGACY KSH
|
Verify that file descriptors > 2 are not private for LEGACY KSH
|
||||||
category: shell:legacy-yes
|
category: shell:legacy-yes
|
||||||
file-setup: file 644 "test.sh"
|
|
||||||
echo >&3 Fowl
|
|
||||||
stdin:
|
stdin:
|
||||||
exec 3>&1
|
cat >cld <<-EOF
|
||||||
"$__progname" test.sh
|
#!$__perlname
|
||||||
|
open(my \$fh, ">&", 9) or die "E: open \$!";
|
||||||
|
syswrite(\$fh, "Fowl\\n", 5) or die "E: write \$!";
|
||||||
|
EOF
|
||||||
|
chmod +x cld
|
||||||
|
exec 9>&1
|
||||||
|
./cld
|
||||||
expected-stdout:
|
expected-stdout:
|
||||||
Fowl
|
Fowl
|
||||||
---
|
---
|
||||||
|
18
lksh.1
18
lksh.1
@ -1,6 +1,6 @@
|
|||||||
.\" $MirOS: src/bin/mksh/lksh.1,v 1.5 2013/05/22 18:18:06 tg Exp $
|
.\" $MirOS: src/bin/mksh/lksh.1,v 1.6 2015/03/20 23:37:29 tg Exp $
|
||||||
.\"-
|
.\"-
|
||||||
.\" Copyright (c) 2008, 2009, 2010, 2012, 2013
|
.\" Copyright (c) 2008, 2009, 2010, 2012, 2013, 2015
|
||||||
.\" Thorsten “mirabilos” Glaser <tg@mirbsd.org>
|
.\" Thorsten “mirabilos” Glaser <tg@mirbsd.org>
|
||||||
.\"
|
.\"
|
||||||
.\" Provided that these terms and disclaimer and all copyright notices
|
.\" Provided that these terms and disclaimer and all copyright notices
|
||||||
@ -72,7 +72,7 @@
|
|||||||
.\" with -mandoc, it might implement .Mx itself, but we want to
|
.\" with -mandoc, it might implement .Mx itself, but we want to
|
||||||
.\" use our own definition. And .Dd must come *first*, always.
|
.\" use our own definition. And .Dd must come *first*, always.
|
||||||
.\"
|
.\"
|
||||||
.Dd $Mdocdate: May 22 2013 $
|
.Dd $Mdocdate: March 20 2015 $
|
||||||
.\"
|
.\"
|
||||||
.\" Check which macro package we use, and do other -mdoc setup.
|
.\" Check which macro package we use, and do other -mdoc setup.
|
||||||
.\"
|
.\"
|
||||||
@ -245,11 +245,17 @@ passes through the errorlevel from the
|
|||||||
.Xr getopt 1
|
.Xr getopt 1
|
||||||
command.
|
command.
|
||||||
.It
|
.It
|
||||||
.Nm lksh ,
|
Unlike
|
||||||
unlike
|
|
||||||
.At
|
.At
|
||||||
.Nm ksh ,
|
.Nm ksh ,
|
||||||
does not keep file descriptors \*(Gt 2 private.
|
.Nm mksh
|
||||||
|
in
|
||||||
|
.Fl o Ic posix
|
||||||
|
or
|
||||||
|
.Fl o Ic sh
|
||||||
|
mode and
|
||||||
|
.Nm lksh
|
||||||
|
do not keep file descriptors \*(Gt 2 private from sub-processes.
|
||||||
.El
|
.El
|
||||||
.Sh SEE ALSO
|
.Sh SEE ALSO
|
||||||
.Xr mksh 1
|
.Xr mksh 1
|
||||||
|
Loading…
x
Reference in New Issue
Block a user