Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040 #include <stdlib.h>
00041 #include <stdio.h>
00042 #include <string.h>
00043 #include <time.h>
00044
00045 #include "CUnit/Basic.h"
00046
00047 #include "ksm/ksm.h"
00048 #include "test_routines.h"
00049
00050
00051
00052
00053
00054
00055
00056
00057
00058 static void TestKsmPolicyRead(void)
00059 {
00060 int status;
00061 KSM_POLICY* policy;
00062 policy = (KSM_POLICY *)malloc(sizeof(KSM_POLICY));
00063 policy->signer = (KSM_SIGNER_POLICY *)malloc(sizeof(KSM_SIGNER_POLICY));
00064 policy->signature = (KSM_SIGNATURE_POLICY *)malloc(sizeof(KSM_SIGNATURE_POLICY));
00065 policy->zone = (KSM_ZONE_POLICY *)malloc(sizeof(KSM_ZONE_POLICY));
00066 policy->parent = (KSM_PARENT_POLICY *)malloc(sizeof(KSM_PARENT_POLICY));
00067 policy->keys = (KSM_COMMON_KEY_POLICY *)malloc(sizeof(KSM_COMMON_KEY_POLICY));
00068 policy->ksk = (KSM_KEY_POLICY *)malloc(sizeof(KSM_KEY_POLICY));
00069 policy->zsk = (KSM_KEY_POLICY *)malloc(sizeof(KSM_KEY_POLICY));
00070 policy->denial = (KSM_DENIAL_POLICY *)malloc(sizeof(KSM_DENIAL_POLICY));
00071 policy->enforcer = (KSM_ENFORCER_POLICY *)malloc(sizeof(KSM_ENFORCER_POLICY));
00072
00073 policy->audit = (char *)calloc(KSM_POLICY_AUDIT_LENGTH, sizeof(char));
00074 policy->description = (char *)calloc(KSM_POLICY_DESC_LENGTH, sizeof(char));
00075
00076 snprintf(policy->name, KSM_NAME_LENGTH, "default");
00077
00078
00079
00080 status = KsmPolicyRead(policy);
00081
00082 CU_ASSERT_EQUAL(status, 0);
00083 CU_ASSERT_EQUAL(policy->id, 2);
00084
00085
00086
00087 status = KsmPolicyRead(policy);
00088
00089 CU_ASSERT_EQUAL(status, 0);
00090
00091 KsmPolicyFree(policy);
00092 }
00093
00094 static void TestKsmPolicyReadId(void)
00095 {
00096 int status;
00097 KSM_POLICY* policy;
00098 policy = (KSM_POLICY *)malloc(sizeof(KSM_POLICY));
00099 policy->signer = (KSM_SIGNER_POLICY *)malloc(sizeof(KSM_SIGNER_POLICY));
00100 policy->signature = (KSM_SIGNATURE_POLICY *)malloc(sizeof(KSM_SIGNATURE_POLICY));
00101 policy->zone = (KSM_ZONE_POLICY *)malloc(sizeof(KSM_ZONE_POLICY));
00102 policy->parent = (KSM_PARENT_POLICY *)malloc(sizeof(KSM_PARENT_POLICY));
00103 policy->keys = (KSM_COMMON_KEY_POLICY *)malloc(sizeof(KSM_COMMON_KEY_POLICY));
00104 policy->ksk = (KSM_KEY_POLICY *)malloc(sizeof(KSM_KEY_POLICY));
00105 policy->zsk = (KSM_KEY_POLICY *)malloc(sizeof(KSM_KEY_POLICY));
00106 policy->denial = (KSM_DENIAL_POLICY *)malloc(sizeof(KSM_DENIAL_POLICY));
00107 policy->enforcer = (KSM_ENFORCER_POLICY *)malloc(sizeof(KSM_ENFORCER_POLICY));
00108
00109 policy->audit = (char *)calloc(KSM_POLICY_AUDIT_LENGTH, sizeof(char));
00110 policy->description = (char *)calloc(KSM_POLICY_DESC_LENGTH, sizeof(char));
00111
00112
00113 policy->id = 2;
00114
00115
00116
00117 status = KsmPolicyReadFromId(policy);
00118
00119 CU_ASSERT_EQUAL(status, 0);
00120
00121
00122
00123 status = KsmPolicyReadFromId(policy);
00124
00125 CU_ASSERT_EQUAL(status, 0);
00126
00127 KsmPolicyFree(policy);
00128 }
00129
00130 static void TestKsmPolicy2(void)
00131 {
00132 DB_RESULT result;
00133 int status = 0;
00134 int i;
00135 KSM_POLICY *policy;
00136 policy = (KSM_POLICY *)malloc(sizeof(KSM_POLICY));
00137 policy->signer = (KSM_SIGNER_POLICY *)malloc(sizeof(KSM_SIGNER_POLICY));
00138 policy->signature = (KSM_SIGNATURE_POLICY *)malloc(sizeof(KSM_SIGNATURE_POLICY));
00139 policy->zone = (KSM_ZONE_POLICY *)malloc(sizeof(KSM_ZONE_POLICY));
00140 policy->parent = (KSM_PARENT_POLICY *)malloc(sizeof(KSM_PARENT_POLICY));
00141 policy->keys = (KSM_COMMON_KEY_POLICY *)malloc(sizeof(KSM_COMMON_KEY_POLICY));
00142 policy->ksk = (KSM_KEY_POLICY *)malloc(sizeof(KSM_KEY_POLICY));
00143 policy->zsk = (KSM_KEY_POLICY *)malloc(sizeof(KSM_KEY_POLICY));
00144 policy->denial = (KSM_DENIAL_POLICY *)malloc(sizeof(KSM_DENIAL_POLICY));
00145 policy->enforcer = (KSM_ENFORCER_POLICY *)malloc(sizeof(KSM_ENFORCER_POLICY));
00146
00147 policy->audit = (char *)calloc(KSM_POLICY_AUDIT_LENGTH, sizeof(char));
00148 policy->description = (char *)calloc(KSM_POLICY_DESC_LENGTH, sizeof(char));
00149
00150
00151 for (i=1; i<5 ; i++) {
00152 printf("Try: %i\n",i);
00153
00154 status = KsmPolicyInit(&result, NULL);
00155 if (status == 0) {
00156
00157 status = KsmPolicy(result, policy);
00158 while (status == 0) {
00159
00160
00161 status = KsmPolicy(result, policy);
00162 }
00163 }
00164
00165 DbFreeResult(result);
00166
00167 }
00168
00169 KsmPolicyFree(policy);
00170 }
00171
00172
00173
00174
00175
00176
00177
00178
00179 static void TestKsmPolicySalt(void)
00180 {
00181 int status;
00182 KSM_POLICY* policy;
00183 policy = (KSM_POLICY *)malloc(sizeof(KSM_POLICY));
00184 policy->signer = (KSM_SIGNER_POLICY *)malloc(sizeof(KSM_SIGNER_POLICY));
00185 policy->signature = (KSM_SIGNATURE_POLICY *)malloc(sizeof(KSM_SIGNATURE_POLICY));
00186 policy->zone = (KSM_ZONE_POLICY *)malloc(sizeof(KSM_ZONE_POLICY));
00187 policy->parent = (KSM_PARENT_POLICY *)malloc(sizeof(KSM_PARENT_POLICY));
00188 policy->keys = (KSM_COMMON_KEY_POLICY *)malloc(sizeof(KSM_COMMON_KEY_POLICY));
00189 policy->ksk = (KSM_KEY_POLICY *)malloc(sizeof(KSM_KEY_POLICY));
00190 policy->zsk = (KSM_KEY_POLICY *)malloc(sizeof(KSM_KEY_POLICY));
00191 policy->denial = (KSM_DENIAL_POLICY *)malloc(sizeof(KSM_DENIAL_POLICY));
00192 policy->enforcer = (KSM_ENFORCER_POLICY *)malloc(sizeof(KSM_ENFORCER_POLICY));
00193
00194 policy->audit = (char *)calloc(KSM_POLICY_AUDIT_LENGTH, sizeof(char));
00195 policy->description = (char *)calloc(KSM_POLICY_DESC_LENGTH, sizeof(char));
00196
00197 snprintf(policy->name, KSM_NAME_LENGTH, "default");
00198
00199 policy->id = 2;
00200 policy->denial->resalt = 0;
00201 policy->denial->saltlength = 30;
00202
00203
00204
00205 status = KsmPolicyUpdateSalt(policy);
00206
00207 CU_ASSERT_EQUAL(status, 0);
00208
00209 KsmPolicyFree(policy);
00210
00211 DbCommit();
00212 }
00213
00214
00215
00216
00217
00218
00219
00220
00221
00222
00223
00224
00225
00226
00227
00228
00229 int TestKsmPolicy(void);
00230 int TestKsmPolicy(void)
00231 {
00232 struct test_testdef tests[] = {
00233 {"KsmPolicy", TestKsmPolicyRead},
00234 {"KsmPolicyFromId", TestKsmPolicyReadId},
00235 {"KsmPolicy2", TestKsmPolicy2},
00236 {"KsmPolicySalt", TestKsmPolicySalt},
00237 {NULL, NULL}
00238 };
00239
00240
00241
00242
00243
00244
00245 return TcuCreateSuite("KsmPolicy", TdbSetup, TdbTeardown, tests);
00246 }