mirror of
https://github.com/systemd/systemd-stable.git
synced 2024-12-24 21:34:08 +03:00
test: add tests for in-addr-prefix-util.c
This commit is contained in:
parent
0bc311bbe9
commit
0856e78df0
@ -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']],
|
||||
|
94
src/test/test-in-addr-prefix-util.c
Normal file
94
src/test/test-in-addr-prefix-util.c
Normal file
@ -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;
|
||||
}
|
Loading…
Reference in New Issue
Block a user