Avoid closing connection on channel EOF (#816)

This commit is contained in:
Etan Kissling 2023-01-06 15:18:16 +01:00 committed by GitHub
parent 9f658c151e
commit ba451196e8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 13 additions and 3 deletions

View File

@ -244,7 +244,11 @@ proc completeWrite(
except CancelledError as exc: except CancelledError as exc:
# Chronos may still send the data # Chronos may still send the data
raise exc raise exc
except LPStreamClosedError as exc: except LPStreamConnDownError as exc:
await s.reset()
await s.conn.close()
raise exc
except LPStreamEOFError as exc:
raise exc raise exc
except CatchableError as exc: except CatchableError as exc:
trace "exception in lpchannel write handler", s, msg = exc.msg trace "exception in lpchannel write handler", s, msg = exc.msg

View File

@ -177,8 +177,14 @@ method handle*(m: Mplex) {.async, gcsafe.} =
raise newLPStreamLimitError() raise newLPStreamLimitError()
trace "pushing data to channel", m, channel, len = data.len trace "pushing data to channel", m, channel, len = data.len
await channel.pushData(data) try:
trace "pushed data to channel", m, channel, len = data.len await channel.pushData(data)
trace "pushed data to channel", m, channel, len = data.len
except LPStreamClosedError as exc:
# Channel is being closed, but `cleanupChann` was not yet triggered.
trace "pushing data to channel failed", m, channel, len = data.len,
msg = exc.msg
discard # Ignore message, same as if `cleanupChann` had completed.
of MessageType.CloseIn, MessageType.CloseOut: of MessageType.CloseIn, MessageType.CloseOut:
await channel.pushEof() await channel.pushEof()