summaryrefslogtreecommitdiff
path: root/unit/test-gobex-transfer.c
diff options
context:
space:
mode:
authorLuiz Augusto von Dentz <luiz.von.dentz@intel.com>2011-12-27 11:07:11 +0200
committerMarcel Holtmann <marcel@holtmann.org>2012-12-04 22:22:05 +0100
commit2951b0d6be1c89bdd9d5e35a77493b22c4d3dede (patch)
treea49b5bfc07e3d1a0dace2bca6f03ad2a984064b5 /unit/test-gobex-transfer.c
parentd3f6db2a6b820f5b02723573ba8f334a13341055 (diff)
downloadbluez-2951b0d6be1c89bdd9d5e35a77493b22c4d3dede.tar.gz
gobex: add unit test for GET response with SRM and SRMP wait
Diffstat (limited to 'unit/test-gobex-transfer.c')
-rw-r--r--unit/test-gobex-transfer.c84
1 files changed, 84 insertions, 0 deletions
diff --git a/unit/test-gobex-transfer.c b/unit/test-gobex-transfer.c
index 9eb660497..0e5d3092f 100644
--- a/unit/test-gobex-transfer.c
+++ b/unit/test-gobex-transfer.c
@@ -1237,6 +1237,85 @@ static void test_packet_get_rsp_random_srm(void)
test_get_rsp_random_srm(SOCK_SEQPACKET);
}
+static void handle_get_random_srm_wait(GObex *obex, GObexPacket *req,
+ gpointer user_data)
+{
+ struct test_data *d = user_data;
+ guint8 op = g_obex_packet_get_operation(req, NULL);
+ guint id;
+
+ if (op != G_OBEX_OP_GET) {
+ d->err = g_error_new(TEST_ERROR, TEST_ERROR_UNEXPECTED,
+ "Unexpected opcode 0x%02x", op);
+ g_main_loop_quit(d->mainloop);
+ return;
+ }
+
+ id = g_obex_get_rsp(obex, provide_random, transfer_complete, d,
+ &d->err,
+ G_OBEX_HDR_SRM, G_OBEX_SRM_ENABLE,
+ G_OBEX_HDR_SRMP, G_OBEX_SRMP_WAIT,
+ G_OBEX_HDR_INVALID);
+ if (id == 0)
+ g_main_loop_quit(d->mainloop);
+}
+
+static void test_get_rsp_random_srm_wait(int sock_type)
+{
+ GIOChannel *io;
+ GIOCondition cond;
+ guint io_id, timer_id;
+ GObex *obex;
+ struct test_data d = { 0, NULL, {
+ { NULL, 0 },
+ { NULL, 0 },
+ { NULL, 0 },
+ { get_rsp_last, sizeof(get_rsp_last) } }, {
+ { get_req_last, sizeof(get_req_last) },
+ { NULL, 0 },
+ { get_req_last, sizeof(get_req_last) } } };
+
+ create_endpoints(&obex, &io, sock_type);
+
+ cond = G_IO_IN | G_IO_HUP | G_IO_ERR | G_IO_NVAL;
+ io_id = g_io_add_watch(io, cond, test_io_cb, &d);
+
+ d.mainloop = g_main_loop_new(NULL, FALSE);
+
+ timer_id = g_timeout_add_seconds(1, test_timeout, &d);
+
+ g_obex_add_request_function(obex, G_OBEX_OP_GET,
+ handle_get_random_srm_wait, &d);
+
+ g_io_channel_write_chars(io, (char *) get_req_first_srm,
+ sizeof(get_req_first_srm), NULL,
+ &d.err);
+ g_assert_no_error(d.err);
+
+ g_main_loop_run(d.mainloop);
+
+ g_assert_cmpuint(d.count, ==, RANDOM_PACKETS - 1);
+
+ g_main_loop_unref(d.mainloop);
+
+ g_source_remove(timer_id);
+ g_io_channel_unref(io);
+ g_source_remove(io_id);
+ g_obex_unref(obex);
+
+ g_assert_no_error(d.err);
+}
+
+static void test_stream_get_rsp_random_srm_wait(void)
+{
+ test_get_rsp_random_srm_wait(SOCK_STREAM);
+}
+
+static void test_packet_get_rsp_random_srm_wait(void)
+{
+ test_get_rsp_random_srm_wait(SOCK_SEQPACKET);
+}
+
static void handle_get_app(GObex *obex, GObexPacket *req, gpointer user_data)
{
struct test_data *d = user_data;
@@ -2066,6 +2145,11 @@ int main(int argc, char *argv[])
g_test_add_func("/gobex/test_packet_get_rsp_random_srm",
test_packet_get_rsp_random_srm);
+ g_test_add_func("/gobex/test_stream_get_rsp_random_srm_wait",
+ test_stream_get_rsp_random_srm_wait);
+ g_test_add_func("/gobex/test_packet_get_rsp_random_srm_wait",
+ test_packet_get_rsp_random_srm_wait);
+
g_test_add_func("/gobex/test_stream_get_req_random_srm",
test_stream_get_req_random_srm);
g_test_add_func("/gobex/test_packet_get_req_random_srm",