2 * Copyright 2011 Jacek Caban for CodeWeavers
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
28 #include "wine/test.h"
30 #define DEFINE_EXPECT(func) \
31 static BOOL expect_ ## func = FALSE, called_ ## func = FALSE
33 #define SET_EXPECT(func) \
34 expect_ ## func = TRUE
36 #define SET_CALLED(func) \
37 called_ ## func = TRUE
39 #define CHECK_EXPECT2(func) \
41 ok(expect_ ##func, "unexpected call " #func "\n"); \
42 called_ ## func = TRUE; \
45 #define CHECK_EXPECT(func) \
47 CHECK_EXPECT2(func); \
48 expect_ ## func = FALSE; \
51 #define CHECK_CALLED(func) \
53 ok(called_ ## func, "expected " #func "\n"); \
54 expect_ ## func = called_ ## func = FALSE; \
57 DEFINE_EXPECT(reportSuccess);
59 #define DISPID_TESTOBJ_OK 10000
60 #define DISPID_TESTOBJ_TRACE 10001
61 #define DISPID_TESTOBJ_REPORTSUCCESS 10002
63 #define TESTOBJ_CLSID "{178fc166-f585-4e24-9c13-4bb7faf80646}"
65 static const GUID CLSID_TestObj =
66 {0x178fc166,0xf585,0x4e24,{0x9c,0x13,0x4b,0xb7,0xfa,0xf8,0x06,0x46}};
68 static const char *script_name;
70 static int strcmp_wa(LPCWSTR strw, const char *stra)
73 MultiByteToWideChar(CP_ACP, 0, stra, -1, buf, sizeof(buf)/sizeof(WCHAR));
74 return lstrcmpW(strw, buf);
77 static HRESULT WINAPI Dispatch_QueryInterface(IDispatch *iface, REFIID riid, void **ppv)
79 if(IsEqualGUID(riid, &IID_IUnknown) || IsEqualGUID(riid, &IID_IDispatch)) {
88 static ULONG WINAPI Dispatch_AddRef(IDispatch *iface)
93 static ULONG WINAPI Dispatch_Release(IDispatch *iface)
98 static HRESULT WINAPI Dispatch_GetTypeInfoCount(IDispatch *iface, UINT *pctinfo)
100 ok(0, "unexpected call\n");
104 static HRESULT WINAPI Dispatch_GetTypeInfo(IDispatch *iface, UINT iTInfo,
105 LCID lcid, ITypeInfo **ppTInfo)
107 ok(0, "unexpected call\n");
111 static HRESULT WINAPI Dispatch_GetIDsOfNames(IDispatch *iface, REFIID riid,
112 LPOLESTR *rgszNames, UINT cNames, LCID lcid, DISPID *rgDispId)
116 for(i=0; i<cNames; i++) {
117 if(!strcmp_wa(rgszNames[i], "ok")) {
118 rgDispId[i] = DISPID_TESTOBJ_OK;
119 }else if(!strcmp_wa(rgszNames[i], "trace")) {
120 rgDispId[i] = DISPID_TESTOBJ_TRACE;
121 }else if(!strcmp_wa(rgszNames[i], "reportSuccess")) {
122 rgDispId[i] = DISPID_TESTOBJ_REPORTSUCCESS;
124 ok(0, "unexpected name %s\n", wine_dbgstr_w(rgszNames[i]));
125 return DISP_E_UNKNOWNNAME;
132 static HRESULT WINAPI Dispatch_Invoke(IDispatch *iface, DISPID dispIdMember, REFIID riid, LCID lcid,
133 WORD wFlags, DISPPARAMS *pdp, VARIANT *pVarResult, EXCEPINFO *pExcepInfo, UINT *puArgErr)
135 switch(dispIdMember) {
136 case DISPID_TESTOBJ_OK:
137 ok(wFlags == INVOKE_FUNC, "wFlags = %x\n", wFlags);
138 ok(pdp->cArgs == 2, "cArgs = %d\n", pdp->cArgs);
139 ok(!pdp->cNamedArgs, "cNamedArgs = %d\n", pdp->cNamedArgs);
140 ok(V_VT(pdp->rgvarg) == VT_BSTR, "V_VT(psp->rgvargs) = %d\n", V_VT(pdp->rgvarg));
141 ok(V_VT(pdp->rgvarg+1) == VT_BOOL, "V_VT(psp->rgvargs+1) = %d\n", V_VT(pdp->rgvarg));
142 ok(V_BOOL(pdp->rgvarg+1), "%s: %s\n", script_name, wine_dbgstr_w(V_BSTR(pdp->rgvarg)));
144 V_VT(pVarResult) = VT_EMPTY;
146 case DISPID_TESTOBJ_TRACE:
147 ok(wFlags == INVOKE_FUNC, "wFlags = %x\n", wFlags);
148 ok(pdp->cArgs == 1, "cArgs = %d\n", pdp->cArgs);
149 ok(!pdp->cNamedArgs, "cNamedArgs = %d\n", pdp->cNamedArgs);
150 ok(V_VT(pdp->rgvarg) == VT_BSTR, "V_VT(psp->rgvargs) = %d\n", V_VT(pdp->rgvarg));
151 trace("%s: %s\n", script_name, wine_dbgstr_w(V_BSTR(pdp->rgvarg)));
153 V_VT(pVarResult) = VT_EMPTY;
155 case DISPID_TESTOBJ_REPORTSUCCESS:
156 CHECK_EXPECT(reportSuccess);
158 ok(wFlags == INVOKE_FUNC, "wFlags = %x\n", wFlags);
159 ok(pdp->cArgs == 0, "cArgs = %d\n", pdp->cArgs);
160 ok(!pdp->cNamedArgs, "cNamedArgs = %d\n", pdp->cNamedArgs);
162 V_VT(pVarResult) = VT_EMPTY;
165 ok(0, "unexpected dispIdMember %d\n", dispIdMember);
172 static IDispatchVtbl testobj_vtbl = {
173 Dispatch_QueryInterface,
176 Dispatch_GetTypeInfoCount,
177 Dispatch_GetTypeInfo,
178 Dispatch_GetIDsOfNames,
182 static IDispatch testobj = { &testobj_vtbl };
184 static HRESULT WINAPI ClassFactory_QueryInterface(IClassFactory *iface, REFIID riid, void **ppv)
186 if(IsEqualGUID(&IID_IUnknown, riid) || IsEqualGUID(&IID_IClassFactory, riid)) {
192 return E_NOINTERFACE;
195 static ULONG WINAPI ClassFactory_AddRef(IClassFactory *iface)
200 static ULONG WINAPI ClassFactory_Release(IClassFactory *iface)
205 static HRESULT WINAPI ClassFactory_CreateInstance(IClassFactory *iface, IUnknown *outer, REFIID riid, void **ppv)
207 ok(!outer, "outer = %p\n", outer);
208 return IDispatch_QueryInterface(&testobj, riid, ppv);
211 static HRESULT WINAPI ClassFactory_LockServer(IClassFactory *iface, BOOL dolock)
216 static const IClassFactoryVtbl ClassFactoryVtbl = {
217 ClassFactory_QueryInterface,
219 ClassFactory_Release,
220 ClassFactory_CreateInstance,
221 ClassFactory_LockServer
224 static IClassFactory testobj_cf = { &ClassFactoryVtbl };
226 static void run_test(const char *file_name)
228 SECURITY_ATTRIBUTES sa = {sizeof(sa), 0, TRUE};
229 char command[MAX_PATH];
230 STARTUPINFOA si = {sizeof(si)};
231 PROCESS_INFORMATION pi;
234 script_name = file_name;
235 sprintf(command, "wscript.exe %s", file_name);
237 SET_EXPECT(reportSuccess);
239 bres = CreateProcessA(NULL, command, NULL, NULL, TRUE, 0, NULL, NULL, &si, &pi);
241 win_skip("script.exe is not available\n");
242 SET_CALLED(reportSuccess);
246 WaitForSingleObject(pi.hProcess, INFINITE);
247 CloseHandle(pi.hThread);
248 CloseHandle(pi.hProcess);
250 CHECK_CALLED(reportSuccess);
253 static BOOL WINAPI test_enum_proc(HMODULE module, LPCTSTR type, LPSTR name, LONG_PTR param)
255 const char *script_data, *ext;
256 DWORD script_size, size;
257 char file_name[MAX_PATH];
262 trace("running %s test...\n", name);
264 src = FindResourceA(NULL, name, type);
265 ok(src != NULL, "Could not find resource %s: %u\n", name, GetLastError());
269 script_data = LoadResource(NULL, src);
270 script_size = SizeofResource(NULL, src);
271 while(script_size && !script_data[script_size-1])
274 ext = strrchr(name, '.');
275 ok(ext != NULL, "no script extension\n");
279 sprintf(file_name, "test%s", ext);
281 file = CreateFileA(file_name, GENERIC_WRITE, 0, NULL, CREATE_ALWAYS,
282 FILE_ATTRIBUTE_NORMAL, NULL);
283 ok(file != INVALID_HANDLE_VALUE, "CreateFile failed: %u\n", GetLastError());
284 if(file == INVALID_HANDLE_VALUE)
287 res = WriteFile(file, script_data, script_size, &size, NULL);
289 ok(res, "Could not write to file: %u\n", GetLastError());
295 DeleteFileA(file_name);
299 static BOOL init_key(const char *key_name, const char *def_value, BOOL init)
305 RegDeleteKey(HKEY_CLASSES_ROOT, key_name);
309 res = RegCreateKeyA(HKEY_CLASSES_ROOT, key_name, &hkey);
310 if(res != ERROR_SUCCESS)
314 res = RegSetValueA(hkey, NULL, REG_SZ, def_value, strlen(def_value));
317 return res == ERROR_SUCCESS;
320 static BOOL init_registry(BOOL init)
322 return init_key("Wine.Test\\CLSID", TESTOBJ_CLSID, init);
325 static BOOL register_activex(void)
330 if(!init_registry(TRUE)) {
331 init_registry(FALSE);
335 hres = CoRegisterClassObject(&CLSID_TestObj, (IUnknown *)&testobj_cf,
336 CLSCTX_SERVER, REGCLS_MULTIPLEUSE, ®id);
337 ok(hres == S_OK, "Could not register script engine: %08x\n", hres);
346 CoInitializeEx(NULL, COINIT_MULTITHREADED);
349 argc = winetest_get_mainargs(&argv);
353 EnumResourceNamesA(NULL, "TESTSCRIPT", test_enum_proc, 0);
355 init_registry(FALSE);