Commit 900f2dc9 authored by Alessio Caiazza's avatar Alessio Caiazza

Check waitDone channel only in case of os.PathError

parent 979ae9aa
...@@ -6,6 +6,7 @@ import ( ...@@ -6,6 +6,7 @@ import (
"errors" "errors"
"fmt" "fmt"
"io" "io"
"os"
"os/exec" "os/exec"
"regexp" "regexp"
...@@ -37,24 +38,30 @@ func NewCleaner(ctx context.Context, stdin io.Reader) (io.Reader, error) { ...@@ -37,24 +38,30 @@ func NewCleaner(ctx context.Context, stdin io.Reader) (io.Reader, error) {
} }
func (c *cleaner) Read(p []byte) (int, error) { func (c *cleaner) Read(p []byte) (int, error) {
select { n, err := c.stdout.Read(p)
case <-c.waitDone: if err == io.EOF {
return 0, io.EOF if waitErr := c.wait(); waitErr != nil {
default: log.WithContextFields(c.ctx, log.Fields{
n, err := c.stdout.Read(p) "command": c.cmd.Args,
if err == io.EOF { "stderr": c.stderr.String(),
if waitErr := c.wait(); waitErr != nil { "error": waitErr.Error(),
log.WithContextFields(c.ctx, log.Fields{ }).Print("exiftool command failed")
"command": c.cmd.Args, return n, ErrRemovingExif
"stderr": c.stderr.String(),
"error": waitErr.Error(),
}).Print("exiftool command failed")
return n, ErrRemovingExif
}
} }
}
return n, err // Calling c.cmd.Wait() will close the stdout pipe, any attempt to read from it will fail with an os.PathError.
// see: https://gitlab.com/gitlab-org/gitlab-workhorse/-/issues/233
if _, ok := err.(*os.PathError); ok {
select {
case <-c.waitDone:
return n, io.EOF
default:
return n, err
}
} }
return n, err
} }
func (c *cleaner) startProcessing(stdin io.Reader) error { func (c *cleaner) startProcessing(stdin io.Reader) error {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment