Compare commits
3 commits
tcl/master
...
debug-stat
Author | SHA1 | Date | |
---|---|---|---|
|
e1bb2129ad | ||
|
95b7f8dd81 | ||
|
29e39e247a |
3 changed files with 22 additions and 2 deletions
|
@ -57,6 +57,7 @@ func (be *RetryBackend) retry(ctx context.Context, msg string, f func() error) e
|
||||||
|
|
||||||
// Save stores the data in the backend under the given handle.
|
// Save stores the data in the backend under the given handle.
|
||||||
func (be *RetryBackend) Save(ctx context.Context, h restic.Handle, rd restic.RewindReader) error {
|
func (be *RetryBackend) Save(ctx context.Context, h restic.Handle, rd restic.RewindReader) error {
|
||||||
|
firstTry := true
|
||||||
return be.retry(ctx, fmt.Sprintf("Save(%v)", h), func() error {
|
return be.retry(ctx, fmt.Sprintf("Save(%v)", h), func() error {
|
||||||
err := rd.Rewind()
|
err := rd.Rewind()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -65,13 +66,27 @@ func (be *RetryBackend) Save(ctx context.Context, h restic.Handle, rd restic.Rew
|
||||||
|
|
||||||
err = be.Backend.Save(ctx, h, rd)
|
err = be.Backend.Save(ctx, h, rd)
|
||||||
if err == nil {
|
if err == nil {
|
||||||
|
if !firstTry {
|
||||||
|
fi, err := be.Backend.Stat(ctx, h)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if fi.Size != rd.Length() {
|
||||||
|
return fmt.Errorf("Stat after save found unexpected length %q instead of %q", fi.Size, rd.Length())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
firstTry = false
|
||||||
|
|
||||||
debug.Log("Save(%v) failed with error, removing file: %v", h, err)
|
debug.Log("Save(%v) failed with error, removing file: %v", h, err)
|
||||||
rerr := be.Backend.Remove(ctx, h)
|
rerr := be.Backend.Remove(ctx, h)
|
||||||
if rerr != nil {
|
if rerr != nil {
|
||||||
debug.Log("Remove(%v) returned error: %v", h, err)
|
debug.Log("Remove(%v) returned error: %v", h, err)
|
||||||
|
if be.Report != nil {
|
||||||
|
be.Report(fmt.Sprintf("Delete-failed-Save(%v)", h), err, time.Duration(0))
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// return original error
|
// return original error
|
||||||
|
|
|
@ -16,6 +16,7 @@ import (
|
||||||
func TestBackendSaveRetry(t *testing.T) {
|
func TestBackendSaveRetry(t *testing.T) {
|
||||||
buf := bytes.NewBuffer(nil)
|
buf := bytes.NewBuffer(nil)
|
||||||
errcount := 0
|
errcount := 0
|
||||||
|
uploadSize := int64(0)
|
||||||
be := &mock.Backend{
|
be := &mock.Backend{
|
||||||
SaveFn: func(ctx context.Context, h restic.Handle, rd restic.RewindReader) error {
|
SaveFn: func(ctx context.Context, h restic.Handle, rd restic.RewindReader) error {
|
||||||
if errcount == 0 {
|
if errcount == 0 {
|
||||||
|
@ -28,9 +29,13 @@ func TestBackendSaveRetry(t *testing.T) {
|
||||||
return errors.New("injected error")
|
return errors.New("injected error")
|
||||||
}
|
}
|
||||||
|
|
||||||
_, err := io.Copy(buf, rd)
|
var err error
|
||||||
|
uploadSize, err = io.Copy(buf, rd)
|
||||||
return err
|
return err
|
||||||
},
|
},
|
||||||
|
StatFn: func(ctx context.Context, h restic.Handle) (restic.FileInfo, error) {
|
||||||
|
return restic.FileInfo{Name: h.Name, Size: uploadSize}, nil
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
retryBackend := NewRetryBackend(be, 10, nil)
|
retryBackend := NewRetryBackend(be, 10, nil)
|
||||||
|
|
|
@ -277,7 +277,7 @@ func (be *Backend) Save(ctx context.Context, h restic.Handle, rd restic.RewindRe
|
||||||
debug.Log("%v -> %v bytes, err %#v: %v", objName, info.Size, err, err)
|
debug.Log("%v -> %v bytes, err %#v: %v", objName, info.Size, err, err)
|
||||||
|
|
||||||
// sanity check
|
// sanity check
|
||||||
if err != nil && info.Size != rd.Length() {
|
if err == nil && info.Size != rd.Length() {
|
||||||
return errors.Errorf("wrote %d bytes instead of the expected %d bytes", info.Size, rd.Length())
|
return errors.Errorf("wrote %d bytes instead of the expected %d bytes", info.Size, rd.Length())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue