Uploaded image for project: 'Node.js Driver'
  1. Node.js Driver
  2. NODE-6691

Handle concurrent (interleaved) client.close() and client.connect() gracefully

    • Type: Icon: Task Task
    • Resolution: Unresolved
    • Priority: Icon: Unknown Unknown
    • None
    • Affects Version/s: None
    • Component/s: None
    • Hide

      1. What would you like to communicate to the user about this feature?
      2. Would you like the user to see examples of the syntax and/or executable code and its output?
      3. Which versions of the driver/connector does this apply to?

      Show
      1. What would you like to communicate to the user about this feature? 2. Would you like the user to see examples of the syntax and/or executable code and its output? 3. Which versions of the driver/connector does this apply to?
    • None
    • None
    • None
    • None
    • None
    • None

      User Experience

      • Currently, if a user calls client.connect() and client.close() concurrently, it would leave the client in an indeterminate state

      Risks/Unknowns

      • What is the desired behavior?
        • Proposed Plan 1:
          • when connect() is called during close(), await close()
          • when connect() is called during close(), await connect()
          • potential problems:
            • this could create a confusing user experience in the event that a connectionCheckedOutEvent and connectionClosedEvent are both emitted through a call to client.close()
            • it also creates more resources for client.close() to clean-up
        • Proposed Plan 2:
          • when connect() is called during close(), throw an runtime / API error 
          • when close() is called during connect(), abort connect()  (should be handled by NODE-6632)
          • potential problems: 

      Acceptance Criteria

      Implementation Requirements

      • Determine and implement desired behavior

      Testing Requirements

      • TBD

      Documentation Requirements

      • TBD

            Assignee:
            Unassigned Unassigned
            Reporter:
            aditi.khare@mongodb.com Aditi Khare (Inactive)
            Votes:
            0 Vote for this issue
            Watchers:
            1 Start watching this issue

              Created:
              Updated:
              None
              None
              None
              None