1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
|
#include "config.h"
#include <string.h>
#include <glib.h>
#include <glib-object.h>
#include <telepathy-glib/dbus.h>
#include <telepathy-glib/enums.h>
#include <telepathy-glib/handle-repo.h>
#include <telepathy-glib/handle-repo-dynamic.h>
#include <telepathy-glib/interfaces.h>
#include <telepathy-glib/errors.h>
#include "tests/lib/util.h"
static void
test_handles (void)
{
TpDBusDaemon *bus_daemon = tp_tests_dbus_daemon_dup_or_die ();
TpHandleRepoIface *tp_repo = NULL;
GError *error = NULL;
TpHandle handle = 0;
const gchar *jid = "handle.test@foobar";
const gchar *return_jid;
tp_repo = tp_tests_object_new_static_class (TP_TYPE_DYNAMIC_HANDLE_REPO,
"handle-type", TP_HANDLE_TYPE_CONTACT,
NULL);
g_assert (tp_repo != NULL);
/* Handle zero is never valid */
g_assert (tp_handle_is_valid (tp_repo, 0, &error) == FALSE);
/* this should probably be InvalidHandle, but it was InvalidArgument in
* older telepathy-glib */
g_assert (error->code == TP_ERROR_INVALID_ARGUMENT ||
error->code == TP_ERROR_INVALID_HANDLE);
g_error_free (error);
error = NULL;
/* Properly return error when handle isn't in the repo */
g_assert (tp_handle_is_valid (tp_repo, 65536, &error) == FALSE);
/* this should really be InvalidHandle, but it was InvalidArgument in
* older telepathy-glib */
g_assert (error->code == TP_ERROR_INVALID_ARGUMENT ||
error->code == TP_ERROR_INVALID_HANDLE);
g_error_free (error);
error = NULL;
/* Properly return when error out argument isn't provided */
g_assert (tp_handle_is_valid (tp_repo, 65536, NULL) == FALSE);
/* It's not there to start with */
handle = tp_handle_lookup (tp_repo, jid, NULL, NULL);
g_assert (handle == 0);
/* ... but when we call tp_handle_ensure we get a new ref to it [ref 1] */
handle = tp_handle_ensure (tp_repo, jid, NULL, NULL);
g_assert (handle != 0);
/* Try to inspect it */
return_jid = tp_handle_inspect (tp_repo, handle);
g_assert (!strcmp (return_jid, jid));
/* Hold the handle on behalf of a bus name that will not go away (my own)
* [ref 2] */
g_assert (tp_handle_client_hold (tp_repo,
tp_dbus_daemon_get_unique_name (bus_daemon), handle, NULL) == TRUE);
/* Now unref it [ref 1] */
tp_handle_unref (tp_repo, handle);
/* Validate it, should be all healthy because client holds it still */
g_assert (tp_handle_is_valid (tp_repo, handle, NULL) == TRUE);
/* Ref it again [ref 3] */
tp_handle_ref (tp_repo, handle);
/* Client releases it [ref 2] */
g_assert (tp_handle_client_release (tp_repo,
tp_dbus_daemon_get_unique_name (bus_daemon), handle, NULL) == TRUE);
/* Hold the handle on behalf of a bus name that does not, in fact, exist;
* this will be detected asynchronously [ref 4] */
g_assert (tp_handle_client_hold (tp_repo, ":666.666", handle, NULL) == TRUE);
/* Now unref it [ref 3] */
tp_handle_unref (tp_repo, handle);
/* ref 4 ensures still valid */
g_assert (tp_handle_is_valid (tp_repo, handle, NULL) == TRUE);
/* wait for D-Bus to catch up (just to detect any crashes) but don't assert
* that the handle doesn't remain valid - unref is a no-op since
* 0.13.8 */
tp_tests_proxy_run_until_dbus_queue_processed (bus_daemon);
g_object_unref (tp_repo);
g_object_unref (bus_daemon);
}
int main (int argc, char **argv)
{
tp_tests_abort_after (10);
test_handles ();
return 0;
}
|