forked from TrueCloudLab/restic
rclone: Don't panic after unexpected subprocess exit
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.
This commit is contained in:
parent
48f97f3567
commit
c81b122374
2 changed files with 9 additions and 6 deletions
|
@ -173,7 +173,8 @@ func newBackend(cfg Config, lim limiter.Limiter) (*Backend, error) {
|
||||||
DialTLS: func(network, address string, cfg *tls.Config) (net.Conn, error) {
|
DialTLS: func(network, address string, cfg *tls.Config) (net.Conn, error) {
|
||||||
debug.Log("new connection requested, %v %v", network, address)
|
debug.Log("new connection requested, %v %v", network, address)
|
||||||
if dialCount > 0 {
|
if dialCount > 0 {
|
||||||
panic("dial count > 0")
|
// the connection to the child process is already closed
|
||||||
|
return nil, errors.New("rclone stdio connection already closed")
|
||||||
}
|
}
|
||||||
dialCount++
|
dialCount++
|
||||||
return conn, nil
|
return conn, nil
|
||||||
|
|
|
@ -29,9 +29,11 @@ func TestRcloneExit(t *testing.T) {
|
||||||
rtest.OK(t, err)
|
rtest.OK(t, err)
|
||||||
t.Log("killed rclone")
|
t.Log("killed rclone")
|
||||||
|
|
||||||
_, err = be.Stat(context.TODO(), restic.Handle{
|
for i := 0; i < 10; i++ {
|
||||||
Name: "foo",
|
_, err = be.Stat(context.TODO(), restic.Handle{
|
||||||
Type: restic.DataFile,
|
Name: "foo",
|
||||||
})
|
Type: restic.DataFile,
|
||||||
rtest.Assert(t, err != nil, "expected an error")
|
})
|
||||||
|
rtest.Assert(t, err != nil, "expected an error")
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue