Skip to content

nbb's nREPL crashes if we disconnect without waiting for all output #335

Open
@mauricioszabo

Description

@mauricioszabo

version
nbb v1.2.175

platform
Linux, Node 16 or 18

problem
If we connect to nREPL, send an "eval" command and don't wait for the result (or for the "done" status) and immediately disconnect, nbb will crash:

node:events:505
      throw er; // Unhandled 'error' event
      ^

Error: read ECONNRESET
    at TCP.onStreamRead (node:internal/stream_base_commons:217:20)
Emitted 'error' event on Socket instance at:
    at emitErrorNT (node:internal/streams/destroy:157:8)
    at emitErrorCloseNT (node:internal/streams/destroy:122:3)
    at processTicksAndRejections (node:internal/process/task_queues:83:21) {
  errno: -104,
  code: 'ECONNRESET',
  syscall: 'read'
}

repro

  1. Connect to nbb's nREPL
  2. Send an eval command
  3. Disconnect before the result comes

expected behavior
nbb should not crash

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions