summaryrefslogtreecommitdiff
path: root/src/platform/tests/test-cleanup.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/platform/tests/test-cleanup.c')
-rw-r--r--src/platform/tests/test-cleanup.c95
1 files changed, 95 insertions, 0 deletions
diff --git a/src/platform/tests/test-cleanup.c b/src/platform/tests/test-cleanup.c
new file mode 100644
index 000000000..e60d82f0e
--- /dev/null
+++ b/src/platform/tests/test-cleanup.c
@@ -0,0 +1,95 @@
+#include "test-common.h"
+
+#define DEVICE_NAME "nm-test-device"
+
+static void
+test_cleanup_internal ()
+{
+ SignalData *link_added = add_signal_ifname (NM_PLATFORM_SIGNAL_LINK_CHANGED, NM_PLATFORM_SIGNAL_ADDED, link_callback, DEVICE_NAME);
+ int ifindex;
+ GArray *addresses4;
+ GArray *addresses6;
+ GArray *routes4;
+ GArray *routes6;
+ in_addr_t addr4;
+ in_addr_t network4;
+ int plen4 = 24;
+ in_addr_t gateway4;
+ struct in6_addr addr6;
+ struct in6_addr network6;
+ int plen6 = 64;
+ struct in6_addr gateway6;
+ int lifetime = NM_PLATFORM_LIFETIME_PERMANENT;
+ int preferred = NM_PLATFORM_LIFETIME_PERMANENT;
+ int metric = 20;
+ int mss = 1000;
+ guint flags = 0;
+
+ inet_pton (AF_INET, "192.0.2.1", &addr4);
+ inet_pton (AF_INET, "192.0.3.0", &network4);
+ inet_pton (AF_INET, "198.51.100.1", &gateway4);
+ inet_pton (AF_INET6, "2001:db8:a:b:1:2:3:4", &addr6);
+ inet_pton (AF_INET6, "2001:db8:c:d:0:0:0:0", &network6);
+ inet_pton (AF_INET6, "2001:db8:e:f:1:2:3:4", &gateway6);
+
+ /* Create and set up device */
+ g_assert (nm_platform_dummy_add (DEVICE_NAME));
+ accept_signal (link_added);
+ free_signal (link_added);
+ g_assert (nm_platform_link_set_up (nm_platform_link_get_ifindex (DEVICE_NAME)));
+ ifindex = nm_platform_link_get_ifindex (DEVICE_NAME);
+ g_assert (ifindex > 0);
+
+ /* Add routes and addresses */
+ g_assert (nm_platform_ip4_address_add (ifindex, addr4, 0, plen4, lifetime, preferred, NULL));
+ g_assert (nm_platform_ip6_address_add (ifindex, addr6, in6addr_any, plen6, lifetime, preferred, flags));
+ g_assert (nm_platform_ip4_route_add (ifindex, NM_PLATFORM_SOURCE_USER, gateway4, 32, INADDR_ANY, metric, mss));
+ g_assert (nm_platform_ip4_route_add (ifindex, NM_PLATFORM_SOURCE_USER, network4, plen4, gateway4, metric, mss));
+ g_assert (nm_platform_ip4_route_add (ifindex, NM_PLATFORM_SOURCE_USER, 0, 0, gateway4, metric, mss));
+ g_assert (nm_platform_ip6_route_add (ifindex, NM_PLATFORM_SOURCE_USER, gateway6, 128, in6addr_any, metric, mss));
+ g_assert (nm_platform_ip6_route_add (ifindex, NM_PLATFORM_SOURCE_USER, network6, plen6, gateway6, metric, mss));
+ g_assert (nm_platform_ip6_route_add (ifindex, NM_PLATFORM_SOURCE_USER, in6addr_any, 0, gateway6, metric, mss));
+
+ addresses4 = nm_platform_ip4_address_get_all (ifindex);
+ addresses6 = nm_platform_ip6_address_get_all (ifindex);
+ routes4 = nm_platform_ip4_route_get_all (ifindex, TRUE);
+ routes6 = nm_platform_ip6_route_get_all (ifindex, TRUE);
+
+ g_assert_cmpint (addresses4->len, ==, 1);
+ g_assert_cmpint (addresses6->len, ==, 1);
+ g_assert_cmpint (routes4->len, ==, 3);
+ g_assert_cmpint (routes6->len, ==, 3);
+
+ g_array_unref (addresses4);
+ g_array_unref (addresses6);
+ g_array_unref (routes4);
+ g_array_unref (routes6);
+
+ /* Delete interface with all addresses and routes */
+ g_assert (nm_platform_link_delete (ifindex));
+
+ addresses4 = nm_platform_ip4_address_get_all (ifindex);
+ addresses6 = nm_platform_ip6_address_get_all (ifindex);
+ routes4 = nm_platform_ip4_route_get_all (ifindex, TRUE);
+ routes6 = nm_platform_ip6_route_get_all (ifindex, TRUE);
+
+ g_assert_cmpint (addresses4->len, ==, 0);
+ g_assert_cmpint (addresses6->len, ==, 0);
+ g_assert_cmpint (routes4->len, ==, 0);
+ g_assert_cmpint (routes6->len, ==, 0);
+
+ g_array_unref (addresses4);
+ g_array_unref (addresses6);
+ g_array_unref (routes4);
+ g_array_unref (routes6);
+}
+
+void
+setup_tests (void)
+{
+ nm_platform_link_delete (nm_platform_link_get_ifindex (DEVICE_NAME));
+ g_assert (!nm_platform_link_exists (DEVICE_NAME));
+
+ g_test_add_func ("/internal", test_cleanup_internal);
+ /* FIXME: add external cleanup check */
+}