summaryrefslogtreecommitdiff
path: root/tests/websocket-test.c
diff options
context:
space:
mode:
authorCarlos Garcia Campos <cgarcia@igalia.com>2021-02-10 14:53:12 +0100
committerCarlos Garcia Campos <cgarcia@igalia.com>2021-02-10 14:53:12 +0100
commit046aac0bbc6bf9745e6cf970d2507c1a4342071f (patch)
tree9764734bcc5e641f84ae06fbfc59245cae156a8f /tests/websocket-test.c
parent607feb72333bf0553d966bafa0f93866e31d8240 (diff)
downloadlibsoup-carlosgc/websocket-connection-error.tar.gz
WebSockets: do not report connection errors as handshake failurescarlosgc/websocket-connection-error
We are assuming that when not switching protocols after a request is because the server didn't accept the handshake, but we can fail even earlier if there's a connection error. In libsoup 2 we could check if it was a connection error by checking the message status was SOUP_STATUS_CANT_CONNECT or SOUP_STATUS_CANT_CONNECT_PROXY. Now that we no longer use the message status for transport errors, we should make soup_session_websocket_connect_async() fail with the connection error.
Diffstat (limited to 'tests/websocket-test.c')
-rw-r--r--tests/websocket-test.c32
1 files changed, 32 insertions, 0 deletions
diff --git a/tests/websocket-test.c b/tests/websocket-test.c
index 714f77fb..5c8a83a4 100644
--- a/tests/websocket-test.c
+++ b/tests/websocket-test.c
@@ -1986,6 +1986,36 @@ test_cookies_in_response (Test *test,
soup_cookie_free (cookie);
}
+static void
+test_connection_error_cb (GObject *object,
+ GAsyncResult *result,
+ gpointer user_data)
+{
+ GError **error = user_data;
+
+ g_assert_null (soup_session_websocket_connect_finish (SOUP_SESSION (object), result, error));
+}
+
+static void
+test_connection_error (void)
+{
+ SoupSession *session;
+ SoupMessage *msg;
+ GError *error = NULL;
+
+ session = soup_test_session_new (NULL);
+
+ msg = soup_message_new ("GET", "ws://127.0.0.1:1234/unix");
+ soup_session_websocket_connect_async (session, msg, NULL, NULL, G_PRIORITY_DEFAULT,
+ NULL, test_connection_error_cb, &error);
+ WAIT_UNTIL (error != NULL);
+ g_assert_error (error, G_IO_ERROR, G_IO_ERROR_CONNECTION_REFUSED);
+
+ g_error_free (error);
+ g_object_unref (msg);
+ soup_test_session_abort_unref (session);
+}
+
int
main (int argc,
char *argv[])
@@ -2219,6 +2249,8 @@ main (int argc,
test_cookies_in_response,
teardown_soup_connection);
+ g_test_add_func ("/websocket/soup/connection-error", test_connection_error);
+
ret = g_test_run ();
test_cleanup ();