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