[ 
https://issues.apache.org/jira/browse/CALCITE-1350?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=15418083#comment-15418083
 ] 

Julian Hyde commented on CALCITE-1350:
--------------------------------------

Maybe. But what if {{openConnection}} got part way through? Which call is 
responsible for clean-up?

It seems clear that to be robust, {{closeConnection}} should be idempotent. So 
can't we use that robustness, and call it when it isn't clear whether 
{{openConnection}} succeeded? It should (at the very least) do no harm when 
called on a connection that wasn't fully initialized.

And what about if {{openConnection}} succeeded, but wasn't able to communicate 
its successful result back?

> Avoid closeConnection when openConnection doesn't finish/succeed
> ----------------------------------------------------------------
>
>                 Key: CALCITE-1350
>                 URL: https://issues.apache.org/jira/browse/CALCITE-1350
>             Project: Calcite
>          Issue Type: Improvement
>          Components: avatica
>            Reporter: Josh Elser
>            Assignee: Josh Elser
>             Fix For: avatica-1.9.0
>
>
> I've noticed during testing of Avatica, often times when SPNEGO 
> authentication is misconfigured, the client will get stuck in 
> openConnection().
> If we consider sqlline and the user control-C's it, sqlline will try to close 
> the driver as well which would do a closeConnection() (which would also 
> obviously fail).
> I believe we should be able to short-circuit the the closeConnection() when 
> we know that the openConnection() didn't succeed properly.
> Another scenario is when the Avatica server is down. openConnection will 
> fail, but we'll still attempt the closeConnection on exit.



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

Reply via email to