xref: /freebsd/tests/sys/netlink/test_snl_generic.c (revision 65eaf726201cd81ecbc17b266786a042bccdf473)
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 
14*65eaf726SJohn Baldwin static const struct snl_hdr_parser *snl_all_genl_parsers[] = {
15*65eaf726SJohn Baldwin 	&_genl_ctrl_getfam_parser, &_genl_ctrl_mc_parser,
16*65eaf726SJohn Baldwin };
17*65eaf726SJohn Baldwin 
1873ae25c1SAlexander V. Chernikov static void
require_netlink(void)1973ae25c1SAlexander V. Chernikov require_netlink(void)
2073ae25c1SAlexander V. Chernikov {
2173ae25c1SAlexander V. Chernikov 	if (modfind("netlink") == -1)
2273ae25c1SAlexander V. Chernikov 		atf_tc_skip("netlink module not loaded");
2373ae25c1SAlexander V. Chernikov }
2473ae25c1SAlexander V. Chernikov 
2573ae25c1SAlexander V. Chernikov ATF_TC(snl_verify_genl_parsers);
ATF_TC_HEAD(snl_verify_genl_parsers,tc)2673ae25c1SAlexander V. Chernikov ATF_TC_HEAD(snl_verify_genl_parsers, tc)
2773ae25c1SAlexander V. Chernikov {
2873ae25c1SAlexander V. Chernikov 	atf_tc_set_md_var(tc, "descr", "Tests snl(3) generic parsers are correct");
2973ae25c1SAlexander V. Chernikov }
3073ae25c1SAlexander V. Chernikov 
ATF_TC_BODY(snl_verify_genl_parsers,tc)3173ae25c1SAlexander V. Chernikov ATF_TC_BODY(snl_verify_genl_parsers, tc)
3273ae25c1SAlexander V. Chernikov {
3373ae25c1SAlexander V. Chernikov 	SNL_VERIFY_PARSERS(snl_all_genl_parsers);
3473ae25c1SAlexander V. Chernikov 
3573ae25c1SAlexander V. Chernikov }
3673ae25c1SAlexander V. Chernikov 
3773ae25c1SAlexander V. Chernikov ATF_TC(test_snl_get_genl_family_success);
ATF_TC_HEAD(test_snl_get_genl_family_success,tc)3873ae25c1SAlexander V. Chernikov ATF_TC_HEAD(test_snl_get_genl_family_success, tc)
3973ae25c1SAlexander V. Chernikov {
4073ae25c1SAlexander V. Chernikov 	atf_tc_set_md_var(tc, "descr", "Tests successfull resolution of the 'nlctrl' family");
4173ae25c1SAlexander V. Chernikov }
4273ae25c1SAlexander V. Chernikov 
ATF_TC_BODY(test_snl_get_genl_family_success,tc)4373ae25c1SAlexander V. Chernikov ATF_TC_BODY(test_snl_get_genl_family_success, tc)
4473ae25c1SAlexander V. Chernikov {
4573ae25c1SAlexander V. Chernikov 	struct snl_state ss;
4673ae25c1SAlexander V. Chernikov 
4773ae25c1SAlexander V. Chernikov 	require_netlink();
4873ae25c1SAlexander V. Chernikov 
4973ae25c1SAlexander V. Chernikov 	if (!snl_init(&ss, NETLINK_GENERIC))
5073ae25c1SAlexander V. Chernikov 		atf_tc_fail("snl_init() failed");
5173ae25c1SAlexander V. Chernikov 
5273ae25c1SAlexander V. Chernikov 	ATF_CHECK_EQ(snl_get_genl_family(&ss, "nlctrl"), GENL_ID_CTRL);
5373ae25c1SAlexander V. Chernikov }
5473ae25c1SAlexander V. Chernikov 
5573ae25c1SAlexander V. Chernikov ATF_TC(test_snl_get_genl_family_failure);
ATF_TC_HEAD(test_snl_get_genl_family_failure,tc)5673ae25c1SAlexander V. Chernikov ATF_TC_HEAD(test_snl_get_genl_family_failure, tc)
5773ae25c1SAlexander V. Chernikov {
5873ae25c1SAlexander V. Chernikov 	atf_tc_set_md_var(tc, "descr", "Tests unsuccessfull resolution of 'no-such-family' family");
5973ae25c1SAlexander V. Chernikov }
6073ae25c1SAlexander V. Chernikov 
ATF_TC_BODY(test_snl_get_genl_family_failure,tc)6173ae25c1SAlexander V. Chernikov ATF_TC_BODY(test_snl_get_genl_family_failure, tc)
6273ae25c1SAlexander V. Chernikov {
6373ae25c1SAlexander V. Chernikov 	struct snl_state ss;
6473ae25c1SAlexander V. Chernikov 
6573ae25c1SAlexander V. Chernikov 	require_netlink();
6673ae25c1SAlexander V. Chernikov 
6773ae25c1SAlexander V. Chernikov 	if (!snl_init(&ss, NETLINK_GENERIC))
6873ae25c1SAlexander V. Chernikov 		atf_tc_fail("snl_init() failed");
6973ae25c1SAlexander V. Chernikov 
7073ae25c1SAlexander V. Chernikov 	ATF_CHECK_EQ(snl_get_genl_family(&ss, "no-such-family"), 0);
7173ae25c1SAlexander V. Chernikov }
7273ae25c1SAlexander V. Chernikov 
737ee6b0f1SAlexander V. Chernikov ATF_TC(test_snl_get_genl_family_groups);
ATF_TC_HEAD(test_snl_get_genl_family_groups,tc)747ee6b0f1SAlexander V. Chernikov ATF_TC_HEAD(test_snl_get_genl_family_groups, tc)
757ee6b0f1SAlexander V. Chernikov {
767ee6b0f1SAlexander V. Chernikov 	atf_tc_set_md_var(tc, "descr", "Tests getting 'nlctrl' groups");
777ee6b0f1SAlexander V. Chernikov }
787ee6b0f1SAlexander V. Chernikov 
ATF_TC_BODY(test_snl_get_genl_family_groups,tc)797ee6b0f1SAlexander V. Chernikov ATF_TC_BODY(test_snl_get_genl_family_groups, tc)
807ee6b0f1SAlexander V. Chernikov {
817ee6b0f1SAlexander V. Chernikov 	struct snl_state ss;
827ee6b0f1SAlexander V. Chernikov 	struct snl_writer nw;
837ee6b0f1SAlexander V. Chernikov 	struct nlmsghdr *hdr;
847ee6b0f1SAlexander V. Chernikov 
857ee6b0f1SAlexander V. Chernikov 	require_netlink();
867ee6b0f1SAlexander V. Chernikov 
877ee6b0f1SAlexander V. Chernikov 	if (!snl_init(&ss, NETLINK_GENERIC))
887ee6b0f1SAlexander V. Chernikov 		atf_tc_fail("snl_init() failed");
897ee6b0f1SAlexander V. Chernikov 
907ee6b0f1SAlexander V. Chernikov 	snl_init_writer(&ss, &nw);
917ee6b0f1SAlexander V. Chernikov 	hdr = snl_create_genl_msg_request(&nw, GENL_ID_CTRL, CTRL_CMD_GETFAMILY);
927ee6b0f1SAlexander V. Chernikov 	snl_add_msg_attr_string(&nw, CTRL_ATTR_FAMILY_NAME, "nlctrl");
934f8f43b0SKristof Provost 	hdr = snl_finalize_msg(&nw);
947ee6b0f1SAlexander V. Chernikov 	snl_send_message(&ss, hdr);
957ee6b0f1SAlexander V. Chernikov 
967ee6b0f1SAlexander V. Chernikov 	hdr = snl_read_reply(&ss, hdr->nlmsg_seq);
977ee6b0f1SAlexander V. Chernikov 	ATF_CHECK(hdr != NULL);
987ee6b0f1SAlexander V. Chernikov 	ATF_CHECK(hdr->nlmsg_type != NLMSG_ERROR);
997ee6b0f1SAlexander V. Chernikov 
1007ee6b0f1SAlexander V. Chernikov 	struct _getfamily_attrs attrs = {};
1017ee6b0f1SAlexander V. Chernikov 
1027ee6b0f1SAlexander V. Chernikov 	ATF_CHECK(snl_parse_nlmsg(&ss, hdr, &_genl_ctrl_getfam_parser, &attrs));
1037ee6b0f1SAlexander V. Chernikov 	ATF_CHECK_EQ(attrs.mcast_groups.num_groups, 1);
1047ee6b0f1SAlexander V. Chernikov 
105f2a4eed3SGleb Smirnoff 	struct _snl_genl_ctrl_mcast_group *group = attrs.mcast_groups.groups[0];
1067ee6b0f1SAlexander V. Chernikov 
1077ee6b0f1SAlexander V. Chernikov 	ATF_CHECK(group->mcast_grp_id > 0);
1087ee6b0f1SAlexander V. Chernikov 	ATF_CHECK(!strcmp(group->mcast_grp_name, "notify"));
1097ee6b0f1SAlexander V. Chernikov }
1107ee6b0f1SAlexander V. Chernikov 
ATF_TP_ADD_TCS(tp)11173ae25c1SAlexander V. Chernikov ATF_TP_ADD_TCS(tp)
11273ae25c1SAlexander V. Chernikov {
11373ae25c1SAlexander V. Chernikov 	ATF_TP_ADD_TC(tp, snl_verify_genl_parsers);
11473ae25c1SAlexander V. Chernikov 	ATF_TP_ADD_TC(tp, test_snl_get_genl_family_success);
11573ae25c1SAlexander V. Chernikov 	ATF_TP_ADD_TC(tp, test_snl_get_genl_family_failure);
1167ee6b0f1SAlexander V. Chernikov 	ATF_TP_ADD_TC(tp, test_snl_get_genl_family_groups);
11773ae25c1SAlexander V. Chernikov 
11873ae25c1SAlexander V. Chernikov 	return (atf_no_error());
11973ae25c1SAlexander V. Chernikov }
12073ae25c1SAlexander V. Chernikov 
121