dotnet / aspnetcore

ASP.NET Core is a cross-platform .NET framework for building modern cloud-based web applications on Windows, Mac, or Linux.
https://asp.net
MIT License
35.57k stars 10.05k forks source link

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

Open Wasenshi123 opened 2 years ago

Wasenshi123 commented 2 years ago

Is there an existing issue for this?

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

BrennanConroy commented 2 years ago

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.

Wasenshi123 commented 2 years ago

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.

BrennanConroy commented 2 years ago

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

Wasenshi123 commented 2 years ago

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.