From 8130685cd665f1d283bbbb8bcbeb1efc397cbb3e Mon Sep 17 00:00:00 2001 From: Marcel Holtmann Date: Sat, 31 Jul 2010 15:16:20 -0700 Subject: [PATCH] Add simple test tool for web service library --- .gitignore | 1 + Makefile.am | 7 ++-- tools/web-test.c | 108 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 114 insertions(+), 2 deletions(-) create mode 100644 tools/web-test.c 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 +#endif + +#include +#include +#include +#include + +#include + +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; +} -- 2.7.4