1 /* 2 * Author: Mary Garvin <mgarvin@tresys.com> 3 * 4 * Copyright (C) 2007-2008 Tresys Technology, LLC 5 * 6 * This library is free software; you can redistribute it and/or 7 * modify it under the terms of the GNU Lesser General Public 8 * License as published by the Free Software Foundation; either 9 * version 2.1 of the License, or (at your option) any later version. 10 * 11 * This library is distributed in the hope that it will be useful, 12 * but WITHOUT ANY WARRANTY; without even the implied warranty of 13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 14 * Lesser General Public License for more details. 15 * 16 * You should have received a copy of the GNU Lesser General Public 17 * License along with this library; if not, write to the Free Software 18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA 19 */ 20 21 #ifndef __TEST_DOWNGRADE_H__ 22 #define __TEST_DOWNGRADE_H__ 23 24 #include <CUnit/Basic.h> 25 #include <sepol/policydb/policydb.h> 26 27 /* 28 * Function Name: downgrade_test_init 29 * 30 * Input: None 31 * 32 * Output: None 33 * 34 * Description: Initialize the policydb (policy data base structure) 35 */ 36 int downgrade_test_init(void); 37 38 /* 39 * Function Name: downgrade_test_cleanup 40 * 41 * Input: None 42 * 43 * Output: None 44 * 45 * Description: Destroys policydb structure 46 */ 47 int downgrade_test_cleanup(void); 48 49 /* 50 * Function Name: downgrade_add_tests 51 * 52 * Input: CU_pSuite 53 * 54 * Output: Returns 0 upon success. Upon failure, a CUnit testing error 55 * value is returned 56 * 57 * Description: Add the given downgrade tests to the downgrade suite. 58 */ 59 int downgrade_add_tests(CU_pSuite suite); 60 61 /* 62 * Function Name: test_downgrade_possible 63 * 64 * Input: None 65 * 66 * Output: None 67 * 68 * Description: Tests the backward compatability of MLS and Non-MLS binary 69 * policy versions. 70 */ 71 void test_downgrade(void); 72 73 /* 74 * Function Name: do_downgrade_test 75 * 76 * Input: int that represents a 0 for Non-MLS policy and a 77 * 1 for MLS policy downgrade testing 78 * 79 * Output: (int) 0 on success, negative number upon failure 80 * 81 * Description: This function handles the downgrade testing. A binary policy 82 * is read into the policydb structure, the policy version is 83 * decreased by a specific amount, written back out and then read 84 * back in again. The process is iterative until the minimum 85 * policy version is reached. 86 */ 87 int do_downgrade_test(int mls); 88 89 /* 90 * Function Name: read_binary_policy 91 * 92 * Input: char * which is the path to the file containing the binary policy 93 * 94 * Output: Returns 0 upon success. Upon failure, -1 is returned. 95 * Possible failures are, filename with given path does not exist, 96 * a failure to open the file, or a failure from prolicydb_read 97 * function call. 98 * 99 * Description: Get a filename, open file and read in the binary policy 100 * into the policydb structure. 101 */ 102 int read_binary_policy(const char *path, policydb_t *); 103 104 /* 105 * Function Name: write_binary_policy 106 * 107 * Input: char * which is the path to the file containing the binary policy 108 * 109 * Output: Returns 0 upon success. Upon failure, -1 is returned. 110 * Possible failures are, filename with given path does not exist, 111 * a failure to open the file, or a failure from prolicydb_read 112 * function call. 113 * 114 * Description: Get a filename, open file and read in the binary policy 115 * into the policydb structure. 116 */ 117 int write_binary_policy(const char *path, policydb_t *); 118 119 #endif 120