forked from TrueCloudLab/rclone
drive: check Open calls for google error messages
This should also enable Open calls to retry properly
This commit is contained in:
parent
dcf8334673
commit
e82452ce9a
1 changed files with 8 additions and 7 deletions
|
@ -1487,6 +1487,12 @@ func (o *Object) httpResponse(method string, options []fs.OpenOption) (req *http
|
||||||
fs.OpenOptionAddHTTPHeaders(req.Header, options)
|
fs.OpenOptionAddHTTPHeaders(req.Header, options)
|
||||||
err = o.fs.pacer.Call(func() (bool, error) {
|
err = o.fs.pacer.Call(func() (bool, error) {
|
||||||
res, err = o.fs.client.Do(req)
|
res, err = o.fs.client.Do(req)
|
||||||
|
if err == nil {
|
||||||
|
err = googleapi.CheckResponse(res)
|
||||||
|
if err != nil {
|
||||||
|
_ = res.Body.Close() // ignore error
|
||||||
|
}
|
||||||
|
}
|
||||||
return shouldRetry(err)
|
return shouldRetry(err)
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -1532,14 +1538,9 @@ var _ io.ReadCloser = &openFile{}
|
||||||
|
|
||||||
// Open an object for read
|
// Open an object for read
|
||||||
func (o *Object) Open(options ...fs.OpenOption) (in io.ReadCloser, err error) {
|
func (o *Object) Open(options ...fs.OpenOption) (in io.ReadCloser, err error) {
|
||||||
req, res, err := o.httpResponse("GET", options)
|
_, res, err := o.httpResponse("GET", options)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, errors.Wrap(err, "open file failed")
|
||||||
}
|
|
||||||
_, isRanging := req.Header["Range"]
|
|
||||||
if !(res.StatusCode == http.StatusOK || (isRanging && res.StatusCode == http.StatusPartialContent)) {
|
|
||||||
_ = res.Body.Close() // ignore error
|
|
||||||
return nil, errors.Errorf("bad response: %d: %s", res.StatusCode, res.Status)
|
|
||||||
}
|
}
|
||||||
// If it is a document, update the size with what we are
|
// If it is a document, update the size with what we are
|
||||||
// reading as it can change from the HEAD in the listing to
|
// reading as it can change from the HEAD in the listing to
|
||||||
|
|
Loading…
Reference in a new issue