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 697ee6b0f1SAlexander V. Chernikov ATF_TC(test_snl_get_genl_family_groups); 707ee6b0f1SAlexander V. Chernikov ATF_TC_HEAD(test_snl_get_genl_family_groups, tc) 717ee6b0f1SAlexander V. Chernikov { 727ee6b0f1SAlexander V. Chernikov atf_tc_set_md_var(tc, "descr", "Tests getting 'nlctrl' groups"); 737ee6b0f1SAlexander V. Chernikov } 747ee6b0f1SAlexander V. Chernikov 757ee6b0f1SAlexander V. Chernikov ATF_TC_BODY(test_snl_get_genl_family_groups, tc) 767ee6b0f1SAlexander V. Chernikov { 777ee6b0f1SAlexander V. Chernikov struct snl_state ss; 787ee6b0f1SAlexander V. Chernikov struct snl_writer nw; 797ee6b0f1SAlexander V. Chernikov struct nlmsghdr *hdr; 807ee6b0f1SAlexander V. Chernikov 817ee6b0f1SAlexander V. Chernikov require_netlink(); 827ee6b0f1SAlexander V. Chernikov 837ee6b0f1SAlexander V. Chernikov if (!snl_init(&ss, NETLINK_GENERIC)) 847ee6b0f1SAlexander V. Chernikov atf_tc_fail("snl_init() failed"); 857ee6b0f1SAlexander V. Chernikov 867ee6b0f1SAlexander V. Chernikov snl_init_writer(&ss, &nw); 877ee6b0f1SAlexander V. Chernikov hdr = snl_create_genl_msg_request(&nw, GENL_ID_CTRL, CTRL_CMD_GETFAMILY); 887ee6b0f1SAlexander V. Chernikov snl_add_msg_attr_string(&nw, CTRL_ATTR_FAMILY_NAME, "nlctrl"); 89*4f8f43b0SKristof Provost hdr = snl_finalize_msg(&nw); 907ee6b0f1SAlexander V. Chernikov snl_send_message(&ss, hdr); 917ee6b0f1SAlexander V. Chernikov 927ee6b0f1SAlexander V. Chernikov hdr = snl_read_reply(&ss, hdr->nlmsg_seq); 937ee6b0f1SAlexander V. Chernikov ATF_CHECK(hdr != NULL); 947ee6b0f1SAlexander V. Chernikov ATF_CHECK(hdr->nlmsg_type != NLMSG_ERROR); 957ee6b0f1SAlexander V. Chernikov 967ee6b0f1SAlexander V. Chernikov struct _getfamily_attrs attrs = {}; 977ee6b0f1SAlexander V. Chernikov 987ee6b0f1SAlexander V. Chernikov ATF_CHECK(snl_parse_nlmsg(&ss, hdr, &_genl_ctrl_getfam_parser, &attrs)); 997ee6b0f1SAlexander V. Chernikov ATF_CHECK_EQ(attrs.mcast_groups.num_groups, 1); 1007ee6b0f1SAlexander V. Chernikov 1017ee6b0f1SAlexander V. Chernikov struct snl_genl_ctrl_mcast_group *group = attrs.mcast_groups.groups[0]; 1027ee6b0f1SAlexander V. Chernikov 1037ee6b0f1SAlexander V. Chernikov ATF_CHECK(group->mcast_grp_id > 0); 1047ee6b0f1SAlexander V. Chernikov ATF_CHECK(!strcmp(group->mcast_grp_name, "notify")); 1057ee6b0f1SAlexander V. Chernikov } 1067ee6b0f1SAlexander 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); 1127ee6b0f1SAlexander 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