Commit bcbf5dce authored by Juan Lang's avatar Juan Lang Committed by Alexandre Julliard

crypt32: Test and correct finding a subject certificate.

parent d89528b0
...@@ -906,9 +906,15 @@ static BOOL compare_cert_by_subject_cert(PCCERT_CONTEXT pCertContext, ...@@ -906,9 +906,15 @@ static BOOL compare_cert_by_subject_cert(PCCERT_CONTEXT pCertContext,
DWORD dwType, DWORD dwFlags, const void *pvPara) DWORD dwType, DWORD dwFlags, const void *pvPara)
{ {
CERT_INFO *pCertInfo = (CERT_INFO *)pvPara; CERT_INFO *pCertInfo = (CERT_INFO *)pvPara;
BOOL ret;
return CertCompareCertificateName(pCertContext->dwCertEncodingType, ret = CertCompareCertificateName(pCertContext->dwCertEncodingType,
&pCertInfo->Issuer, &pCertContext->pCertInfo->Subject); &pCertInfo->Issuer, &pCertContext->pCertInfo->Subject);
if (ret && pCertInfo->SerialNumber.cbData)
ret = CertCompareIntegerBlob(&pCertContext->pCertInfo->SerialNumber,
&pCertInfo->SerialNumber);
TRACE("returning %d\n", ret);
return ret;
} }
static BOOL compare_cert_by_cert_id(PCCERT_CONTEXT pCertContext, DWORD dwType, static BOOL compare_cert_by_cert_id(PCCERT_CONTEXT pCertContext, DWORD dwType,
......
...@@ -604,6 +604,7 @@ static void testFindCert(void) ...@@ -604,6 +604,7 @@ static void testFindCert(void)
BOOL ret; BOOL ret;
CERT_INFO certInfo = { 0 }; CERT_INFO certInfo = { 0 };
CRYPT_HASH_BLOB blob; CRYPT_HASH_BLOB blob;
BYTE otherSerialNumber[] = { 2 };
store = CertOpenStore(CERT_STORE_PROV_MEMORY, 0, 0, store = CertOpenStore(CERT_STORE_PROV_MEMORY, 0, 0,
CERT_STORE_CREATE_NEW_FLAG, NULL); CERT_STORE_CREATE_NEW_FLAG, NULL);
...@@ -685,6 +686,27 @@ static void testFindCert(void) ...@@ -685,6 +686,27 @@ static void testFindCert(void)
CERT_FIND_SUBJECT_CERT, &certInfo.Subject, context); CERT_FIND_SUBJECT_CERT, &certInfo.Subject, context);
ok(context == NULL, "Expected one cert only\n"); ok(context == NULL, "Expected one cert only\n");
} }
/* The above search matched even though no serial number is set. A
* non-matching serial number will not match.
*/
certInfo.SerialNumber.pbData = otherSerialNumber;
certInfo.SerialNumber.cbData = sizeof(otherSerialNumber);
context = CertFindCertificateInStore(store, X509_ASN_ENCODING, 0,
CERT_FIND_SUBJECT_CERT, &certInfo, NULL);
ok(context == NULL, "Expected no match\n");
/* A matching serial number will match. */
certInfo.SerialNumber.pbData = serialNum;
certInfo.SerialNumber.cbData = sizeof(serialNum);
context = CertFindCertificateInStore(store, X509_ASN_ENCODING, 0,
CERT_FIND_SUBJECT_CERT, &certInfo, NULL);
ok(context != NULL, "CertFindCertificateInStore failed: %08x\n",
GetLastError());
if (context)
{
context = CertFindCertificateInStore(store, X509_ASN_ENCODING, 0,
CERT_FIND_SUBJECT_CERT, &certInfo.Subject, context);
ok(context == NULL, "Expected one cert only\n");
}
/* The nice thing about hashes, they're unique */ /* The nice thing about hashes, they're unique */
blob.pbData = bigCertHash; blob.pbData = bigCertHash;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment