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 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128
|
/* Easy Publish and Consume Library
* Copyright (C) 2007, 2008 Openismus GmbH
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*
* Authors:
* Mathias Hasselmann
*/
#include "libepc/consumer.h"
#include "libepc/publisher.h"
#include "framework.h"
#include <string.h>
static gchar *test_name = NULL;
static gchar *test_path = NULL;
static gchar *test_value = NULL;
static gchar *test_key = NULL;
static void
service_found_cb (EpcServiceMonitor *monitor G_GNUC_UNUSED,
const gchar *name,
const EpcServiceInfo *service)
{
EpcConsumer *consumer = NULL;
GError *error = NULL;
gchar *value = NULL;
if (!test_name || strcmp (test_name, name))
goto out;
epc_test_pass_once (1 << 0);
consumer = epc_consumer_new (service);
epc_test_goto_if_fail (EPC_IS_CONSUMER (consumer), out);
epc_test_pass_once (1 << 1);
value = epc_consumer_lookup (consumer, test_key, NULL, &error);
if (value)
epc_test_pass_once (1 << 2);
if (value && g_str_equal (value, test_value))
epc_test_pass_once (1 << 3);
g_free (value);
g_object_get (consumer, "path", &value, NULL);
if (value && g_str_equal (value, test_path))
epc_test_pass_once (1 << 4);
epc_test_quit ();
out:
if (error)
g_warning ("%s: lookup failed: %s", G_STRLOC, error->message);
g_clear_error (&error);
g_free (value);
if (consumer)
g_object_unref (consumer);
}
int
main (void)
{
EpcServiceMonitor *monitor = NULL;
EpcPublisher *publisher = NULL;
gboolean running = FALSE;
GError *error = NULL;
gint result = 1;
g_set_prgname (__FILE__);
if (!epc_test_init (5))
goto out;
test_name = g_strdup_printf ("%s %x", __FILE__, g_random_int ());
test_path = g_strdup_printf ("/stuff-%x", g_random_int ());
test_key = g_strdup_printf ("Maman %x", g_random_int ());
test_value = g_strdup_printf ("Bar: %x", g_random_int ());
monitor = epc_service_monitor_new (NULL, NULL, EPC_PROTOCOL_UNKNOWN);
g_signal_connect (monitor, "service-found", G_CALLBACK (service_found_cb), NULL);
publisher = epc_publisher_new (test_name, NULL, NULL);
epc_test_goto_if_fail (EPC_IS_PUBLISHER (publisher), out);
epc_publisher_set_protocol (publisher, EPC_PROTOCOL_HTTP);
epc_publisher_set_contents_path (publisher, test_path);
epc_publisher_add (publisher, test_key, test_value, -1);
running = epc_publisher_run_async (publisher, &error);
epc_test_goto_if_fail (running, out);
result = epc_test_run ();
out:
if (error)
g_warning ("%s: lookup failed: %s", G_STRLOC, error->message);
g_clear_error (&error);
if (publisher)
g_object_unref (publisher);
if (monitor)
g_object_unref (monitor);
g_free (test_name);
g_free (test_path);
g_free (test_key);
g_free (test_value);
return result;
}
|