summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarcel Holtmann <marcel@holtmann.org>2010-07-31 22:16:20 (GMT)
committerMarcel Holtmann <marcel@holtmann.org>2010-07-31 22:16:20 (GMT)
commit8130685cd665f1d283bbbb8bcbeb1efc397cbb3e (patch)
tree1e9f01b775a1f9d1457f22aef8fdf9f9abd02f6c
parent2a3855c57fbe42e3f9f26bc6b08a09f6471370ea (diff)
downloadconnman-8130685cd665f1d283bbbb8bcbeb1efc397cbb3e.zip
connman-8130685cd665f1d283bbbb8bcbeb1efc397cbb3e.tar.gz
connman-8130685cd665f1d283bbbb8bcbeb1efc397cbb3e.tar.bz2
Add simple test tool for web service library
-rw-r--r--.gitignore1
-rw-r--r--Makefile.am7
-rw-r--r--tools/web-test.c108
3 files changed, 114 insertions, 2 deletions
diff --git a/.gitignore b/.gitignore
index 2aa27f9..fb4f50b 100644
--- a/.gitignore
+++ b/.gitignore
@@ -43,6 +43,7 @@ tools/wifi-scan
tools/dhcp-test
tools/addr-test
tools/tap-test
+tools/web-test
tools/wpad-test
tools/resolv-test
tools/polkit-test
diff --git a/Makefile.am b/Makefile.am
index 28a2b97..ed4689c 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -125,9 +125,9 @@ endif
if TOOLS
noinst_PROGRAMS += tools/wifi-scan tools/supplicant-test tools/dhcp-test \
- tools/addr-test tools/tap-test tools/resolv-test \
+ tools/addr-test tools/web-test tools/resolv-test \
tools/dbus-test tools/polkit-test tools/portal-test \
- tools/iptables-test tools/wpad-test
+ tools/iptables-test tools/tap-test tools/wpad-test
tools_wifi_scan_LDADD = @GLIB_LIBS@ @NETLINK_LIBS@
@@ -136,6 +136,9 @@ tools_supplicant_test_SOURCES = $(gdbus_sources) tools/supplicant-test.c \
tools/supplicant.h tools/supplicant.c
tools_supplicant_test_LDADD = @GLIB_LIBS@ @DBUS_LIBS@
+tools_web_test_SOURCES = $(gweb_sources) tools/web-test.c
+tools_web_test_LDADD = @GLIB_LIBS@
+
tools_resolv_test_SOURCES = $(gresolv_sources) tools/resolv-test.c
tools_resolv_test_LDADD = @GLIB_LIBS@ -lresolv
diff --git a/tools/web-test.c b/tools/web-test.c
new file mode 100644
index 0000000..cf85c71
--- /dev/null
+++ b/tools/web-test.c
@@ -0,0 +1,108 @@
+/*
+ *
+ * Connection Manager
+ *
+ * Copyright (C) 2007-2010 Intel Corporation. All rights reserved.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 2 as
+ * published by the Free Software Foundation.
+ *
+ * This program 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 General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+ *
+ */
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <signal.h>
+
+#include <gweb/gweb.h>
+
+static GTimer *timer;
+
+static GMainLoop *main_loop;
+
+static void web_debug(const char *str, void *data)
+{
+ g_print("%s: %s\n", (const char *) data, str);
+}
+
+static void sig_term(int sig)
+{
+ g_main_loop_quit(main_loop);
+}
+
+static gboolean option_debug = FALSE;
+
+static GOptionEntry options[] = {
+ { "debug", 'd', 0, G_OPTION_ARG_NONE, &option_debug,
+ "Enable debug output" },
+ { NULL },
+};
+
+int main(int argc, char *argv[])
+{
+ GOptionContext *context;
+ GError *error = NULL;
+ struct sigaction sa;
+ GWeb *web;
+
+ context = g_option_context_new(NULL);
+ g_option_context_add_main_entries(context, options, NULL);
+
+ if (g_option_context_parse(context, &argc, &argv, &error) == FALSE) {
+ if (error != NULL) {
+ g_printerr("%s\n", error->message);
+ g_error_free(error);
+ } else
+ g_printerr("An unknown error occurred\n");
+ exit(1);
+ }
+
+ g_option_context_free(context);
+
+ if (argc < 2) {
+ printf("missing argument\n");
+ return 1;
+ }
+
+ web = g_web_new();
+ if (web == NULL) {
+ printf("failed to web service\n");
+ return 1;
+ }
+
+ if (option_debug == TRUE)
+ g_web_set_debug(web, web_debug, "WEB");
+
+ main_loop = g_main_loop_new(NULL, FALSE);
+
+ timer = g_timer_new();
+
+ memset(&sa, 0, sizeof(sa));
+ sa.sa_handler = sig_term;
+ sigaction(SIGINT, &sa, NULL);
+ sigaction(SIGTERM, &sa, NULL);
+
+ g_main_loop_run(main_loop);
+
+ g_timer_destroy(timer);
+
+ g_web_unref(web);
+
+ g_main_loop_unref(main_loop);
+
+ return 0;
+}