summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGuillaume Desmottes <guillaume.desmottes@collabora.co.uk>2011-10-18 15:46:11 +0200
committerGuillaume Desmottes <guillaume.desmottes@collabora.co.uk>2011-10-18 15:46:11 +0200
commita35dadc4069721ffee181123ef379f60a9055716 (patch)
treec1e045a6a306001bcf7b7b36ce402fa0c2771d98
parent1a01d5f17d259491211320b67036ab1bdfc1c134 (diff)
downloadtelepathy-glib-a35dadc4069721ffee181123ef379f60a9055716.tar.gz
_tp_channel_contacts_queue_prepare_finish: don't assume item->contacts is not NULL
For example, when receiving a MUC delivery report we end up with a message having no sender and so no contact to prepare. https://bugs.freedesktop.org/show_bug.cgi?id=41929
-rw-r--r--telepathy-glib/channel-contacts.c7
-rw-r--r--tests/dbus/text-channel.c47
2 files changed, 53 insertions, 1 deletions
diff --git a/telepathy-glib/channel-contacts.c b/telepathy-glib/channel-contacts.c
index f5de15bd2..88f968f3c 100644
--- a/telepathy-glib/channel-contacts.c
+++ b/telepathy-glib/channel-contacts.c
@@ -484,7 +484,12 @@ _tp_channel_contacts_queue_prepare_finish (TpChannel *self,
item = g_simple_async_result_get_op_res_gpointer (simple);
if (contacts != NULL)
- *contacts = g_ptr_array_ref (item->contacts);
+ {
+ if (item->contacts != NULL)
+ *contacts = g_ptr_array_ref (item->contacts);
+ else
+ *contacts = g_ptr_array_new ();
+ }
if (g_simple_async_result_propagate_error (simple, error))
return FALSE;
diff --git a/tests/dbus/text-channel.c b/tests/dbus/text-channel.c
index a33292d02..a2926408a 100644
--- a/tests/dbus/text-channel.c
+++ b/tests/dbus/text-channel.c
@@ -923,6 +923,51 @@ test_sent_with_no_sender (Test *test,
g_ptr_array_unref (parts);
}
+/* regression test for fdo #41929 */
+static void
+test_receive_muc_delivery (Test *test,
+ gconstpointer data G_GNUC_UNUSED)
+{
+ GQuark features[] = { TP_TEXT_CHANNEL_FEATURE_INCOMING_MESSAGES, 0 };
+ GPtrArray *parts;
+ GHashTable *header;
+
+ /* We have to prepare the pending messages feature to be notified about
+ * incoming messages */
+ tp_proxy_prepare_async (test->channel, features,
+ proxy_prepare_cb, test);
+
+ g_main_loop_run (test->mainloop);
+ g_assert_no_error (test->error);
+
+ g_signal_connect (test->channel, "message-received",
+ G_CALLBACK (message_received_cb), test);
+
+ /* build delivery report */
+ parts = g_ptr_array_new_with_free_func ((GDestroyNotify) g_hash_table_unref);
+ header = tp_asv_new (NULL, NULL);
+ g_ptr_array_add (parts, header);
+
+ tp_asv_set_uint32 (header, "message-type",
+ TP_CHANNEL_TEXT_MESSAGE_TYPE_DELIVERY_REPORT);
+ tp_asv_set_uint32 (header, "pending-message-id", 5);
+ tp_asv_set_string (header, "message-token", "message_token");
+ tp_asv_set_string (header, "delivery-token", "delivery_token");
+ tp_asv_set_uint32 (header, "delivery-status", TP_DELIVERY_STATUS_DELIVERED);
+
+ tp_svc_channel_interface_messages_emit_message_received (test->chan_service,
+ parts);
+
+ test->wait = 1;
+ g_main_loop_run (test->mainloop);
+ g_assert_no_error (test->error);
+
+ g_assert_cmpuint (tp_message_get_message_type (test->received_msg), ==,
+ TP_CHANNEL_TEXT_MESSAGE_TYPE_DELIVERY_REPORT);
+
+ g_ptr_array_unref (parts);
+}
+
int
main (int argc,
char **argv)
@@ -956,6 +1001,8 @@ main (int argc,
test_sender_prepared, teardown);
g_test_add ("/text-channel/sent-with-no-sender", Test, NULL, setup,
test_sent_with_no_sender, teardown);
+ g_test_add ("/text-channel/receive-muc-delivery", Test, NULL, setup,
+ test_receive_muc_delivery, teardown);
return g_test_run ();
}