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

rsaenh: Test importing a key with an input buffer that's too small for the key it contains.

parent 54b972e2
...@@ -1516,7 +1516,9 @@ static void test_import_private(void) ...@@ -1516,7 +1516,9 @@ static void test_import_private(void)
0x40, 0x64, 0x28, 0xe8, 0x8a, 0xe7, 0xa4, 0xd4, 0x40, 0x64, 0x28, 0xe8, 0x8a, 0xe7, 0xa4, 0xd4,
0x1c, 0xfd, 0xde, 0x71 0x1c, 0xfd, 0xde, 0x71
}; };
BLOBHEADER *blobHeader = (BLOBHEADER *)abPlainPrivateKey;
RSAPUBKEY *rsaPubKey = (RSAPUBKEY *)(blobHeader+1);
dwLen = (DWORD)sizeof(abPlainPrivateKey); dwLen = (DWORD)sizeof(abPlainPrivateKey);
result = CryptImportKey(hProv, abPlainPrivateKey, dwLen, 0, 0, &hKeyExchangeKey); result = CryptImportKey(hProv, abPlainPrivateKey, dwLen, 0, 0, &hKeyExchangeKey);
if (!result) { if (!result) {
...@@ -1561,6 +1563,22 @@ static void test_import_private(void) ...@@ -1561,6 +1563,22 @@ static void test_import_private(void)
CryptDestroyKey(hSessionKey); CryptDestroyKey(hSessionKey);
CryptDestroyKey(hKeyExchangeKey); CryptDestroyKey(hKeyExchangeKey);
/* Test importing a private key with a buffer that's smaller than the
* actual buffer. The private exponent can be omitted, its length is
* inferred from the passed-in length parameter.
*/
dwLen = sizeof(BLOBHEADER) + sizeof(RSAPUBKEY) +
rsaPubKey->bitlen / 8 + 5 * rsaPubKey->bitlen / 16;
for (; dwLen < sizeof(abPlainPrivateKey); dwLen++)
{
result = CryptImportKey(hProv, abPlainPrivateKey, dwLen, 0, 0, &hKeyExchangeKey);
todo_wine
ok(result, "CryptImportKey failed at size %d: %d (%08x)\n", dwLen,
GetLastError(), GetLastError());
if (result)
CryptDestroyKey(hKeyExchangeKey);
}
} }
static void test_verify_signature(void) { static void test_verify_signature(void) {
......
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