diff options
| author | Petter Rasmussen | 2016-02-06 15:07:24 +0100 | 
|---|---|---|
| committer | Petter Rasmussen | 2016-02-06 15:07:24 +0100 | 
| commit | b7e45b080ffe13d286be65ce396da47b36a16944 (patch) | |
| tree | 9059e8b0b19160bb0fbc5a95c27e6e0f1621b972 /drive/sync_upload.go | |
| parent | ce32c7536cf40afae065b09018c05da6ba221c55 (diff) | |
| download | gdrive-b7e45b080ffe13d286be65ce396da47b36a16944.tar.bz2 | |
Retry file upload on backend error
Diffstat (limited to 'drive/sync_upload.go')
| -rw-r--r-- | drive/sync_upload.go | 12 | 
1 files changed, 9 insertions, 3 deletions
| diff --git a/drive/sync_upload.go b/drive/sync_upload.go index 445ed42..c4df1e8 100644 --- a/drive/sync_upload.go +++ b/drive/sync_upload.go @@ -185,7 +185,7 @@ func (self *Drive) uploadMissingFiles(files *syncFiles, args UploadSyncArgs) err              continue          } -        err := self.uploadMissingFile(parent.file.Id, lf, args) +        err := self.uploadMissingFile(parent.file.Id, lf, args, 0)          if err != nil {              return err          } @@ -245,7 +245,7 @@ func (self *Drive) deleteExtraneousRemoteFiles(files *syncFiles, args UploadSync      return nil  } -func (self *Drive) uploadMissingFile(parentId string, lf *LocalFile, args UploadSyncArgs) error { +func (self *Drive) uploadMissingFile(parentId string, lf *LocalFile, args UploadSyncArgs, try int) error {      srcFile, err := os.Open(lf.absPath)      if err != nil {          return fmt.Errorf("Failed to open file: %s", err) @@ -269,7 +269,13 @@ func (self *Drive) uploadMissingFile(parentId string, lf *LocalFile, args Upload      _, err = self.service.Files.Create(dstFile).Fields("id", "name", "size", "md5Checksum").Media(srcReader, chunkSize).Do()      if err != nil { -        return fmt.Errorf("Failed to upload file: %s", err) +        if isBackendError(err) && try < MaxBackendErrorRetries { +            exponentialBackoffSleep(try) +            try++ +            self.uploadMissingFile(parentId, lf, args, try) +        } else { +            return fmt.Errorf("Failed to upload file: %s", err) +        }      }      return nil | 
