aspnetcore icon indicating copy to clipboard operation
aspnetcore copied to clipboard

[SignalR-Client-Cpp] Cannot properly handle invalid url

Open Wasenshi123 opened this issue 2 years ago • 4 comments

Is there an existing issue for this?

  • [X] I have searched the existing issues

Describe the bug

When use a url like "/something" then start the connection,

It seems that underline lib cpprest does not allow empty host and throw the exception, but the exception does not return in the callback, instead, it terminates the program.

terminate called after throwing an instance of 'std::invalid_argument'
  what():  URI must contain a hostname.
Aborted

and this cannot be catched in anyway because the function hub_connection::start(std::function<void(std::exception_ptr)> callback) noexcept; is a noexcept function

https://docs.microsoft.com/en-us/cpp/cpp/noexcept-cpp?view=msvc-170

Mark a function as noexcept only if all the functions that it calls, either directly or indirectly, are also noexcept or const. The compiler doesn't necessarily check every code path for exceptions that might bubble up to a noexcept function. If an exception does exit the outer scope of a function marked noexcept, std::terminate is invoked immediately, and there's no guarantee that destructors of any in-scope objects will be invoked.

Expected Behavior

With the mark of noexcept in hub_connection::start() function, any exceptions that might occur are expected to be in the callback.

Otherwise, it should not be marked with noexcept and let user handle any exception that might come out from it.

Steps To Reproduce

No response

Exceptions (if any)

No response

.NET Version

No response

Anything else?

No response

Wasenshi123 avatar Sep 06 '22 12:09 Wasenshi123

While we should probably fix the underlying issue, why are you trying to use /something? That won't work unless you're using the Javascript client in the browser since we can infer the current web pages host then.

BrennanConroy avatar Sep 06 '22 16:09 BrennanConroy

It's just my use case where the app is in initial state and the server url is not yet configured, so the url might be in that format at first use.

And since my app allow free input from user (to configure their server url), I will need to be able to catch/handle this exception appropriately.

Wasenshi123 avatar Sep 06 '22 19:09 Wasenshi123

You could also look at the url before initializing the SignalR connection.

BrennanConroy avatar Sep 06 '22 19:09 BrennanConroy

You could also look at the url before initializing the SignalR connection.

Yes, that is my workaround right now.

But anyhow, would be nice if this is addressed from the lib itself.

Wasenshi123 avatar Sep 06 '22 19:09 Wasenshi123