1 /* Unit test suite for wintrust crypt functions
3 * Copyright 2007 Paul Vriens
5 * This library is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Lesser General Public
7 * License as published by the Free Software Foundation; either
8 * version 2.1 of the License, or (at your option) any later version.
10 * This library is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * Lesser General Public License for more details.
15 * You should have received a copy of the GNU Lesser General Public
16 * License along with this library; if not, write to the Free Software
17 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
27 #include "wine/test.h"
29 static char selfname[MAX_PATH];
31 static CHAR CURR_DIR[MAX_PATH];
33 static HMODULE hWintrust = 0;
35 static BOOL (WINAPI * pCryptCATAdminAcquireContext)(HCATADMIN*, const GUID*, DWORD);
36 static BOOL (WINAPI * pCryptCATAdminReleaseContext)(HCATADMIN, DWORD);
37 static BOOL (WINAPI * pCryptCATAdminCalcHashFromFileHandle)(HANDLE hFile, DWORD*, BYTE*, DWORD);
39 #define WINTRUST_GET_PROC(func) \
40 p ## func = (void*)GetProcAddress(hWintrust, #func); \
42 trace("GetProcAddress(%s) failed\n", #func); \
45 static BOOL InitFunctionPtrs(void)
47 hWintrust = LoadLibraryA("wintrust.dll");
51 skip("Could not load wintrust.dll\n");
55 WINTRUST_GET_PROC(CryptCATAdminAcquireContext)
56 WINTRUST_GET_PROC(CryptCATAdminReleaseContext)
57 WINTRUST_GET_PROC(CryptCATAdminCalcHashFromFileHandle)
62 static void test_context(void)
66 static GUID dummy = { 0xdeadbeef, 0xdead, 0xbeef, { 0xde,0xad,0xbe,0xef,0xde,0xad,0xbe,0xef }};
67 static GUID unknown = { 0xC689AABA, 0x8E78, 0x11D0, { 0x8C,0x47,0x00,0xC0,0x4F,0xC2,0x95,0xEE }}; /* WINTRUST.DLL */
69 if (!pCryptCATAdminAcquireContext || !pCryptCATAdminReleaseContext)
71 skip("CryptCATAdminAcquireContext and/or CryptCATAdminReleaseContext are not available\n");
76 SetLastError(0xdeadbeef);
77 ret = pCryptCATAdminAcquireContext(NULL, NULL, 0);
80 ok(!ret, "Expected failure\n");
81 ok(GetLastError() == ERROR_INVALID_PARAMETER,
82 "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
86 SetLastError(0xdeadbeef);
87 ret = pCryptCATAdminAcquireContext(&hca, NULL, 0);
88 ok(ret, "Expected success\n");
89 ok(GetLastError() == ERROR_SUCCESS ||
90 GetLastError() == 0xdeadbeef /* Vista */,
91 "Expected ERROR_SUCCESS or 0xdeadbeef, got %d\n", GetLastError());
92 ok(hca != NULL, "Expected a context handle, got NULL\n");
95 SetLastError(0xdeadbeef);
96 ret = pCryptCATAdminReleaseContext(NULL, 0);
99 ok(!ret, "Expected failure\n");
100 ok(GetLastError() == ERROR_INVALID_PARAMETER,
101 "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
105 SetLastError(0xdeadbeef);
106 ret = pCryptCATAdminReleaseContext(hca, 0);
107 ok(ret, "Expected success\n");
108 ok(GetLastError() == 0xdeadbeef,
109 "Expected no change in last error, got %d\n", GetLastError());
111 /* Try to release a second time */
112 SetLastError(0xdeadbeef);
113 ret = pCryptCATAdminReleaseContext(hca, 0);
116 ok(!ret, "Expected failure\n");
117 ok(GetLastError() == ERROR_INVALID_PARAMETER,
118 "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
121 /* NULL context handle and dummy GUID */
122 SetLastError(0xdeadbeef);
123 ret = pCryptCATAdminAcquireContext(NULL, &dummy, 0);
126 ok(!ret, "Expected failure\n");
127 ok(GetLastError() == ERROR_INVALID_PARAMETER,
128 "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
131 /* Correct context handle and dummy GUID */
132 SetLastError(0xdeadbeef);
133 ret = pCryptCATAdminAcquireContext(&hca, &dummy, 0);
134 ok(ret, "Expected success\n");
135 ok(GetLastError() == ERROR_SUCCESS ||
136 GetLastError() == 0xdeadbeef /* Vista */,
137 "Expected ERROR_SUCCESS or 0xdeadbeef, got %d\n", GetLastError());
138 ok(hca != NULL, "Expected a context handle, got NULL\n");
140 ret = pCryptCATAdminReleaseContext(hca, 0);
141 ok(ret, "Expected success\n");
143 /* Correct context handle and GUID */
144 SetLastError(0xdeadbeef);
145 ret = pCryptCATAdminAcquireContext(&hca, &unknown, 0);
146 ok(ret, "Expected success\n");
147 ok(GetLastError() == ERROR_SUCCESS ||
148 GetLastError() == 0xdeadbeef /* Vista */,
149 "Expected ERROR_SUCCESS or 0xdeadbeef, got %d\n", GetLastError());
150 ok(hca != NULL, "Expected a context handle, got NULL\n");
152 ret = pCryptCATAdminReleaseContext(hca, 0);
153 ok(ret, "Expected success\n");
155 /* Flags not equal to 0 */
156 SetLastError(0xdeadbeef);
157 ret = pCryptCATAdminAcquireContext(&hca, &unknown, 1);
158 ok(ret, "Expected success\n");
159 ok(GetLastError() == ERROR_SUCCESS ||
160 GetLastError() == 0xdeadbeef /* Vista */,
161 "Expected ERROR_SUCCESS or 0xdeadbeef, got %d\n", GetLastError());
162 ok(hca != NULL, "Expected a context handle, got NULL\n");
164 ret = pCryptCATAdminReleaseContext(hca, 0);
165 ok(ret, "Expected success\n");
168 /* TODO: Check whether SHA-1 is the algorithm that's always used */
169 static void test_calchash(void)
175 BYTE expectedhash[20] = {0x3a,0xa1,0x19,0x08,0xec,0xa6,0x0d,0x2e,0x7e,0xcc,0x7a,0xca,0xf5,0xb8,0x2e,0x62,0x6a,0xda,0xf0,0x19};
179 if (!pCryptCATAdminCalcHashFromFileHandle)
181 skip("CryptCATAdminCalcHashFromFileHandle is not available\n");
186 SetLastError(0xdeadbeef);
187 ret = pCryptCATAdminCalcHashFromFileHandle(NULL, NULL, NULL, 0);
190 ok(!ret, "Expected failure\n");
191 ok(GetLastError() == ERROR_INVALID_PARAMETER,
192 "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
195 /* NULL filehandle, rest is legal */
196 SetLastError(0xdeadbeef);
197 ret = pCryptCATAdminCalcHashFromFileHandle(NULL, &hashsize, NULL, 0);
200 ok(!ret, "Expected failure\n");
201 ok(GetLastError() == ERROR_INVALID_PARAMETER,
202 "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
205 /* Correct filehandle, rest is NULL */
206 file = CreateFileA(selfname, GENERIC_READ, 0, NULL, OPEN_EXISTING, 0, NULL);
207 SetLastError(0xdeadbeef);
208 ret = pCryptCATAdminCalcHashFromFileHandle(file, NULL, NULL, 0);
211 ok(!ret, "Expected failure\n");
212 ok(GetLastError() == ERROR_INVALID_PARAMETER,
213 "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
217 /* All OK, but dwFlags set to 1 */
218 file = CreateFileA(selfname, GENERIC_READ, 0, NULL, OPEN_EXISTING, 0, NULL);
219 SetLastError(0xdeadbeef);
220 ret = pCryptCATAdminCalcHashFromFileHandle(file, &hashsize, NULL, 1);
223 ok(!ret, "Expected failure\n");
224 ok(GetLastError() == ERROR_INVALID_PARAMETER,
225 "Expected ERROR_INVALID_PARAMETER, got %d\n", GetLastError());
229 /* All OK, requesting the size of the hash */
230 file = CreateFileA(selfname, GENERIC_READ, 0, NULL, OPEN_EXISTING, 0, NULL);
231 SetLastError(0xdeadbeef);
232 ret = pCryptCATAdminCalcHashFromFileHandle(file, &hashsize, NULL, 0);
233 ok(ret, "Expected success\n");
236 ok(hashsize == 20," Expected a hash size of 20, got %d\n", hashsize);
237 ok(GetLastError() == ERROR_INSUFFICIENT_BUFFER,
238 "Expected ERROR_INSUFFICIENT_BUFFER, got %d\n", GetLastError());
242 /* All OK, retrieve the hash
243 * Double the hash buffer to see what happens to the size parameter
245 file = CreateFileA(selfname, GENERIC_READ, 0, NULL, OPEN_EXISTING, 0, NULL);
247 hash = HeapAlloc(GetProcessHeap(), 0, hashsize);
248 SetLastError(0xdeadbeef);
249 ret = pCryptCATAdminCalcHashFromFileHandle(file, &hashsize, hash, 0);
250 ok(ret, "Expected success\n");
253 ok(hashsize == 20," Expected a hash size of 20, got %d\n", hashsize);
254 ok(GetLastError() == ERROR_SUCCESS,
255 "Expected ERROR_SUCCESS, got %d\n", GetLastError());
258 HeapFree(GetProcessHeap(), 0, hash);
260 /* Do the same test with a file created and filled by ourselves (and we thus
261 * have a known hash for).
263 GetTempFileNameA(CURR_DIR, "hsh", 0, temp);
264 file = CreateFileA(temp, GENERIC_WRITE, 0, NULL, OPEN_EXISTING, 0, NULL);
265 WriteFile(file, "Text in this file is needed to create a know hash", 49, &written, NULL);
268 /* All OK, first request the size and then retrieve the hash */
269 file = CreateFileA(temp, GENERIC_READ, 0, NULL, OPEN_EXISTING, 0, NULL);
271 pCryptCATAdminCalcHashFromFileHandle(file, &hashsize, NULL, 0);
272 hash = HeapAlloc(GetProcessHeap(), 0, hashsize);
273 SetLastError(0xdeadbeef);
274 ret = pCryptCATAdminCalcHashFromFileHandle(file, &hashsize, hash, 0);
275 ok(ret, "Expected success\n");
278 ok(GetLastError() == ERROR_SUCCESS,
279 "Expected ERROR_SUCCESS, got %d\n", GetLastError());
280 ok(!memcmp(hash, expectedhash, sizeof(expectedhash)), "Hashes didn't match\n");
284 HeapFree(GetProcessHeap(), 0, hash);
293 if(!InitFunctionPtrs())
296 myARGC = winetest_get_mainargs(&myARGV);
297 strcpy(selfname, myARGV[0]);
299 GetCurrentDirectoryA(MAX_PATH, CURR_DIR);
304 FreeLibrary(hWintrust);