summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLubomir Rintel <lkundrak@v3.sk>2015-01-06 13:41:29 +0100
committerLubomir Rintel <lkundrak@v3.sk>2015-01-26 13:30:51 +0100
commit60f2124c008f2676fd156e1c1987e03330526871 (patch)
treec9e784740626884204dea62a490b156c5cdf935a
parentb8e93957cd6861f57f466f584c3e675f7d609985 (diff)
downloadNetworkManager-60f2124c008f2676fd156e1c1987e03330526871.tar.gz
route-manager: add test
-rw-r--r--.gitignore2
-rw-r--r--src/tests/Makefile.am32
-rw-r--r--src/tests/test-route-manager.c429
3 files changed, 463 insertions, 0 deletions
diff --git a/.gitignore b/.gitignore
index cf426d7351..40448f92bc 100644
--- a/.gitignore
+++ b/.gitignore
@@ -249,6 +249,8 @@ valgrind-*.log
/src/tests/test-ip4-config
/src/tests/test-ip6-config
/src/tests/test-resolvconf-capture
+/src/tests/test-route-manager-fake
+/src/tests/test-route-manager-linux
/src/tests/test-wired-defname
/vapi/*.vapi
diff --git a/src/tests/Makefile.am b/src/tests/Makefile.am
index 65bc2199c6..5a0907d167 100644
--- a/src/tests/Makefile.am
+++ b/src/tests/Makefile.am
@@ -20,6 +20,8 @@ noinst_PROGRAMS = \
test-general-with-expect \
test-ip4-config \
test-ip6-config \
+ test-route-manager-linux \
+ test-route-manager-fake \
test-dcb \
test-resolvconf-capture \
test-wired-defname
@@ -40,6 +42,34 @@ test_ip6_config_SOURCES = \
test_ip6_config_LDADD = \
$(top_builddir)/src/libNetworkManager.la
+####### route manager test #######
+
+test_route_manager_fake_CPPFLAGS = \
+ $(AM_CPPFLAGS) \
+ -I$(top_builddir)/src/platform/tests \
+ -DSETUP=nm_fake_platform_setup \
+ -DKERNEL_HACKS=0
+
+test_route_manager_fake_SOURCES = \
+ ../platform/tests/test-common.c \
+ test-route-manager.c
+
+test_route_manager_fake_LDADD = \
+ $(top_builddir)/src/libNetworkManager.la
+
+test_route_manager_linux_SOURCES = \
+ ../platform/tests/test-common.c \
+ test-route-manager.c
+
+test_route_manager_linux_CPPFLAGS = \
+ $(AM_CPPFLAGS) \
+ -I$(top_builddir)/src/platform/tests \
+ -DSETUP=nm_linux_platform_setup \
+ -DKERNEL_HACKS=1
+
+test_route_manager_linux_LDADD = \
+ $(top_builddir)/src/libNetworkManager.la
+
####### DCB test #######
test_dcb_SOURCES = \
@@ -89,6 +119,8 @@ EXTRA_DIST = test-secret-agent.py
TESTS = \
test-ip4-config \
test-ip6-config \
+ test-route-manager-fake \
+ test-route-manager-linux \
test-dcb \
test-resolvconf-capture \
test-general \
diff --git a/src/tests/test-route-manager.c b/src/tests/test-route-manager.c
new file mode 100644
index 0000000000..a9d96fb5e8
--- /dev/null
+++ b/src/tests/test-route-manager.c
@@ -0,0 +1,429 @@
+/* -*- Mode: C; tab-width: 4; indent-tabs-mode: t; c-basic-offset: 4 -*- */
+/*
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2, or (at your option)
+ * any later version.
+ *
+ * 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 Street, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Copyright (C) 2015 Red Hat, Inc.
+ *
+ */
+
+#include "config.h"
+
+#include <glib.h>
+#include <arpa/inet.h>
+
+#include "test-common.h"
+
+#include "nm-platform.h"
+#include "nm-route-manager.h"
+#include "nm-logging.h"
+
+#include "nm-test-utils.h"
+
+typedef struct {
+ int ifindex0, ifindex1;
+} test_fixture;
+
+static void
+setup_dev0_ip4 (int ifindex)
+{
+ GArray *routes = g_array_new (FALSE, FALSE, sizeof (NMPlatformIP4Route));
+ NMPlatformIP4Route route;
+
+ route.ifindex = ifindex;
+ route.mss = 0;
+
+ route.source = NM_IP_CONFIG_SOURCE_USER;
+ inet_pton (AF_INET, "6.6.6.0", &route.network);
+ route.plen = 24;
+ route.gateway = INADDR_ANY;
+ route.metric = 20;
+ g_array_append_val (routes, route);
+
+ route.source = NM_IP_CONFIG_SOURCE_USER;
+ inet_pton (AF_INET, "7.0.0.0", &route.network);
+ route.plen = 8;
+ inet_pton (AF_INET, "6.6.6.1", &route.gateway);
+ route.metric = 21;
+ g_array_append_val (routes, route);
+
+ nm_route_manager_ip4_route_sync (nm_route_manager_get (), ifindex, routes);
+ g_array_free (routes, TRUE);
+}
+
+static void
+setup_dev1_ip4 (int ifindex)
+{
+ GArray *routes = g_array_new (FALSE, FALSE, sizeof (NMPlatformIP4Route));
+ NMPlatformIP4Route route;
+
+ route.ifindex = ifindex;
+ route.mss = 0;
+
+ /* Add some route outside of route manager. The route manager
+ * should get rid of it upon sync. */
+ nm_platform_ip4_route_add (route.ifindex,
+ NM_IP_CONFIG_SOURCE_USER,
+ nmtst_inet4_from_string ("8.0.0.0"),
+ 8,
+ INADDR_ANY,
+ 0,
+ 10,
+ route.mss);
+
+ route.source = NM_IP_CONFIG_SOURCE_USER;
+ inet_pton (AF_INET, "6.6.6.0", &route.network);
+ route.plen = 24;
+ route.gateway = INADDR_ANY;
+ route.metric = 20;
+ g_array_append_val (routes, route);
+
+ route.source = NM_IP_CONFIG_SOURCE_USER;
+ inet_pton (AF_INET, "7.0.0.0", &route.network);
+ route.plen = 8;
+ route.gateway = INADDR_ANY;
+ route.metric = 22;
+ g_array_append_val (routes, route);
+
+ nm_route_manager_ip4_route_sync (nm_route_manager_get (), ifindex, routes);
+ g_array_free (routes, TRUE);
+}
+
+static GArray *
+ip4_routes (test_fixture *fixture)
+{
+ GArray *routes = nm_platform_ip4_route_get_all (fixture->ifindex0,
+ NM_PLATFORM_GET_ROUTE_MODE_NO_DEFAULT);
+ GArray *routes1 = nm_platform_ip4_route_get_all (fixture->ifindex1,
+ NM_PLATFORM_GET_ROUTE_MODE_NO_DEFAULT);
+
+ g_array_append_vals (routes, routes1->data, routes1->len);
+ g_array_free (routes1, TRUE);
+
+ return routes;
+}
+
+static void
+test_ip4 (test_fixture *fixture, gconstpointer user_data)
+{
+ GArray *routes;
+
+ NMPlatformIP4Route state1[] = {
+ {
+ .source = NM_IP_CONFIG_SOURCE_USER,
+ .network = nmtst_inet4_from_string ("7.0.0.0"),
+ .plen = 8,
+ .ifindex = fixture->ifindex0,
+ .gateway = nmtst_inet4_from_string ("6.6.6.1"),
+ .metric = 21,
+ .mss = 0,
+ },
+ {
+ .source = NM_IP_CONFIG_SOURCE_USER,
+ .network = nmtst_inet4_from_string ("6.6.6.0"),
+ .plen = 24,
+ .ifindex = fixture->ifindex0,
+ .gateway = INADDR_ANY,
+ .metric = 20,
+ .mss = 0,
+ },
+ {
+ .source = NM_IP_CONFIG_SOURCE_USER,
+ .network = nmtst_inet4_from_string ("7.0.0.0"),
+ .plen = 8,
+ .ifindex = fixture->ifindex1,
+ .gateway = INADDR_ANY,
+ .metric = 22,
+ .mss = 0,
+ },
+ };
+
+ NMPlatformIP4Route state2[] = {
+ {
+ .source = NM_IP_CONFIG_SOURCE_USER,
+ .network = nmtst_inet4_from_string ("7.0.0.0"),
+ .plen = 8,
+ .ifindex = fixture->ifindex1,
+ .gateway = INADDR_ANY,
+ .metric = 22,
+ .mss = 0,
+ },
+ {
+ .source = NM_IP_CONFIG_SOURCE_USER,
+ .network = nmtst_inet4_from_string ("6.6.6.0"),
+ .plen = 24,
+ .ifindex = fixture->ifindex1,
+ .gateway = INADDR_ANY,
+ .metric = 20,
+ .mss = 0,
+ },
+ };
+
+ setup_dev0_ip4 (fixture->ifindex0);
+ setup_dev1_ip4 (fixture->ifindex1);
+
+ /* Check that the 6.6.6.0/24 didn't clash and everything else is fine too. */
+ routes = ip4_routes (fixture);
+
+ g_assert_cmpint (routes->len, ==, G_N_ELEMENTS (state1));
+ nmtst_platform_ip4_routes_equal ((NMPlatformIP4Route *) routes->data, state1, routes->len);
+ g_array_free (routes, TRUE);
+
+ setup_dev1_ip4 (fixture->ifindex1);
+ setup_dev0_ip4 (fixture->ifindex0);
+
+ /* Ensure nothing changed. */
+ routes = ip4_routes (fixture);
+ g_assert_cmpint (routes->len, ==, G_N_ELEMENTS (state1));
+ nmtst_platform_ip4_routes_equal ((NMPlatformIP4Route *) routes->data, state1, routes->len);
+ g_array_free (routes, TRUE);
+
+ nm_route_manager_route_flush (nm_route_manager_get (), fixture->ifindex0);
+
+ /* Check that the 6.6.6.0/24 is now on dev1 and other dev0 routes went away. */
+ routes = ip4_routes (fixture);
+ g_assert_cmpint (routes->len, ==, G_N_ELEMENTS (state2));
+ nmtst_platform_ip4_routes_equal ((NMPlatformIP4Route *) routes->data, state2, routes->len);
+ g_array_free (routes, TRUE);
+
+ nm_route_manager_route_flush (nm_route_manager_get (), fixture->ifindex1);
+
+ /* No routes left. */
+ routes = ip4_routes (fixture);
+ g_assert_cmpint (routes->len, ==, 0);
+ g_array_free (routes, TRUE);
+}
+
+static void
+setup_dev0_ip6 (int ifindex)
+{
+ GArray *routes = g_array_new (FALSE, FALSE, sizeof (NMPlatformIP6Route));
+ NMPlatformIP6Route *route;
+
+ /* Add an address so that a route to the gateway below gets added. */
+ nm_platform_ip6_address_add (ifindex,
+ *nmtst_inet6_from_string ("2001:db8:8086::2"),
+ in6addr_any,
+ 64,
+ 3600,
+ 3600,
+ 0);
+
+ route = nmtst_platform_ip6_route_full ("2001:db8:8086::",
+ 48,
+ NULL,
+ ifindex,
+ NM_IP_CONFIG_SOURCE_USER,
+ 20,
+ 0);
+ g_array_append_val (routes, *route);
+
+ route = nmtst_platform_ip6_route_full ("2001:db8:abad:c0de::",
+ 64,
+ "2001:db8:8086::1",
+ ifindex,
+ NM_IP_CONFIG_SOURCE_USER,
+ 21,
+ 0);
+ g_array_append_val (routes, *route);
+
+ nm_route_manager_ip6_route_sync (nm_route_manager_get (), ifindex, routes);
+ g_array_free (routes, TRUE);
+}
+
+static void
+setup_dev1_ip6 (int ifindex)
+{
+ GArray *routes = g_array_new (FALSE, FALSE, sizeof (NMPlatformIP6Route));
+ NMPlatformIP6Route *route;
+
+ /* Add some route outside of route manager. The route manager
+ * should get rid of it upon sync. */
+ nm_platform_ip6_route_add (ifindex,
+ NM_IP_CONFIG_SOURCE_USER,
+ *nmtst_inet6_from_string ("2001:db8:8088::"),
+ 48,
+ in6addr_any,
+ 10,
+ 0);
+
+ route = nmtst_platform_ip6_route_full ("2001:db8:8086::",
+ 48,
+ NULL,
+ ifindex,
+ NM_IP_CONFIG_SOURCE_USER,
+ 20,
+ 0);
+ g_array_append_val (routes, *route);
+
+ route = nmtst_platform_ip6_route_full ("2001:db8:abad:c0de::",
+ 64,
+ NULL,
+ ifindex,
+ NM_IP_CONFIG_SOURCE_USER,
+ 22,
+ 0);
+ g_array_append_val (routes, *route);
+
+ nm_route_manager_ip6_route_sync (nm_route_manager_get (), ifindex, routes);
+ g_array_free (routes, TRUE);
+}
+
+static GArray *
+ip6_routes (test_fixture *fixture)
+{
+ GArray *routes = nm_platform_ip6_route_get_all (fixture->ifindex0,
+ NM_PLATFORM_GET_ROUTE_MODE_NO_DEFAULT);
+ GArray *routes1 = nm_platform_ip6_route_get_all (fixture->ifindex1,
+ NM_PLATFORM_GET_ROUTE_MODE_NO_DEFAULT);
+
+ g_array_append_vals (routes, routes1->data, routes1->len);
+ g_array_free (routes1, TRUE);
+
+ return routes;
+}
+
+static void
+test_ip6 (test_fixture *fixture, gconstpointer user_data)
+{
+ GArray *routes;
+
+ NMPlatformIP6Route state1[] = {
+ {
+ .source = NM_IP_CONFIG_SOURCE_USER,
+ .network = *nmtst_inet6_from_string ("2001:db8:abad:c0de::"),
+ .plen = 64,
+ .ifindex = fixture->ifindex0,
+ .gateway = *nmtst_inet6_from_string ("2001:db8:8086::1"),
+ .metric = 21,
+ .mss = 0,
+ },
+ {
+ .source = NM_IP_CONFIG_SOURCE_USER,
+ .network = *nmtst_inet6_from_string ("2001:db8:8086::"),
+ .plen = 48,
+ .ifindex = fixture->ifindex0,
+ .gateway = in6addr_any,
+ .metric = 20,
+ .mss = 0,
+ },
+ {
+ .source = NM_IP_CONFIG_SOURCE_USER,
+ .network = *nmtst_inet6_from_string ("2001:db8:abad:c0de::"),
+ .plen = 64,
+ .ifindex = fixture->ifindex1,
+ .gateway = in6addr_any,
+ .metric = 22,
+ .mss = 0,
+ },
+ };
+
+ NMPlatformIP6Route state2[] = {
+ {
+ .source = NM_IP_CONFIG_SOURCE_USER,
+ .network = *nmtst_inet6_from_string ("2001:db8:abad:c0de::"),
+ .plen = 64,
+ .ifindex = fixture->ifindex1,
+ .gateway = in6addr_any,
+ .metric = 22,
+ .mss = 0,
+ },
+ {
+ .source = NM_IP_CONFIG_SOURCE_USER,
+ .network = *nmtst_inet6_from_string ("2001:db8:8086::"),
+ .plen = 48,
+ .ifindex = fixture->ifindex1,
+ .gateway = in6addr_any,
+ .metric = 20,
+ .mss = 0,
+ },
+ };
+
+ setup_dev0_ip6 (fixture->ifindex0);
+ setup_dev1_ip6 (fixture->ifindex1);
+
+ /* Check that the 2001:db8:8086::/48 didn't clash and everything else is fine too. */
+ routes = ip6_routes (fixture);
+ g_assert_cmpint (routes->len, ==, G_N_ELEMENTS (state1));
+ nmtst_platform_ip6_routes_equal ((NMPlatformIP6Route *) routes->data, state1, routes->len);
+ g_array_free (routes, TRUE);
+
+ setup_dev1_ip6 (fixture->ifindex1);
+ setup_dev0_ip6 (fixture->ifindex0);
+
+ /* Ensure nothing changed. */
+ routes = ip6_routes (fixture);
+ g_assert_cmpint (routes->len, ==, G_N_ELEMENTS (state1));
+ nmtst_platform_ip6_routes_equal ((NMPlatformIP6Route *) routes->data, state1, routes->len);
+ g_array_free (routes, TRUE);
+
+ nm_route_manager_route_flush (nm_route_manager_get (), fixture->ifindex0);
+
+ /* Check that the 2001:db8:8086::/48 is now on dev1 and other dev0 routes went away. */
+ routes = ip6_routes (fixture);
+ g_assert_cmpint (routes->len, ==, G_N_ELEMENTS (state2));
+ nmtst_platform_ip6_routes_equal ((NMPlatformIP6Route *) routes->data, state2, routes->len);
+ g_array_free (routes, TRUE);
+
+ nm_route_manager_route_flush (nm_route_manager_get (), fixture->ifindex1);
+
+ /* No routes left. */
+ routes = ip6_routes (fixture);
+ g_assert_cmpint (routes->len, ==, 0);
+ g_array_free (routes, TRUE);
+}
+
+static void
+fixture_setup (test_fixture *fixture, gconstpointer user_data)
+{
+ SignalData *link_added;
+
+ link_added = add_signal_ifname (NM_PLATFORM_SIGNAL_LINK_CHANGED,
+ NM_PLATFORM_SIGNAL_ADDED,
+ link_callback,
+ "nm-test-device0");
+ nm_platform_link_delete (nm_platform_link_get_ifindex ("nm-test-device0"));
+ g_assert (!nm_platform_link_exists ("nm-test-device0"));
+ g_assert (nm_platform_dummy_add ("nm-test-device0"));
+ accept_signal (link_added);
+ free_signal (link_added);
+ fixture->ifindex0 = nm_platform_link_get_ifindex ("nm-test-device0");
+ g_assert (nm_platform_link_set_up (fixture->ifindex0));
+
+ link_added = add_signal_ifname (NM_PLATFORM_SIGNAL_LINK_CHANGED,
+ NM_PLATFORM_SIGNAL_ADDED,
+ link_callback,
+ "nm-test-device1");
+ nm_platform_link_delete (nm_platform_link_get_ifindex ("nm-test-device1"));
+ g_assert (!nm_platform_link_exists ("nm-test-device1"));
+ g_assert (nm_platform_dummy_add ("nm-test-device1"));
+ accept_signal (link_added);
+ free_signal (link_added);
+ fixture->ifindex1 = nm_platform_link_get_ifindex ("nm-test-device1");
+ g_assert (nm_platform_link_set_up (fixture->ifindex1));
+}
+
+static void
+fixture_teardown (test_fixture *fixture, gconstpointer user_data)
+{
+ nm_platform_link_delete (fixture->ifindex0);
+ nm_platform_link_delete (fixture->ifindex1);
+}
+
+void
+setup_tests (void)
+{
+ g_test_add ("/route-manager/ip4", test_fixture, NULL, fixture_setup, test_ip4, fixture_teardown);
+ g_test_add ("/route-manager/ip6", test_fixture, NULL, fixture_setup, test_ip6, fixture_teardown);
+}