[Spice-devel] [PATCH spice-gtk 3/4] spice-uri: Set user & password to NULL when not specified

Pavel Grunt pgrunt at redhat.com
Mon May 16 13:00:16 UTC 2016


Avoid using old values after parsing a new uri.

Related: rhbz#1335239
---
 src/spice-uri.c        | 3 +++
 tests/test-spice-uri.c | 8 ++++++++
 2 files changed, 11 insertions(+)

diff --git a/src/spice-uri.c b/src/spice-uri.c
index 0cc2195..35d773e 100644
--- a/src/spice-uri.c
+++ b/src/spice-uri.c
@@ -141,6 +141,9 @@ gboolean spice_uri_parse(SpiceURI *self, const gchar *_uri, GError **error)
         spice_uri_set_user(self, user);
         spice_uri_set_password(self, pass);
         uri = next;
+    } else {
+        spice_uri_set_user(self, NULL);
+        spice_uri_set_password(self, NULL);
     }
 
     /* max 2 parts, host:port */
diff --git a/tests/test-spice-uri.c b/tests/test-spice-uri.c
index 993cc78..d556e01 100644
--- a/tests/test-spice-uri.c
+++ b/tests/test-spice-uri.c
@@ -51,6 +51,14 @@ static void test_spice_uri_ipv4(void)
     g_assert_cmpstr(spice_uri_get_password(uri), ==, "password");
     g_assert_cmpuint(spice_uri_get_port(uri), ==, 80);
 
+    /* new parsing resets values */
+    g_assert_true(spice_uri_parse(uri, "http://127.0.0.1", NULL));
+    g_assert_cmpstr(spice_uri_get_scheme(uri), ==, "http");
+    g_assert_cmpstr(spice_uri_get_hostname(uri), ==, "127.0.0.1");
+    g_assert_cmpstr(spice_uri_get_user(uri), ==, NULL);
+    g_assert_cmpstr(spice_uri_get_password(uri), ==, NULL);
+    g_assert_cmpuint(spice_uri_get_port(uri), ==, 3128);
+
     g_object_unref(uri);
 }
 
-- 
2.8.2



More information about the Spice-devel mailing list