113cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle/* 213cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * Author: Joshua Brindle <jbrindle@tresys.com> 313cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * Chad Sellers <csellers@tresys.com> 413cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * 513cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * Copyright (C) 2006 Tresys Technology, LLC 613cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * 713cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * This library is free software; you can redistribute it and/or 813cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * modify it under the terms of the GNU Lesser General Public 913cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * License as published by the Free Software Foundation; either 1013cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * version 2.1 of the License, or (at your option) any later version. 1113cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * 1213cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * This library is distributed in the hope that it will be useful, 1313cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * but WITHOUT ANY WARRANTY; without even the implied warranty of 1413cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 1513cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * Lesser General Public License for more details. 1613cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * 1713cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * You should have received a copy of the GNU Lesser General Public 1813cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * License along with this library; if not, write to the Free Software 1913cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA 2013cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle */ 2113cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 2213cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle#ifndef __TEST_COMMON_H__ 2313cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle#define __TEST_COMMON_H__ 2413cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 2513cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle#include <sepol/policydb/policydb.h> 2613cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 2713cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle/* p the policy being inspected 2813cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * id string symbol identifier 2913cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * sym_type symbol type (eg., SYM_ROLES, SYM_TYPES) 3013cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * scope_type what scope the role should have (eg., SCOPE_DECL or SCOPE_REQ) 3113cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * decls integer array of decl id's that we expect the role to have in the scope table 3213cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * len number of elements in decls 3313cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * 3413cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * This is a utility function to test for the symbol's presence in the global symbol table, 3513cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * the scope table, and that the decl blocks we think this symbol is in are correct 3613cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle */ 3713cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern void test_sym_presence(policydb_t * p, char *id, int sym_type, unsigned int scope_type, unsigned int *decls, unsigned int len); 3813cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 3913cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle/* Test the indexes in the policydb to ensure their correctness. These include 4013cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * the sym_val_to_name[], class_val_to_struct, role_val_to_struct, type_val_to_struct, 4113cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * user_val_to_struct, and bool_val_to_struct indexes. 4213cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle */ 4313cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern void test_policydb_indexes(policydb_t * p); 4413cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 4513cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle/* Test alias datum to ensure that it is as expected 4613cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * 4713cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * id = the key for the alias 4813cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * primary_id = the key for its primary 4913cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * mode: 0 = test the datum according to the flavor value in the call 5013cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 1 = automatically detect the flavor value and test the datum accordingly 5113cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * flavor = flavor value if in mode 0 5213cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle */ 5313cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern void test_alias_datum(policydb_t * p, char *id, char *primary_id, char mode, unsigned int flavor); 5413cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 5513cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle/* p the policy being inspected 5613cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * id string role identifier 5713cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * decl the decl block which we are looking in for the role datum 5813cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * types the array of string types which we expect the role has in its type ebitmap 5913cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * len number of elements in types 6013cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * flags the expected flags in the role typeset (eg., * or ~) 6113cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * 6213cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * This is a utility function to test whether the type set associated with a role in a specific 6313cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * avrule decl block matches our expectations 6413cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle */ 6513cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern role_datum_t *test_role_type_set(policydb_t * p, char *id, avrule_decl_t * decl, char **types, unsigned int len, unsigned int flags); 6613cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 6713cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle/* p the policy being inspected 6813cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * id string attribute identifier 6913cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * decl the decl block which we are looking in for the attribute datum 7013cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * types the array of string types which we expect the attribute has in its type ebitmap 7113cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * len number of elements in types 7213cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * 7313cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * This is a utility function to test whether the type set associated with an attribute in a specific 7413cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle * avrule decl block matches our expectations 7513cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle */ 7613cd4c8960688af11ad23b4c946149015c80d54Joshua Brindleextern void test_attr_types(policydb_t * p, char *id, avrule_decl_t * decl, char **types, int len); 7713cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle 7813cd4c8960688af11ad23b4c946149015c80d54Joshua Brindle#endif 79