2 * Copyright 2008 James Hawkins
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2.1 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
22 #include "wine/test.h"
24 static HMODULE hmscoree;
26 static HRESULT (WINAPI *pGetCachePath)(ASM_CACHE_FLAGS dwCacheFlags,
27 LPWSTR pwzCachePath, PDWORD pcchPath);
28 static HRESULT (WINAPI *pLoadLibraryShim)(LPCWSTR szDllName, LPCWSTR szVersion,
29 LPVOID pvReserved, HMODULE *phModDll);
30 static HRESULT (WINAPI *pGetCORVersion)(LPWSTR pbuffer, DWORD cchBuffer,
33 static CHAR string1[MAX_PATH], string2[MAX_PATH];
35 #define ok_w2(format, szString1, szString2) \
37 WideCharToMultiByte(CP_ACP, 0, szString1, -1, string1, MAX_PATH, NULL, NULL); \
38 WideCharToMultiByte(CP_ACP, 0, szString2, -1, string2, MAX_PATH, NULL, NULL); \
39 ok(!lstrcmpA(string1, string2), format, string1, string2)
41 static BOOL init_functionpointers(void)
46 static const WCHAR szFusion[] = {'f','u','s','i','o','n','.','d','l','l',0};
48 hmscoree = LoadLibraryA("mscoree.dll");
51 skip("mscoree.dll not available\n");
55 pLoadLibraryShim = (void *)GetProcAddress(hmscoree, "LoadLibraryShim");
56 if (!pLoadLibraryShim)
58 skip("LoadLibraryShim not available\n");
59 FreeLibrary(hmscoree);
63 pGetCORVersion = (void *)GetProcAddress(hmscoree, "GetCORVersion");
65 hr = pLoadLibraryShim(szFusion, NULL, NULL, &hfusion);
68 skip("fusion.dll not available\n");
69 FreeLibrary(hmscoree);
73 pGetCachePath = (void *)GetProcAddress(hfusion, "GetCachePath");
77 static void test_GetCachePath(void)
79 CHAR windirA[MAX_PATH];
80 WCHAR windir[MAX_PATH];
81 WCHAR cachepath[MAX_PATH];
82 WCHAR version[MAX_PATH];
87 static const WCHAR backslash[] = {'\\',0};
88 static const WCHAR nochange[] = {'n','o','c','h','a','n','g','e',0};
89 static const WCHAR assembly[] = {'a','s','s','e','m','b','l','y',0};
90 static const WCHAR gac[] = {'G','A','C',0};
94 skip("GetCachePath not implemented\n");
98 GetWindowsDirectoryA(windirA, MAX_PATH);
99 MultiByteToWideChar(CP_ACP, 0, windirA, -1, windir, MAX_PATH);
100 lstrcpyW(cachepath, windir);
101 lstrcatW(cachepath, backslash);
102 lstrcatW(cachepath, assembly);
103 lstrcatW(cachepath, backslash);
104 lstrcatW(cachepath, gac);
106 /* NULL pwzCachePath, pcchPath is 0 */
108 hr = pGetCachePath(ASM_CACHE_GAC, NULL, &size);
109 ok(hr == HRESULT_FROM_WIN32(ERROR_INSUFFICIENT_BUFFER),
110 "Expected HRESULT_FROM_WIN32(ERROR_INSUFFICIENT_BUFFER), got %08x\n", hr);
111 ok(size == lstrlenW(cachepath) + 1,
112 "Expected %d, got %d\n", lstrlenW(cachepath) + 1, size);
114 /* NULL pwszCachePath, pcchPath is MAX_PATH */
116 hr = pGetCachePath(ASM_CACHE_GAC, NULL, &size);
117 ok(hr == HRESULT_FROM_WIN32(ERROR_INSUFFICIENT_BUFFER),
118 "Expected HRESULT_FROM_WIN32(ERROR_INSUFFICIENT_BUFFER), got %08x\n", hr);
119 ok(size == lstrlenW(cachepath) + 1,
120 "Expected %d, got %d\n", lstrlenW(cachepath) + 1, size);
122 /* both pwszCachePath and pcchPath NULL */
123 hr = pGetCachePath(ASM_CACHE_GAC, NULL, NULL);
124 ok(hr == E_INVALIDARG, "Expected E_INVALIDARG, got %08x\n", hr);
127 lstrcpyW(path, nochange);
128 hr = pGetCachePath(ASM_CACHE_GAC, path, NULL);
129 ok(hr == E_INVALIDARG, "Expected E_INVALIDARG, got %08x\n", hr);
130 ok_w2("Expected \"%s\", got \"%s\"\n", nochange, path);
132 /* get the cache path */
133 lstrcpyW(path, nochange);
135 hr = pGetCachePath(ASM_CACHE_GAC, path, &size);
136 ok(hr == S_OK, "Expected S_OK, got %08x\n", hr);
137 ok_w2("Expected \"%s\", got \"%s\"\n", cachepath, path);
139 /* pcchPath has no room for NULL terminator */
140 lstrcpyW(path, nochange);
141 size = lstrlenW(cachepath);
142 hr = pGetCachePath(ASM_CACHE_GAC, path, &size);
143 ok(hr == HRESULT_FROM_WIN32(ERROR_INSUFFICIENT_BUFFER),
144 "Expected HRESULT_FROM_WIN32(ERROR_INSUFFICIENT_BUFFER), got %08x\n", hr);
145 ok_w2("Expected \"%s\", got \"%s\"\n", nochange, path);
149 CHAR versionA[MAX_PATH];
150 CHAR cachepathA[MAX_PATH];
152 static const CHAR nativeimgA[] = "NativeImages_";
153 static const CHAR zapfmtA[] = "%s\\%s\\%s%s_32";
155 pGetCORVersion(version, MAX_PATH, &size);
156 WideCharToMultiByte(CP_ACP, 0, version, -1, versionA, MAX_PATH, 0, 0);
158 wsprintfA(cachepathA, zapfmtA, windirA, "assembly", nativeimgA, versionA);
159 MultiByteToWideChar(CP_ACP, 0, cachepathA, -1, cachepath, MAX_PATH);
162 lstrcpyW(path, nochange);
164 hr = pGetCachePath(ASM_CACHE_ZAP, path, &size);
165 ok(hr == S_OK, "Expected S_OK, got %08x\n", hr);
166 ok_w2("Expected \"%s\", got \"%s\"\n", cachepath, path);
169 lstrcpyW(cachepath, windir);
170 lstrcatW(cachepath, backslash);
171 lstrcatW(cachepath, assembly);
174 lstrcpyW(path, nochange);
176 hr = pGetCachePath(ASM_CACHE_ROOT, path, &size);
177 ok(hr == S_OK, "Expected S_OK, got %08x\n", hr);
178 ok_w2("Expected \"%s\", got \"%s\"\n", cachepath, path);
180 /* two flags at once */
181 lstrcpyW(path, nochange);
183 hr = pGetCachePath(ASM_CACHE_GAC | ASM_CACHE_ROOT, path, &size);
184 ok(hr == E_INVALIDARG, "Expected E_INVALIDARG, got %08x\n", hr);
185 ok_w2("Expected \"%s\", got \"%s\"\n", nochange, path);
190 if (!init_functionpointers())
195 FreeLibrary(hmscoree);