1 /* 2 * Author: Karl MacMillan <kmacmillan@tresys.com> 3 * 4 * Copyright (C) 2006 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 #include "test-cond.h" 22 #include "parse_util.h" 23 #include "helpers.h" 24 25 #include <sepol/policydb/policydb.h> 26 #include <sepol/policydb/link.h> 27 #include <sepol/policydb/expand.h> 28 #include <sepol/policydb/conditional.h> 29 30 static policydb_t basemod; 31 static policydb_t base_expanded; 32 33 int cond_test_init(void) 34 { 35 if (policydb_init(&base_expanded)) { 36 fprintf(stderr, "out of memory!\n"); 37 policydb_destroy(&basemod); 38 return -1; 39 } 40 41 if (test_load_policy(&basemod, POLICY_BASE, 1, "test-cond", "refpolicy-base.conf")) 42 goto cleanup; 43 44 if (link_modules(NULL, &basemod, NULL, 0, 0)) { 45 fprintf(stderr, "link modules failed\n"); 46 goto cleanup; 47 } 48 49 if (expand_module(NULL, &basemod, &base_expanded, 0, 1)) { 50 fprintf(stderr, "expand module failed\n"); 51 goto cleanup; 52 } 53 54 return 0; 55 56 cleanup: 57 policydb_destroy(&basemod); 58 policydb_destroy(&base_expanded); 59 return -1; 60 } 61 62 int cond_test_cleanup(void) 63 { 64 policydb_destroy(&basemod); 65 policydb_destroy(&base_expanded); 66 67 return 0; 68 } 69 70 static void test_cond_expr_equal(void) 71 { 72 cond_node_t *a, *b; 73 74 a = base_expanded.cond_list; 75 while (a) { 76 b = base_expanded.cond_list; 77 while (b) { 78 if (a == b) { 79 CU_ASSERT(cond_expr_equal(a, b)); 80 } else { 81 CU_ASSERT(cond_expr_equal(a, b) == 0); 82 } 83 b = b->next; 84 } 85 a = a->next; 86 } 87 } 88 89 int cond_add_tests(CU_pSuite suite) 90 { 91 if (NULL == CU_add_test(suite, "cond_expr_equal", test_cond_expr_equal)) { 92 return CU_get_error(); 93 } 94 return 0; 95 } 96