Juan Lang : wintrust: Add tests for WVTAsn1CatMemberInfoEncode.
Alexandre Julliard
julliard at winehq.org
Sat Oct 18 13:38:42 CDT 2008
Module: wine
Branch: master
Commit: 52751981ad8b3befa6b4b5d2f443583f43e8f803
URL: http://source.winehq.org/git/wine.git/?a=commit;h=52751981ad8b3befa6b4b5d2f443583f43e8f803
Author: Juan Lang <juan.lang at gmail.com>
Date: Fri Oct 17 14:06:26 2008 -0700
wintrust: Add tests for WVTAsn1CatMemberInfoEncode.
---
dlls/wintrust/tests/asn.c | 71 +++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 71 insertions(+), 0 deletions(-)
diff --git a/dlls/wintrust/tests/asn.c b/dlls/wintrust/tests/asn.c
index a3557e7..28cc6f6 100644
--- a/dlls/wintrust/tests/asn.c
+++ b/dlls/wintrust/tests/asn.c
@@ -464,6 +464,76 @@ static void test_decodeSPCPEImage(void)
}
}
+static WCHAR foo[] = { 'f','o','o',0 };
+static WCHAR guidStr[] = { '{','8','b','c','9','6','b','0','0','-',
+ '8','d','a','1','-','1','1','c','f','-','8','7','3','6','-','0','0',
+ 'a','a','0','0','a','4','8','5','e','b','}',0 };
+
+static const BYTE emptyCatMemberInfo[] = { 0x30,0x05,0x1e,0x00,0x02,0x01,0x00 };
+static const BYTE catMemberInfoWithSillyGuid[] = {
+0x30,0x0b,0x1e,0x06,0x00,0x66,0x00,0x6f,0x00,0x6f,0x02,0x01,0x00 };
+static const BYTE catMemberInfoWithGuid[] = {
+0x30,0x51,0x1e,0x4c,0x00,0x7b,0x00,0x38,0x00,0x62,0x00,0x63,0x00,0x39,0x00,0x36,
+0x00,0x62,0x00,0x30,0x00,0x30,0x00,0x2d,0x00,0x38,0x00,0x64,0x00,0x61,0x00,0x31,
+0x00,0x2d,0x00,0x31,0x00,0x31,0x00,0x63,0x00,0x66,0x00,0x2d,0x00,0x38,0x00,0x37,
+0x00,0x33,0x00,0x36,0x00,0x2d,0x00,0x30,0x00,0x30,0x00,0x61,0x00,0x61,0x00,0x30,
+0x00,0x30,0x00,0x61,0x00,0x34,0x00,0x38,0x00,0x35,0x00,0x65,0x00,0x62,0x00,0x7d,
+0x02,0x01,0x00 };
+
+static void test_encodeCatMemberInfo(void)
+{
+ CAT_MEMBERINFO info;
+ BOOL ret;
+ DWORD size = 0;
+ LPBYTE buf;
+
+ memset(&info, 0, sizeof(info));
+
+ if (!pCryptEncodeObjectEx)
+ {
+ skip("CryptEncodeObjectEx() is not available. Skipping the encodeCatMemberInfo tests\n");
+ return;
+ }
+
+ ret = pCryptEncodeObjectEx(X509_ASN_ENCODING, CAT_MEMBERINFO_STRUCT,
+ &info, CRYPT_ENCODE_ALLOC_FLAG, NULL, &buf, &size);
+ todo_wine
+ ok(ret, "CryptEncodeObjectEx failed: %08x\n", GetLastError());
+ if (ret)
+ {
+ ok(size == sizeof(emptyCatMemberInfo), "Unexpected size %d\n", size);
+ ok(!memcmp(buf, emptyCatMemberInfo, sizeof(emptyCatMemberInfo)),
+ "Unexpected value\n");
+ LocalFree(buf);
+ }
+ info.pwszSubjGuid = foo;
+ ret = pCryptEncodeObjectEx(X509_ASN_ENCODING, CAT_MEMBERINFO_STRUCT,
+ (LPBYTE)&info, CRYPT_ENCODE_ALLOC_FLAG, NULL, &buf, &size);
+ todo_wine
+ ok(ret, "CryptEncodeObjectEx failed: %08x\n", GetLastError());
+ if (ret)
+ {
+ ok(size == sizeof(catMemberInfoWithSillyGuid), "Unexpected size %d\n",
+ size);
+ ok(!memcmp(buf, catMemberInfoWithSillyGuid,
+ sizeof(catMemberInfoWithSillyGuid)), "Unexpected value\n");
+ LocalFree(buf);
+ }
+ info.pwszSubjGuid = guidStr;
+ ret = pCryptEncodeObjectEx(X509_ASN_ENCODING, CAT_MEMBERINFO_STRUCT,
+ (LPBYTE)&info, CRYPT_ENCODE_ALLOC_FLAG, NULL, &buf, &size);
+ todo_wine
+ ok(ret, "CryptEncodeObjectEx failed: %08x\n", GetLastError());
+ if (ret)
+ {
+ ok(size == sizeof(catMemberInfoWithGuid), "Unexpected size %d\n",
+ size);
+ ok(!memcmp(buf, catMemberInfoWithGuid, sizeof(catMemberInfoWithGuid)),
+ "Unexpected value\n");
+ LocalFree(buf);
+ }
+}
+
START_TEST(asn)
{
HMODULE hCrypt32 = LoadLibraryA("crypt32.dll");
@@ -474,6 +544,7 @@ START_TEST(asn)
test_decodeSPCLink();
test_encodeSPCPEImage();
test_decodeSPCPEImage();
+ test_encodeCatMemberInfo();
FreeLibrary(hCrypt32);
}
More information about the wine-cvs
mailing list