summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorYu Watanabe <watanabe.yu+github@gmail.com>2021-09-14 14:55:25 +0900
committerYu Watanabe <watanabe.yu+github@gmail.com>2021-09-14 20:30:09 +0900
commit0856e78df05c289fd1abe488f52d0f4eb22c410c (patch)
tree33071c0bb8fc5df2a9995f1851a364d4b14bb581 /src
parent0bc311bbe911e1f30d55878bd17ccc4659da0c50 (diff)
downloadsystemd-0856e78df05c289fd1abe488f52d0f4eb22c410c.tar.gz
test: add tests for in-addr-prefix-util.c
Diffstat (limited to 'src')
-rw-r--r--src/test/meson.build2
-rw-r--r--src/test/test-in-addr-prefix-util.c94
2 files changed, 96 insertions, 0 deletions
diff --git a/src/test/meson.build b/src/test/meson.build
index 46b497672f..f58cf2d843 100644
--- a/src/test/meson.build
+++ b/src/test/meson.build
@@ -285,6 +285,8 @@ tests += [
[['src/test/test-in-addr-util.c']],
+ [['src/test/test-in-addr-prefix-util.c']],
+
[['src/test/test-barrier.c']],
[['src/test/test-tmpfiles.c']],
diff --git a/src/test/test-in-addr-prefix-util.c b/src/test/test-in-addr-prefix-util.c
new file mode 100644
index 0000000000..5db22302bf
--- /dev/null
+++ b/src/test/test-in-addr-prefix-util.c
@@ -0,0 +1,94 @@
+/* SPDX-License-Identifier: LGPL-2.1-or-later */
+
+#include "in-addr-prefix-util.h"
+#include "tests.h"
+
+static void test_config_parse_in_addr_prefixes_one(int family, const union in_addr_union *addr, uint8_t prefixlen, Set **prefixes) {
+ _cleanup_free_ char *str = NULL;
+
+ assert_se(in_addr_prefix_to_string(family, addr, prefixlen, &str) >= 0);
+ assert_se(config_parse_in_addr_prefixes("unit", "filename", 1, "Service", 1, "IPAddressAllow", 0, str, prefixes, NULL) >= 0);
+}
+
+static void test_config_parse_in_addr_prefixes(Set **ret) {
+ _cleanup_set_free_ Set *prefixes = NULL;
+
+ log_info("/* %s() */", __func__);
+
+ for (uint32_t i = 0; i < 256; i++) {
+ /* ipv4 link-local address */
+ test_config_parse_in_addr_prefixes_one(AF_INET, &(union in_addr_union) {
+ .in.s_addr = htobe32((UINT32_C(169) << 24) |
+ (UINT32_C(254) << 16) |
+ (i << 8)),
+ }, 24, &prefixes);
+
+ /* ipv6 multicast address */
+ test_config_parse_in_addr_prefixes_one(AF_INET6, &(union in_addr_union) {
+ .in6.s6_addr[0] = 0xff,
+ .in6.s6_addr[1] = i,
+ }, 16, &prefixes);
+
+ for (uint32_t j = 0; j < 256; j++) {
+ test_config_parse_in_addr_prefixes_one(AF_INET, &(union in_addr_union) {
+ .in.s_addr = htobe32((UINT32_C(169) << 24) |
+ (UINT32_C(254) << 16) |
+ (i << 8) | j),
+ }, 32, &prefixes);
+
+ test_config_parse_in_addr_prefixes_one(AF_INET6, &(union in_addr_union) {
+ .in6.s6_addr[0] = 0xff,
+ .in6.s6_addr[1] = i,
+ .in6.s6_addr[2] = j,
+ }, 24, &prefixes);
+ }
+ }
+
+ *ret = TAKE_PTR(prefixes);
+}
+
+static void test_in_addr_prefixes_reduce(Set *prefixes) {
+ log_info("/* %s() */", __func__);
+
+ assert_se(set_size(prefixes) == 2 * 256 * 257);
+ assert_se(!in_addr_prefixes_is_any(prefixes));
+
+ assert_se(in_addr_prefixes_reduce(prefixes) >= 0);
+ assert_se(set_size(prefixes) == 2 * 256);
+ assert_se(!in_addr_prefixes_is_any(prefixes));
+
+ assert_se(config_parse_in_addr_prefixes("unit", "filename", 1, "Service", 1, "IPAddressAllow", 0, "link-local", &prefixes, NULL) == 0);
+ assert_se(set_size(prefixes) == 2 * 256 + 2);
+ assert_se(!in_addr_prefixes_is_any(prefixes));
+
+ assert_se(in_addr_prefixes_reduce(prefixes) >= 0);
+ assert_se(set_size(prefixes) == 256 + 2);
+ assert_se(!in_addr_prefixes_is_any(prefixes));
+
+ assert_se(config_parse_in_addr_prefixes("unit", "filename", 1, "Service", 1, "IPAddressAllow", 0, "multicast", &prefixes, NULL) == 0);
+ assert_se(set_size(prefixes) == 256 + 4);
+ assert_se(!in_addr_prefixes_is_any(prefixes));
+
+ assert_se(in_addr_prefixes_reduce(prefixes) >= 0);
+ assert_se(set_size(prefixes) == 4);
+ assert_se(!in_addr_prefixes_is_any(prefixes));
+
+ assert_se(config_parse_in_addr_prefixes("unit", "filename", 1, "Service", 1, "IPAddressAllow", 0, "any", &prefixes, NULL) == 0);
+ assert_se(set_size(prefixes) == 6);
+ assert_se(in_addr_prefixes_is_any(prefixes));
+
+ assert_se(in_addr_prefixes_reduce(prefixes) >= 0);
+ assert_se(set_size(prefixes) == 2);
+ assert_se(in_addr_prefixes_is_any(prefixes));
+}
+
+int main(int argc, char *argv[]) {
+ _cleanup_set_free_ Set *prefixes = NULL;
+
+ test_setup_logging(LOG_DEBUG);
+
+ test_config_parse_in_addr_prefixes(&prefixes);
+ test_in_addr_prefixes_reduce(prefixes);
+
+ return 0;
+}