c81b122374
As the connection to the rclone child process is now closed after an unexpected subprocess exit, later requests will cause the http2 transport to try to reestablish a new connection. As previously this never should have happened, the connection called panic in that case. This panic is now replaced with a simple error message, as it no longer indicates an internal problem.
39 lines
814 B
Go
39 lines
814 B
Go
package rclone
|
|
|
|
import (
|
|
"context"
|
|
"os/exec"
|
|
"testing"
|
|
|
|
"github.com/restic/restic/internal/errors"
|
|
"github.com/restic/restic/internal/restic"
|
|
rtest "github.com/restic/restic/internal/test"
|
|
)
|
|
|
|
// restic should detect rclone exiting.
|
|
func TestRcloneExit(t *testing.T) {
|
|
dir, cleanup := rtest.TempDir(t)
|
|
defer cleanup()
|
|
|
|
cfg := NewConfig()
|
|
cfg.Remote = dir
|
|
be, err := Open(cfg, nil)
|
|
if e, ok := errors.Cause(err).(*exec.Error); ok && e.Err == exec.ErrNotFound {
|
|
t.Skipf("program %q not found", e.Name)
|
|
return
|
|
}
|
|
rtest.OK(t, err)
|
|
defer be.Close()
|
|
|
|
err = be.cmd.Process.Kill()
|
|
rtest.OK(t, err)
|
|
t.Log("killed rclone")
|
|
|
|
for i := 0; i < 10; i++ {
|
|
_, err = be.Stat(context.TODO(), restic.Handle{
|
|
Name: "foo",
|
|
Type: restic.DataFile,
|
|
})
|
|
rtest.Assert(t, err != nil, "expected an error")
|
|
}
|
|
}
|