|
Packit |
40b132 |
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
Packit |
40b132 |
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
Packit |
40b132 |
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
Packit |
40b132 |
/*
|
|
Packit |
40b132 |
* test_nameconstraints.c
|
|
Packit |
40b132 |
*
|
|
Packit |
40b132 |
* Test CERT Name Constraints Type
|
|
Packit |
40b132 |
*
|
|
Packit |
40b132 |
*/
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
#include "testutil.h"
|
|
Packit |
40b132 |
#include "testutil_nss.h"
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
static void *plContext = NULL;
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
static char *catDirName(char *platform, char *dir, void *plContext)
|
|
Packit |
40b132 |
{
|
|
Packit |
40b132 |
char *pathName = NULL;
|
|
Packit |
40b132 |
PKIX_UInt32 dirLen;
|
|
Packit |
40b132 |
PKIX_UInt32 platformLen;
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
PKIX_TEST_STD_VARS();
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
dirLen = PL_strlen(dir);
|
|
Packit |
40b132 |
platformLen = PL_strlen(platform);
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
PKIX_TEST_EXPECT_NO_ERROR(PKIX_PL_Malloc
|
|
Packit |
40b132 |
(platformLen + dirLen + 2, (void **)&pathName, plContext));
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
PL_strcpy(pathName, platform);
|
|
Packit |
40b132 |
PL_strcat(pathName, "/");
|
|
Packit |
40b132 |
PL_strcat(pathName, dir);
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
cleanup:
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
PKIX_TEST_RETURN();
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
return (pathName);
|
|
Packit |
40b132 |
}
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
static void
|
|
Packit |
40b132 |
testNameConstraints(char *dataDir)
|
|
Packit |
40b132 |
{
|
|
Packit |
40b132 |
char *goodPname = "nameConstraintsDN5CACert.crt";
|
|
Packit |
40b132 |
PKIX_PL_Cert *goodCert = NULL;
|
|
Packit |
40b132 |
PKIX_PL_CertNameConstraints *goodNC = NULL;
|
|
Packit |
40b132 |
char *expectedAscii =
|
|
Packit |
40b132 |
"[\n"
|
|
Packit |
40b132 |
"\t\tPermitted Name: (OU=permittedSubtree1,"
|
|
Packit |
40b132 |
"O=Test Certificates,C=US)\n"
|
|
Packit |
40b132 |
"\t\tExcluded Name: (OU=excludedSubtree1,"
|
|
Packit |
40b132 |
"OU=permittedSubtree1,O=Test Certificates,C=US)\n"
|
|
Packit |
40b132 |
"\t]\n";
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
PKIX_TEST_STD_VARS();
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
subTest("PKIX_PL_CertNameConstraints");
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
goodCert = createCert(dataDir, goodPname, plContext);
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
subTest("PKIX_PL_Cert_GetNameConstraints");
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
PKIX_TEST_EXPECT_NO_ERROR(PKIX_PL_Cert_GetNameConstraints
|
|
Packit |
40b132 |
(goodCert, &goodNC, plContext));
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
testToStringHelper
|
|
Packit |
40b132 |
((PKIX_PL_Object *)goodNC, expectedAscii, plContext);
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
cleanup:
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
PKIX_TEST_DECREF_AC(goodNC);
|
|
Packit |
40b132 |
PKIX_TEST_DECREF_AC(goodCert);
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
PKIX_TEST_RETURN();
|
|
Packit |
40b132 |
}
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
static
|
|
Packit |
40b132 |
void printUsage(void) {
|
|
Packit |
40b132 |
(void) printf
|
|
Packit |
40b132 |
("\nUSAGE:\ttest_nameconstraints <test-purpose>"
|
|
Packit |
40b132 |
" <data-dir> <platform-prefix>\n\n");
|
|
Packit |
40b132 |
}
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
/* Functional tests for CRL public functions */
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
int test_nameconstraints(int argc, char *argv[]) {
|
|
Packit |
40b132 |
PKIX_UInt32 actualMinorVersion;
|
|
Packit |
40b132 |
PKIX_UInt32 j = 0;
|
|
Packit |
40b132 |
char *platformDir = NULL;
|
|
Packit |
40b132 |
char *dataDir = NULL;
|
|
Packit |
40b132 |
char *combinedDir = NULL;
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
/* Note XXX serialnumber and reasoncode need debug */
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
PKIX_TEST_STD_VARS();
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
startTests("NameConstraints");
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
PKIX_TEST_EXPECT_NO_ERROR(
|
|
Packit |
40b132 |
PKIX_PL_NssContext_Create(0, PKIX_FALSE, NULL, &plContext));
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
if (argc < 3 + j) {
|
|
Packit |
40b132 |
printUsage();
|
|
Packit |
40b132 |
return (0);
|
|
Packit |
40b132 |
}
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
dataDir = argv[2 + j];
|
|
Packit |
40b132 |
platformDir = argv[3 + j];
|
|
Packit |
40b132 |
combinedDir = catDirName(platformDir, dataDir, plContext);
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
testNameConstraints(combinedDir);
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
cleanup:
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
pkixTestErrorResult = PKIX_PL_Free(combinedDir, plContext);
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
PKIX_Shutdown(plContext);
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
PKIX_TEST_RETURN();
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
endTests("NameConstraints");
|
|
Packit |
40b132 |
|
|
Packit |
40b132 |
return (0);
|
|
Packit |
40b132 |
}
|