diff options
Diffstat (limited to 'src/platform/tests/test-cleanup.c')
-rw-r--r-- | src/platform/tests/test-cleanup.c | 95 |
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 */ +} |