test-nat: Add nat unit test
authorDaniel Wagner <daniel.wagner@bmw-carit.de>
Wed, 1 Feb 2012 17:51:47 +0000 (18:51 +0100)
committerSamuel Ortiz <sameo@linux.intel.com>
Mon, 13 Feb 2012 10:33:17 +0000 (11:33 +0100)
Makefile.am
unit/test-nat.c [new file with mode: 0644]

index 79b4f9f63cea742cc24848eb20b049c184f648e4..dcf3d514e315b580788a2dfc74c8e381fcbbb407 100644 (file)
@@ -145,7 +145,8 @@ noinst_PROGRAMS += tools/wispr tools/supplicant-test \
                        tools/dbus-test tools/polkit-test \
                        tools/iptables-test tools/tap-test tools/wpad-test \
                        tools/stats-tool tools/private-network-test \
-                       tools/alg-test unit/test-session unit/test-ippool
+                       tools/alg-test unit/test-session unit/test-ippool \
+                       unit/test-nat
 
 tools_wispr_SOURCES = $(gweb_sources) tools/wispr.c
 tools_wispr_LDADD = @GLIB_LIBS@ @GNUTLS_LIBS@ -lresolv
@@ -193,6 +194,11 @@ unit_test_ippool_SOURCES = $(gdbus_sources) src/log.c src/dbus.c \
                 src/ippool.c unit/test-ippool.c
 unit_test_ippool_LDADD = @GLIB_LIBS@ @DBUS_LIBS@ -ldl
 unit_objects += $(unit_test_ippool_OBJECTS)
+
+unit_test_nat_SOURCES = $(gdbus_sources) src/log.c src/dbus.c \
+               src/iptables.c  src/nat.c unit/test-nat.c
+unit_test_nat_LDADD = @GLIB_LIBS@ @DBUS_LIBS@  @XTABLES_LIBS@ -ldl
+unit_objects += $(unit_nat_ippool_OBJECTS)
 endif
 
 test_scripts = test/get-state test/list-services \
diff --git a/unit/test-nat.c b/unit/test-nat.c
new file mode 100644 (file)
index 0000000..a601871
--- /dev/null
@@ -0,0 +1,126 @@
+/*
+ *
+ *  Connection Manager
+ *
+ *  Copyright (C) 2012  BWM CarIT GmbH. 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 <glib.h>
+
+#include "../src/connman.h"
+
+/* #define DEBUG */
+#ifdef DEBUG
+#include <stdio.h>
+
+#define LOG(fmt, arg...) do { \
+       fprintf(stdout, "%s:%s() " fmt "\n", \
+                       __FILE__, __func__ , ## arg); \
+} while (0)
+#else
+#define LOG(fmt, arg...)
+#endif
+
+struct connman_notifier *nat_notifier;
+
+struct connman_service {
+       char *dummy;
+};
+
+char *connman_service_get_interface(struct connman_service *service)
+{
+       return "eth0";
+}
+
+int connman_notifier_register(struct connman_notifier *notifier)
+{
+       nat_notifier = notifier;
+
+       return 0;
+}
+
+void connman_notifier_unregister(struct connman_notifier *notifier)
+{
+       nat_notifier = NULL;
+}
+
+static void test_nat_basic0(void)
+{
+       int err;
+
+       err = __connman_nat_enable("bridge", "192.168.2.1", 24);
+       g_assert(err == 0);
+
+       /* test that table is empty */
+       err = __connman_iptables_command("-t nat -C POSTROUTING "
+                                       "-s 192.168.2.1/24 -o eth0 -j MASQUERADE");
+       g_assert(err != 0);
+
+       __connman_nat_disable("bridge");
+}
+
+static void test_nat_basic1(void)
+{
+       struct connman_service *service;
+       int err;
+
+       service = g_try_new0(struct connman_service, 1);
+       g_assert(service);
+
+       nat_notifier->default_changed(service);
+
+       err = __connman_nat_enable("bridge", "192.168.2.1", 24);
+       g_assert(err == 0);
+
+       /* test that table is not empty */
+       err = __connman_iptables_command("-t nat -C POSTROUTING "
+                                       "-s 192.168.2.1/24 -o eth0 -j MASQUERADE");
+       g_assert(err == 0);
+
+       __connman_nat_disable("bridge");
+
+       /* test that table is empty again */
+       err = __connman_iptables_command("-t nat -C POSTROUTING "
+                                       "-s 192.168.2.1/24 -o eth0 -j MASQUERADE");
+       g_assert(err != 0);
+}
+
+int main(int argc, char *argv[])
+{
+       int err;
+
+       g_test_init(&argc, &argv, NULL);
+
+       __connman_log_init(argv[0], "*", FALSE);
+       __connman_iptables_init();
+       __connman_nat_init();
+
+       g_test_add_func("/basic0", test_nat_basic0);
+       g_test_add_func("/basic1", test_nat_basic1);
+
+       err = g_test_run();
+
+       __connman_nat_cleanup();
+       __connman_iptables_cleanup();
+       __connman_log_cleanup();
+
+       return err;
+}