Commit 2822b577 authored by Jacek Caban's avatar Jacek Caban Committed by Alexandre Julliard

oleaut32/tests: Add test of reference typelib caching.

parent dc96f63f
...@@ -17,5 +17,6 @@ RC_SRCS = tmarshal.rc ...@@ -17,5 +17,6 @@ RC_SRCS = tmarshal.rc
IDL_SRCS = \ IDL_SRCS = \
test_reg.idl \ test_reg.idl \
test_simple.idl \
test_tlb.idl \ test_tlb.idl \
tmarshal.idl tmarshal.idl
/*
* Copyright 2020 Jacek Caban for CodeWeavers
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
*/
#pragma makedep ident
#pragma makedep typelib
import "oaidl.idl"; /* needed by widl */
[uuid(8b05fe77-4a6c-4133-b9cd-8f00007af786)]
library base
{
importlib("stdole2.tlb");
[uuid(b14b6bb5-904e-4ff9-b247-bd361f7a0004)]
interface IBaseIface : IDispatch
{
HRESULT simple_test();
}
}
...@@ -35,3 +35,6 @@ LANGUAGE LANG_NEUTRAL, SUBLANG_NEUTRAL ...@@ -35,3 +35,6 @@ LANGUAGE LANG_NEUTRAL, SUBLANG_NEUTRAL
/* @makedep: test_reg.tlb */ /* @makedep: test_reg.tlb */
3 TYPELIB test_reg.tlb 3 TYPELIB test_reg.tlb
/* @makedep: test_simple.tlb */
4 TL test_simple.tlb
...@@ -41,6 +41,7 @@ ...@@ -41,6 +41,7 @@
#include "test_reg.h" #include "test_reg.h"
#include "test_tlb.h" #include "test_tlb.h"
#include "test_simple.h"
#define expect_eq(expr, value, type, format) { type _ret = (expr); ok((value) == _ret, #expr " expected " format " got " format "\n", value, _ret); } #define expect_eq(expr, value, type, format) { type _ret = (expr); ok((value) == _ret, #expr " expected " format " got " format "\n", value, _ret); }
#define expect_int(expr, value) expect_eq(expr, (int)(value), int, "%d") #define expect_int(expr, value) expect_eq(expr, (int)(value), int, "%d")
...@@ -775,7 +776,7 @@ static void test_CreateDispTypeInfo(void) ...@@ -775,7 +776,7 @@ static void test_CreateDispTypeInfo(void)
SysFreeString(methdata[3].szName); SysFreeString(methdata[3].szName);
} }
static void write_typelib(int res_no, const WCHAR *filename) static void write_typelib(int res_no, const WCHAR *filename, const WCHAR *type)
{ {
DWORD written; DWORD written;
HANDLE file; HANDLE file;
...@@ -785,8 +786,8 @@ static void write_typelib(int res_no, const WCHAR *filename) ...@@ -785,8 +786,8 @@ static void write_typelib(int res_no, const WCHAR *filename)
file = CreateFileW( filename, GENERIC_READ|GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, 0, 0 ); file = CreateFileW( filename, GENERIC_READ|GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, 0, 0 );
ok( file != INVALID_HANDLE_VALUE, "file creation failed\n" ); ok( file != INVALID_HANDLE_VALUE, "file creation failed\n" );
if (file == INVALID_HANDLE_VALUE) return; if (file == INVALID_HANDLE_VALUE) return;
res = FindResourceA( GetModuleHandleA(NULL), (LPCSTR)MAKEINTRESOURCE(res_no), "TYPELIB" ); res = FindResourceW( GetModuleHandleA(NULL), (const WCHAR *)MAKEINTRESOURCE(res_no), type );
ok( res != 0, "couldn't find resource\n" ); ok( res != 0, "couldn't find resource %d %s\n", res_no, debugstr_w(type) );
ptr = LockResource( LoadResource( GetModuleHandleA(NULL), res )); ptr = LockResource( LoadResource( GetModuleHandleA(NULL), res ));
WriteFile( file, ptr, SizeofResource( GetModuleHandleA(NULL), res ), &written, NULL ); WriteFile( file, ptr, SizeofResource( GetModuleHandleA(NULL), res ), &written, NULL );
ok( written == SizeofResource( GetModuleHandleA(NULL), res ), "couldn't write resource\n" ); ok( written == SizeofResource( GetModuleHandleA(NULL), res ), "couldn't write resource\n" );
...@@ -820,12 +821,12 @@ static void test_invoke_func(ITypeInfo *typeinfo) ...@@ -820,12 +821,12 @@ static void test_invoke_func(ITypeInfo *typeinfo)
ok(hres == DISP_E_BADPARAMCOUNT, "got 0x%08x\n", hres); ok(hres == DISP_E_BADPARAMCOUNT, "got 0x%08x\n", hres);
} }
static WCHAR *create_test_typelib(int res_no) static WCHAR *create_test_typelib(int res_no, const WCHAR *type)
{ {
static WCHAR filename[MAX_PATH]; static WCHAR filename[MAX_PATH];
GetTempFileNameW(L".", L"tlb", 0, filename); GetTempFileNameW(L".", L"tlb", 0, filename);
write_typelib(res_no, filename); write_typelib(res_no, filename, type);
return filename; return filename;
} }
...@@ -1028,7 +1029,7 @@ static void test_TypeInfo(void) ...@@ -1028,7 +1029,7 @@ static void test_TypeInfo(void)
ITypeInfo_Release(pTypeInfo); ITypeInfo_Release(pTypeInfo);
ITypeLib_Release(pTypeLib); ITypeLib_Release(pTypeLib);
filename = create_test_typelib(3); filename = create_test_typelib(3, L"TYPELIB");
hr = LoadTypeLib(filename, &pTypeLib); hr = LoadTypeLib(filename, &pTypeLib);
ok(hr == S_OK, "got 0x%08x\n", hr); ok(hr == S_OK, "got 0x%08x\n", hr);
...@@ -5036,7 +5037,7 @@ static void test_register_typelib(BOOL system_registration) ...@@ -5036,7 +5037,7 @@ static void test_register_typelib(BOOL system_registration)
if (pIsWow64Process) if (pIsWow64Process)
pIsWow64Process(GetCurrentProcess(), &is_wow64); pIsWow64Process(GetCurrentProcess(), &is_wow64);
filename = create_test_typelib(3); filename = create_test_typelib(3, L"TYPELIB");
hr = LoadTypeLibEx(filename, REGKIND_NONE, &typelib); hr = LoadTypeLibEx(filename, REGKIND_NONE, &typelib);
ok(hr == S_OK, "got %08x\n", hr); ok(hr == S_OK, "got %08x\n", hr);
...@@ -5787,8 +5788,8 @@ static void test_LoadRegTypeLib(void) ...@@ -5787,8 +5788,8 @@ static void test_LoadRegTypeLib(void)
DeleteFileA("main.manifest"); DeleteFileA("main.manifest");
/* create typelib file */ /* create typelib file */
write_typelib(1, L"test_actctx_tlb.tlb"); write_typelib(1, L"test_actctx_tlb.tlb", L"TYPELIB");
write_typelib(3, L"test_actctx_tlb2.tlb"); write_typelib(3, L"test_actctx_tlb2.tlb", L"TYPELIB");
hr = LoadRegTypeLib(&LIBID_TestTypelib, 1, 0, LOCALE_NEUTRAL, &tl); hr = LoadRegTypeLib(&LIBID_TestTypelib, 1, 0, LOCALE_NEUTRAL, &tl);
ok(hr == TYPE_E_LIBNOTREGISTERED, "got 0x%08x\n", hr); ok(hr == TYPE_E_LIBNOTREGISTERED, "got 0x%08x\n", hr);
...@@ -6388,11 +6389,11 @@ static void test_dep(void) { ...@@ -6388,11 +6389,11 @@ static void test_dep(void) {
trace("Starting typelib dependency tests\n"); trace("Starting typelib dependency tests\n");
refFilename = create_test_typelib(2); refFilename = create_test_typelib(4, L"TL");
hr = LoadTypeLibEx(refFilename, REGKIND_NONE, &preftLib); hr = LoadTypeLibEx(refFilename, REGKIND_NONE, &preftLib);
ok(hr == S_OK, "got %08x\n", hr); ok(hr == S_OK, "got %08x\n", hr);
hr = ITypeLib_GetTypeInfoOfGuid(preftLib, &IID_ISimpleIface, &preftInfo); hr = ITypeLib_GetTypeInfoOfGuid(preftLib, &IID_IBaseIface, &preftInfo);
ok(hr == S_OK, "got %08x\n", hr); ok(hr == S_OK, "got %08x\n", hr);
GetTempFileNameA(".", "tlb", 0, filename); GetTempFileNameA(".", "tlb", 0, filename);
...@@ -6448,13 +6449,39 @@ static void test_dep(void) { ...@@ -6448,13 +6449,39 @@ static void test_dep(void) {
ok(hr == S_OK, "got: %x\n", hr); ok(hr == S_OK, "got: %x\n", hr);
hr = ITypeInfo_GetRefTypeInfo(ptInfo, refType, &ptInfoExt); hr = ITypeInfo_GetRefTypeInfo(ptInfo, refType, &ptInfoExt);
ok(hr == S_OK || broken(hr == TYPE_E_CANTLOADLIBRARY) /* win 2000 */, "got: %x\n", hr); ok(hr == TYPE_E_CANTLOADLIBRARY, "got: %x\n", hr);
ITypeInfo_Release(ptInfo); ITypeInfo_Release(ptInfo);
if(ptInfoExt) if(ptInfoExt)
ITypeInfo_Release(ptInfoExt); ITypeInfo_Release(ptInfoExt);
ITypeLib_Release(ptLib); ITypeLib_Release(ptLib);
hr = LoadTypeLibEx(filenameW, REGKIND_NONE, &ptLib);
ok(hr == S_OK, "got %08x\n", hr);
hr = ITypeLib_GetTypeInfo(ptLib, 0, &ptInfo);
ok(hr == S_OK, "GetTypeInfo failed: %08x\n", hr);
hr = ITypeInfo_GetRefTypeOfImplType(ptInfo, 0, &refType);
ok(hr == S_OK, "GetRefTypeOfImplType failed: %08x\n", hr);
hr = ITypeInfo_GetRefTypeInfo(ptInfo, refType, &ptInfoExt);
ok(hr == TYPE_E_CANTLOADLIBRARY, "got: %x\n", hr);
refFilename = create_test_typelib(4, L"TL");
hr = LoadTypeLibEx(refFilename, REGKIND_NONE, &preftLib);
ok(hr == S_OK, "got %08x\n", hr);
hr = ITypeInfo_GetRefTypeInfo(ptInfo, refType, &ptInfoExt);
ok(hr == S_OK, "got: %x\n", hr);
ITypeInfo_Release(ptInfoExt);
ITypeLib_Release(preftLib);
DeleteFileW(refFilename);
ITypeInfo_Release(ptInfo);
ITypeLib_Release(ptLib);
DeleteFileW(filenameW); DeleteFileW(filenameW);
} }
...@@ -6580,7 +6607,7 @@ START_TEST(typelib) ...@@ -6580,7 +6607,7 @@ START_TEST(typelib)
test_SetDocString(); test_SetDocString();
test_FindName(); test_FindName();
if ((filename = create_test_typelib(2))) if ((filename = create_test_typelib(2, L"TYPELIB")))
{ {
test_dump_typelib( filename ); test_dump_typelib( filename );
DeleteFileW( filename ); DeleteFileW( filename );
......
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