http: fix backend with --files-from and non-existent files

Before this fix the http backend was returning the wrong error code
when files were not found.  This was causing --files-from to error on
missing files instead of skipping them like it should.
This commit is contained in:
Nick Craig-Wood 2018-12-04 17:40:44 +00:00
parent 26b5f55cba
commit fc654a4cec
2 changed files with 9 additions and 1 deletions

View file

@ -193,7 +193,7 @@ func (f *Fs) NewObject(remote string) (fs.Object, error) {
} }
err := o.stat() err := o.stat()
if err != nil { if err != nil {
return nil, errors.Wrap(err, "Stat failed") return nil, err
} }
return o, nil return o, nil
} }
@ -416,6 +416,9 @@ func (o *Object) url() string {
func (o *Object) stat() error { func (o *Object) stat() error {
url := o.url() url := o.url()
res, err := o.fs.httpClient.Head(url) res, err := o.fs.httpClient.Head(url)
if err == nil && res.StatusCode == http.StatusNotFound {
return fs.ErrorObjectNotFound
}
err = statusError(res, err) err = statusError(res, err)
if err != nil { if err != nil {
return errors.Wrap(err, "failed to stat") return errors.Wrap(err, "failed to stat")

View file

@ -144,6 +144,11 @@ func TestNewObject(t *testing.T) {
dt, ok := fstest.CheckTimeEqualWithPrecision(tObj, tFile, time.Second) dt, ok := fstest.CheckTimeEqualWithPrecision(tObj, tFile, time.Second)
assert.True(t, ok, fmt.Sprintf("%s: Modification time difference too big |%s| > %s (%s vs %s) (precision %s)", o.Remote(), dt, time.Second, tObj, tFile, time.Second)) assert.True(t, ok, fmt.Sprintf("%s: Modification time difference too big |%s| > %s (%s vs %s) (precision %s)", o.Remote(), dt, time.Second, tObj, tFile, time.Second))
// check object not found
o, err = f.NewObject("not found.txt")
assert.Nil(t, o)
assert.Equal(t, fs.ErrorObjectNotFound, err)
} }
func TestOpen(t *testing.T) { func TestOpen(t *testing.T) {