From: Fazlul Shahriar Date: Thu, 21 Nov 2019 09:09:17 +0000 (-0500) Subject: os/exec: ignore hungup error while copying stdin on Plan 9 X-Git-Tag: go1.14beta1~7 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=a3dc6da6d6d25666d24bab293c0990d1b07bb798;p=gostls13.git os/exec: ignore hungup error while copying stdin on Plan 9 Fixes #35753 Change-Id: I38674c59c601785eb25b778dc25efdb92231dd9b Reviewed-on: https://go-review.googlesource.com/c/go/+/208223 Run-TryBot: Emmanuel Odeke TryBot-Result: Gobot Gobot Reviewed-by: Brad Fitzpatrick --- diff --git a/src/os/exec/exec.go b/src/os/exec/exec.go index 0c17b7a35d..3474ae0ca4 100644 --- a/src/os/exec/exec.go +++ b/src/os/exec/exec.go @@ -238,7 +238,6 @@ func (c *Cmd) argv() []string { // skipStdinCopyError optionally specifies a function which reports // whether the provided stdin copy error should be ignored. -// It is non-nil everywhere but Plan 9, which lacks EPIPE. See exec_posix.go. var skipStdinCopyError func(error) bool func (c *Cmd) stdin() (f *os.File, err error) { diff --git a/src/os/exec/exec_plan9.go b/src/os/exec/exec_plan9.go new file mode 100644 index 0000000000..d90bd04399 --- /dev/null +++ b/src/os/exec/exec_plan9.go @@ -0,0 +1,19 @@ +// Copyright 2019 The Go Authors. All rights reserved. +// Use of this source code is governed by a BSD-style +// license that can be found in the LICENSE file. + +package exec + +import "os" + +func init() { + skipStdinCopyError = func(err error) bool { + // Ignore hungup errors copying to stdin if the program + // completed successfully otherwise. + // See Issue 35753. + pe, ok := err.(*os.PathError) + return ok && + pe.Op == "write" && pe.Path == "|1" && + pe.Err.Error() == "i/o on hungup channel" + } +} diff --git a/src/os/exec/exec_test.go b/src/os/exec/exec_test.go index 19bda6902a..dce66c5c2e 100644 --- a/src/os/exec/exec_test.go +++ b/src/os/exec/exec_test.go @@ -974,11 +974,6 @@ func (delayedInfiniteReader) Read(b []byte) (int, error) { func TestIgnorePipeErrorOnSuccess(t *testing.T) { testenv.MustHaveExec(t) - // We really only care about testing this on Unixy and Windowsy things. - if runtime.GOOS == "plan9" { - t.Skipf("skipping test on %q", runtime.GOOS) - } - testWith := func(r io.Reader) func(*testing.T) { return func(t *testing.T) { cmd := helperCommand(t, "echo", "foo")