xref: /freebsd/tests/sys/netlink/test_snl_generic.c (revision 7ee6b0f125a092ed99d327bb8d608dd2ff77b7aa)
173ae25c1SAlexander V. Chernikov #include <stdio.h>
273ae25c1SAlexander V. Chernikov #include <string.h>
373ae25c1SAlexander V. Chernikov #include <stdlib.h>
473ae25c1SAlexander V. Chernikov 
573ae25c1SAlexander V. Chernikov #include <sys/param.h>
673ae25c1SAlexander V. Chernikov #include <sys/module.h>
773ae25c1SAlexander V. Chernikov 
873ae25c1SAlexander V. Chernikov #include <netlink/netlink.h>
973ae25c1SAlexander V. Chernikov #include "netlink/netlink_snl.h"
1073ae25c1SAlexander V. Chernikov #include "netlink/netlink_snl_generic.h"
1173ae25c1SAlexander V. Chernikov 
1273ae25c1SAlexander V. Chernikov #include <atf-c.h>
1373ae25c1SAlexander V. Chernikov 
1473ae25c1SAlexander V. Chernikov static void
1573ae25c1SAlexander V. Chernikov require_netlink(void)
1673ae25c1SAlexander V. Chernikov {
1773ae25c1SAlexander V. Chernikov 	if (modfind("netlink") == -1)
1873ae25c1SAlexander V. Chernikov 		atf_tc_skip("netlink module not loaded");
1973ae25c1SAlexander V. Chernikov }
2073ae25c1SAlexander V. Chernikov 
2173ae25c1SAlexander V. Chernikov ATF_TC(snl_verify_genl_parsers);
2273ae25c1SAlexander V. Chernikov ATF_TC_HEAD(snl_verify_genl_parsers, tc)
2373ae25c1SAlexander V. Chernikov {
2473ae25c1SAlexander V. Chernikov 	atf_tc_set_md_var(tc, "descr", "Tests snl(3) generic parsers are correct");
2573ae25c1SAlexander V. Chernikov }
2673ae25c1SAlexander V. Chernikov 
2773ae25c1SAlexander V. Chernikov ATF_TC_BODY(snl_verify_genl_parsers, tc)
2873ae25c1SAlexander V. Chernikov {
2973ae25c1SAlexander V. Chernikov 	SNL_VERIFY_PARSERS(snl_all_genl_parsers);
3073ae25c1SAlexander V. Chernikov 
3173ae25c1SAlexander V. Chernikov }
3273ae25c1SAlexander V. Chernikov 
3373ae25c1SAlexander V. Chernikov ATF_TC(test_snl_get_genl_family_success);
3473ae25c1SAlexander V. Chernikov ATF_TC_HEAD(test_snl_get_genl_family_success, tc)
3573ae25c1SAlexander V. Chernikov {
3673ae25c1SAlexander V. Chernikov 	atf_tc_set_md_var(tc, "descr", "Tests successfull resolution of the 'nlctrl' family");
3773ae25c1SAlexander V. Chernikov }
3873ae25c1SAlexander V. Chernikov 
3973ae25c1SAlexander V. Chernikov ATF_TC_BODY(test_snl_get_genl_family_success, tc)
4073ae25c1SAlexander V. Chernikov {
4173ae25c1SAlexander V. Chernikov 	struct snl_state ss;
4273ae25c1SAlexander V. Chernikov 
4373ae25c1SAlexander V. Chernikov 	require_netlink();
4473ae25c1SAlexander V. Chernikov 
4573ae25c1SAlexander V. Chernikov 	if (!snl_init(&ss, NETLINK_GENERIC))
4673ae25c1SAlexander V. Chernikov 		atf_tc_fail("snl_init() failed");
4773ae25c1SAlexander V. Chernikov 
4873ae25c1SAlexander V. Chernikov 	ATF_CHECK_EQ(snl_get_genl_family(&ss, "nlctrl"), GENL_ID_CTRL);
4973ae25c1SAlexander V. Chernikov }
5073ae25c1SAlexander V. Chernikov 
5173ae25c1SAlexander V. Chernikov ATF_TC(test_snl_get_genl_family_failure);
5273ae25c1SAlexander V. Chernikov ATF_TC_HEAD(test_snl_get_genl_family_failure, tc)
5373ae25c1SAlexander V. Chernikov {
5473ae25c1SAlexander V. Chernikov 	atf_tc_set_md_var(tc, "descr", "Tests unsuccessfull resolution of 'no-such-family' family");
5573ae25c1SAlexander V. Chernikov }
5673ae25c1SAlexander V. Chernikov 
5773ae25c1SAlexander V. Chernikov ATF_TC_BODY(test_snl_get_genl_family_failure, tc)
5873ae25c1SAlexander V. Chernikov {
5973ae25c1SAlexander V. Chernikov 	struct snl_state ss;
6073ae25c1SAlexander V. Chernikov 
6173ae25c1SAlexander V. Chernikov 	require_netlink();
6273ae25c1SAlexander V. Chernikov 
6373ae25c1SAlexander V. Chernikov 	if (!snl_init(&ss, NETLINK_GENERIC))
6473ae25c1SAlexander V. Chernikov 		atf_tc_fail("snl_init() failed");
6573ae25c1SAlexander V. Chernikov 
6673ae25c1SAlexander V. Chernikov 	ATF_CHECK_EQ(snl_get_genl_family(&ss, "no-such-family"), 0);
6773ae25c1SAlexander V. Chernikov }
6873ae25c1SAlexander V. Chernikov 
69*7ee6b0f1SAlexander V. Chernikov ATF_TC(test_snl_get_genl_family_groups);
70*7ee6b0f1SAlexander V. Chernikov ATF_TC_HEAD(test_snl_get_genl_family_groups, tc)
71*7ee6b0f1SAlexander V. Chernikov {
72*7ee6b0f1SAlexander V. Chernikov 	atf_tc_set_md_var(tc, "descr", "Tests getting 'nlctrl' groups");
73*7ee6b0f1SAlexander V. Chernikov }
74*7ee6b0f1SAlexander V. Chernikov 
75*7ee6b0f1SAlexander V. Chernikov ATF_TC_BODY(test_snl_get_genl_family_groups, tc)
76*7ee6b0f1SAlexander V. Chernikov {
77*7ee6b0f1SAlexander V. Chernikov 	struct snl_state ss;
78*7ee6b0f1SAlexander V. Chernikov 	struct snl_writer nw;
79*7ee6b0f1SAlexander V. Chernikov 	struct nlmsghdr *hdr;
80*7ee6b0f1SAlexander V. Chernikov 
81*7ee6b0f1SAlexander V. Chernikov 	require_netlink();
82*7ee6b0f1SAlexander V. Chernikov 
83*7ee6b0f1SAlexander V. Chernikov 	if (!snl_init(&ss, NETLINK_GENERIC))
84*7ee6b0f1SAlexander V. Chernikov 		atf_tc_fail("snl_init() failed");
85*7ee6b0f1SAlexander V. Chernikov 
86*7ee6b0f1SAlexander V. Chernikov 	snl_init_writer(&ss, &nw);
87*7ee6b0f1SAlexander V. Chernikov 	hdr = snl_create_genl_msg_request(&nw, GENL_ID_CTRL, CTRL_CMD_GETFAMILY);
88*7ee6b0f1SAlexander V. Chernikov 	snl_add_msg_attr_string(&nw, CTRL_ATTR_FAMILY_NAME, "nlctrl");
89*7ee6b0f1SAlexander V. Chernikov 	snl_finalize_msg(&nw);
90*7ee6b0f1SAlexander V. Chernikov 	snl_send_message(&ss, hdr);
91*7ee6b0f1SAlexander V. Chernikov 
92*7ee6b0f1SAlexander V. Chernikov 	hdr = snl_read_reply(&ss, hdr->nlmsg_seq);
93*7ee6b0f1SAlexander V. Chernikov 	ATF_CHECK(hdr != NULL);
94*7ee6b0f1SAlexander V. Chernikov 	ATF_CHECK(hdr->nlmsg_type != NLMSG_ERROR);
95*7ee6b0f1SAlexander V. Chernikov 
96*7ee6b0f1SAlexander V. Chernikov 	struct _getfamily_attrs attrs = {};
97*7ee6b0f1SAlexander V. Chernikov 
98*7ee6b0f1SAlexander V. Chernikov 	ATF_CHECK(snl_parse_nlmsg(&ss, hdr, &_genl_ctrl_getfam_parser, &attrs));
99*7ee6b0f1SAlexander V. Chernikov 	ATF_CHECK_EQ(attrs.mcast_groups.num_groups, 1);
100*7ee6b0f1SAlexander V. Chernikov 
101*7ee6b0f1SAlexander V. Chernikov 	struct snl_genl_ctrl_mcast_group *group = attrs.mcast_groups.groups[0];
102*7ee6b0f1SAlexander V. Chernikov 
103*7ee6b0f1SAlexander V. Chernikov 	ATF_CHECK(group->mcast_grp_id > 0);
104*7ee6b0f1SAlexander V. Chernikov 	ATF_CHECK(!strcmp(group->mcast_grp_name, "notify"));
105*7ee6b0f1SAlexander V. Chernikov }
106*7ee6b0f1SAlexander V. Chernikov 
10773ae25c1SAlexander V. Chernikov ATF_TP_ADD_TCS(tp)
10873ae25c1SAlexander V. Chernikov {
10973ae25c1SAlexander V. Chernikov 	ATF_TP_ADD_TC(tp, snl_verify_genl_parsers);
11073ae25c1SAlexander V. Chernikov 	ATF_TP_ADD_TC(tp, test_snl_get_genl_family_success);
11173ae25c1SAlexander V. Chernikov 	ATF_TP_ADD_TC(tp, test_snl_get_genl_family_failure);
112*7ee6b0f1SAlexander V. Chernikov 	ATF_TP_ADD_TC(tp, test_snl_get_genl_family_groups);
11373ae25c1SAlexander V. Chernikov 
11473ae25c1SAlexander V. Chernikov 	return (atf_no_error());
11573ae25c1SAlexander V. Chernikov }
11673ae25c1SAlexander V. Chernikov 
117