14 #include <netinet/in.h>
16 #include <linux/netfilter/nf_tables.h>
17 #include <libnftnl/table.h>
19 static int test_ok = 1;
21 static void print_err(
const char *msg)
24 printf(
"\033[31mERROR:\e[0m %s\n", msg);
27 static void cmp_nft_table(
struct nft_table *a,
struct nft_table *b)
29 if (strcmp(nft_table_attr_get_str(a, NFT_TABLE_ATTR_NAME),
30 nft_table_attr_get_str(b, NFT_TABLE_ATTR_NAME)) != 0)
31 print_err(
"table name mismatches");
32 if (nft_table_attr_get_u32(a, NFT_TABLE_ATTR_FLAGS) !=
33 nft_table_attr_get_u32(b, NFT_TABLE_ATTR_FLAGS))
34 print_err(
"table flags mismatches");
35 if (nft_table_attr_get_u32(a, NFT_TABLE_ATTR_FAMILY) !=
36 nft_table_attr_get_u32(b, NFT_TABLE_ATTR_FAMILY))
37 print_err(
"tabke family mismatches");
40 int main(
int argc,
char *argv[])
45 struct nft_table *a = NULL;
46 struct nft_table *b = NULL;
47 a = nft_table_alloc();
48 b = nft_table_alloc();
50 if (a == NULL || b == NULL)
53 nft_table_attr_set_str(a, NFT_TABLE_ATTR_NAME,
"test");
54 nft_table_attr_set_u32(a, NFT_TABLE_ATTR_FAMILY, AF_INET);
55 nft_table_attr_set_u32(a, NFT_TABLE_ATTR_FLAGS, 0);
58 nlh = nft_table_nlmsg_build_hdr(buf, NFT_MSG_NEWTABLE, AF_INET, 0,
60 nft_table_nlmsg_build_payload(nlh, a);
62 if (nft_table_nlmsg_parse(nlh, b) < 0)
63 print_err(
"parsing problems");
72 printf(
"%s: \033[32mOK\e[0m\n", argv[0]);