2 * Object Linking and Embedding Tests
4 * Copyright 2005 Robert Shearman
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
31 #include "wine/test.h"
33 #define ok_ole_success(hr, func) ok(hr == S_OK, func " failed with error 0x%08x\n", hr)
35 static IPersistStorage OleObjectPersistStg;
36 static IOleCache *cache;
37 static IRunnableObject *runnable;
39 static const CLSID CLSID_WineTest =
40 { /* 9474ba1a-258b-490b-bc13-516e9239ace0 */
44 {0xbc, 0x13, 0x51, 0x6e, 0x92, 0x39, 0xac, 0xe0}
47 static char const * const *expected_method_list;
49 BOOL g_showRunnable = TRUE;
50 BOOL g_isRunning = TRUE;
52 #define CHECK_EXPECTED_METHOD(method_name) \
54 trace("%s\n", method_name); \
55 ok(*expected_method_list != NULL, "Extra method %s called\n", method_name); \
56 if (*expected_method_list) \
58 ok(!strcmp(*expected_method_list, method_name), "Expected %s to be called instead of %s\n", \
59 *expected_method_list, method_name); \
60 expected_method_list++; \
64 static HRESULT WINAPI OleObject_QueryInterface(IOleObject *iface, REFIID riid, void **ppv)
66 CHECK_EXPECTED_METHOD("OleObject_QueryInterface");
70 if (IsEqualIID(riid, &IID_IUnknown) || IsEqualIID(riid, &IID_IOleObject))
72 else if (IsEqualIID(riid, &IID_IPersistStorage))
73 *ppv = &OleObjectPersistStg;
74 else if (IsEqualIID(riid, &IID_IOleCache))
76 else if (IsEqualIID(riid, &IID_IRunnableObject) && g_showRunnable)
80 IUnknown_AddRef((IUnknown*)*ppv);
84 trace("OleObject_QueryInterface: returning E_NOINTERFACE\n");
88 static ULONG WINAPI OleObject_AddRef(IOleObject *iface)
90 CHECK_EXPECTED_METHOD("OleObject_AddRef");
94 static ULONG WINAPI OleObject_Release(IOleObject *iface)
96 CHECK_EXPECTED_METHOD("OleObject_Release");
100 static HRESULT WINAPI OleObject_SetClientSite
103 IOleClientSite *pClientSite
106 CHECK_EXPECTED_METHOD("OleObject_SetClientSite");
110 static HRESULT WINAPI OleObject_GetClientSite
113 IOleClientSite **ppClientSite
116 CHECK_EXPECTED_METHOD("OleObject_GetClientSite");
120 static HRESULT WINAPI OleObject_SetHostNames
123 LPCOLESTR szContainerApp,
124 LPCOLESTR szContainerObj
127 CHECK_EXPECTED_METHOD("OleObject_SetHostNames");
131 static HRESULT WINAPI OleObject_Close
137 CHECK_EXPECTED_METHOD("OleObject_Close");
141 static HRESULT WINAPI OleObject_SetMoniker
144 DWORD dwWhichMoniker,
148 CHECK_EXPECTED_METHOD("OleObject_SetMoniker");
152 static HRESULT WINAPI OleObject_GetMoniker
156 DWORD dwWhichMoniker,
160 CHECK_EXPECTED_METHOD("OleObject_GetMoniker");
164 static HRESULT WINAPI OleObject_InitFromData
167 IDataObject *pDataObject,
172 CHECK_EXPECTED_METHOD("OleObject_InitFromData");
176 static HRESULT WINAPI OleObject_GetClipboardData
180 IDataObject **ppDataObject
183 CHECK_EXPECTED_METHOD("OleObject_GetClipboardData");
187 static HRESULT WINAPI OleObject_DoVerb
192 IOleClientSite *pActiveSite,
198 CHECK_EXPECTED_METHOD("OleObject_DoVerb");
202 static HRESULT WINAPI OleObject_EnumVerbs
205 IEnumOLEVERB **ppEnumOleVerb
208 CHECK_EXPECTED_METHOD("OleObject_EnumVerbs");
212 static HRESULT WINAPI OleObject_Update
217 CHECK_EXPECTED_METHOD("OleObject_Update");
221 static HRESULT WINAPI OleObject_IsUpToDate
226 CHECK_EXPECTED_METHOD("OleObject_IsUpToDate");
230 static HRESULT WINAPI OleObject_GetUserClassID
236 CHECK_EXPECTED_METHOD("OleObject_GetUserClassID");
240 static HRESULT WINAPI OleObject_GetUserType
244 LPOLESTR *pszUserType
247 CHECK_EXPECTED_METHOD("OleObject_GetUserType");
251 static HRESULT WINAPI OleObject_SetExtent
258 CHECK_EXPECTED_METHOD("OleObject_SetExtent");
262 static HRESULT WINAPI OleObject_GetExtent
269 CHECK_EXPECTED_METHOD("OleObject_GetExtent");
273 static HRESULT WINAPI OleObject_Advise
276 IAdviseSink *pAdvSink,
280 CHECK_EXPECTED_METHOD("OleObject_Advise");
284 static HRESULT WINAPI OleObject_Unadvise
290 CHECK_EXPECTED_METHOD("OleObject_Unadvise");
294 static HRESULT WINAPI OleObject_EnumAdvise
297 IEnumSTATDATA **ppenumAdvise
300 CHECK_EXPECTED_METHOD("OleObject_EnumAdvise");
304 static HRESULT WINAPI OleObject_GetMiscStatus
311 CHECK_EXPECTED_METHOD("OleObject_GetMiscStatus");
312 *pdwStatus = DVASPECT_CONTENT;
316 static HRESULT WINAPI OleObject_SetColorScheme
322 CHECK_EXPECTED_METHOD("OleObject_SetColorScheme");
326 static const IOleObjectVtbl OleObjectVtbl =
328 OleObject_QueryInterface,
331 OleObject_SetClientSite,
332 OleObject_GetClientSite,
333 OleObject_SetHostNames,
335 OleObject_SetMoniker,
336 OleObject_GetMoniker,
337 OleObject_InitFromData,
338 OleObject_GetClipboardData,
342 OleObject_IsUpToDate,
343 OleObject_GetUserClassID,
344 OleObject_GetUserType,
349 OleObject_EnumAdvise,
350 OleObject_GetMiscStatus,
351 OleObject_SetColorScheme
354 static IOleObject OleObject = { &OleObjectVtbl };
356 static HRESULT WINAPI OleObjectPersistStg_QueryInterface(IPersistStorage *iface, REFIID riid, void **ppv)
358 trace("OleObjectPersistStg_QueryInterface\n");
359 return IUnknown_QueryInterface((IUnknown *)&OleObject, riid, ppv);
362 static ULONG WINAPI OleObjectPersistStg_AddRef(IPersistStorage *iface)
364 CHECK_EXPECTED_METHOD("OleObjectPersistStg_AddRef");
368 static ULONG WINAPI OleObjectPersistStg_Release(IPersistStorage *iface)
370 CHECK_EXPECTED_METHOD("OleObjectPersistStg_Release");
374 static HRESULT WINAPI OleObjectPersistStg_GetClassId(IPersistStorage *iface, CLSID *clsid)
376 CHECK_EXPECTED_METHOD("OleObjectPersistStg_GetClassId");
380 static HRESULT WINAPI OleObjectPersistStg_IsDirty
382 IPersistStorage *iface
385 CHECK_EXPECTED_METHOD("OleObjectPersistStg_IsDirty");
389 static HRESULT WINAPI OleObjectPersistStg_InitNew
391 IPersistStorage *iface,
395 CHECK_EXPECTED_METHOD("OleObjectPersistStg_InitNew");
399 static HRESULT WINAPI OleObjectPersistStg_Load
401 IPersistStorage *iface,
405 CHECK_EXPECTED_METHOD("OleObjectPersistStg_Load");
409 static HRESULT WINAPI OleObjectPersistStg_Save
411 IPersistStorage *iface,
416 CHECK_EXPECTED_METHOD("OleObjectPersistStg_Save");
420 static HRESULT WINAPI OleObjectPersistStg_SaveCompleted
422 IPersistStorage *iface,
426 CHECK_EXPECTED_METHOD("OleObjectPersistStg_SaveCompleted");
430 static HRESULT WINAPI OleObjectPersistStg_HandsOffStorage
432 IPersistStorage *iface
435 CHECK_EXPECTED_METHOD("OleObjectPersistStg_HandsOffStorage");
439 static const IPersistStorageVtbl OleObjectPersistStgVtbl =
441 OleObjectPersistStg_QueryInterface,
442 OleObjectPersistStg_AddRef,
443 OleObjectPersistStg_Release,
444 OleObjectPersistStg_GetClassId,
445 OleObjectPersistStg_IsDirty,
446 OleObjectPersistStg_InitNew,
447 OleObjectPersistStg_Load,
448 OleObjectPersistStg_Save,
449 OleObjectPersistStg_SaveCompleted,
450 OleObjectPersistStg_HandsOffStorage
453 static IPersistStorage OleObjectPersistStg = { &OleObjectPersistStgVtbl };
455 static HRESULT WINAPI OleObjectCache_QueryInterface(IOleCache *iface, REFIID riid, void **ppv)
457 return IUnknown_QueryInterface((IUnknown *)&OleObject, riid, ppv);
460 static ULONG WINAPI OleObjectCache_AddRef(IOleCache *iface)
462 CHECK_EXPECTED_METHOD("OleObjectCache_AddRef");
466 static ULONG WINAPI OleObjectCache_Release(IOleCache *iface)
468 CHECK_EXPECTED_METHOD("OleObjectCache_Release");
472 static HRESULT WINAPI OleObjectCache_Cache
475 FORMATETC *pformatetc,
480 CHECK_EXPECTED_METHOD("OleObjectCache_Cache");
484 static HRESULT WINAPI OleObjectCache_Uncache
490 CHECK_EXPECTED_METHOD("OleObjectCache_Uncache");
494 static HRESULT WINAPI OleObjectCache_EnumCache
497 IEnumSTATDATA **ppenumSTATDATA
500 CHECK_EXPECTED_METHOD("OleObjectCache_EnumCache");
505 static HRESULT WINAPI OleObjectCache_InitCache
508 IDataObject *pDataObject
511 CHECK_EXPECTED_METHOD("OleObjectCache_InitCache");
516 static HRESULT WINAPI OleObjectCache_SetData
519 FORMATETC *pformatetc,
524 CHECK_EXPECTED_METHOD("OleObjectCache_SetData");
529 static const IOleCacheVtbl OleObjectCacheVtbl =
531 OleObjectCache_QueryInterface,
532 OleObjectCache_AddRef,
533 OleObjectCache_Release,
534 OleObjectCache_Cache,
535 OleObjectCache_Uncache,
536 OleObjectCache_EnumCache,
537 OleObjectCache_InitCache,
538 OleObjectCache_SetData
541 static IOleCache OleObjectCache = { &OleObjectCacheVtbl };
543 static HRESULT WINAPI OleObjectCF_QueryInterface(IClassFactory *iface, REFIID riid, void **ppv)
545 if (IsEqualIID(riid, &IID_IUnknown) || IsEqualIID(riid, &IID_IClassFactory))
548 IUnknown_AddRef(iface);
552 return E_NOINTERFACE;
555 static ULONG WINAPI OleObjectCF_AddRef(IClassFactory *iface)
560 static ULONG WINAPI OleObjectCF_Release(IClassFactory *iface)
565 static HRESULT WINAPI OleObjectCF_CreateInstance(IClassFactory *iface, IUnknown *punkOuter, REFIID riid, void **ppv)
567 return IUnknown_QueryInterface((IUnknown *)&OleObject, riid, ppv);
570 static HRESULT WINAPI OleObjectCF_LockServer(IClassFactory *iface, BOOL lock)
575 static const IClassFactoryVtbl OleObjectCFVtbl =
577 OleObjectCF_QueryInterface,
580 OleObjectCF_CreateInstance,
581 OleObjectCF_LockServer
584 static IClassFactory OleObjectCF = { &OleObjectCFVtbl };
586 static HRESULT WINAPI OleObjectRunnable_QueryInterface(IRunnableObject *iface, REFIID riid, void **ppv)
588 return IUnknown_QueryInterface((IUnknown *)&OleObject, riid, ppv);
591 static ULONG WINAPI OleObjectRunnable_AddRef(IRunnableObject *iface)
593 CHECK_EXPECTED_METHOD("OleObjectRunnable_AddRef");
597 static ULONG WINAPI OleObjectRunnable_Release(IRunnableObject *iface)
599 CHECK_EXPECTED_METHOD("OleObjectRunnable_Release");
603 static HRESULT WINAPI OleObjectRunnable_GetRunningClass(
604 IRunnableObject *iface,
607 CHECK_EXPECTED_METHOD("OleObjectRunnable_GetRunningClass");
611 static HRESULT WINAPI OleObjectRunnable_Run(
612 IRunnableObject *iface,
615 CHECK_EXPECTED_METHOD("OleObjectRunnable_Run");
619 static BOOL WINAPI OleObjectRunnable_IsRunning(IRunnableObject *iface)
621 CHECK_EXPECTED_METHOD("OleObjectRunnable_IsRunning");
625 static HRESULT WINAPI OleObjectRunnable_LockRunning(
626 IRunnableObject *iface,
628 BOOL fLastUnlockCloses)
630 CHECK_EXPECTED_METHOD("OleObjectRunnable_LockRunning");
634 static HRESULT WINAPI OleObjectRunnable_SetContainedObject(
635 IRunnableObject *iface,
638 CHECK_EXPECTED_METHOD("OleObjectRunnable_SetContainedObject");
642 static const IRunnableObjectVtbl OleObjectRunnableVtbl =
644 OleObjectRunnable_QueryInterface,
645 OleObjectRunnable_AddRef,
646 OleObjectRunnable_Release,
647 OleObjectRunnable_GetRunningClass,
648 OleObjectRunnable_Run,
649 OleObjectRunnable_IsRunning,
650 OleObjectRunnable_LockRunning,
651 OleObjectRunnable_SetContainedObject
654 static IRunnableObject OleObjectRunnable = { &OleObjectRunnableVtbl };
656 static const CLSID CLSID_Equation3 = {0x0002CE02, 0x0000, 0x0000, {0xC0,0x00,0x00,0x00,0x00,0x00,0x00,0x46} };
658 static void test_OleCreate(IStorage *pStorage)
663 static const char *methods_olerender_none[] =
665 "OleObject_QueryInterface",
667 "OleObject_QueryInterface",
668 "OleObjectPersistStg_AddRef",
669 "OleObjectPersistStg_InitNew",
670 "OleObjectPersistStg_Release",
674 static const char *methods_olerender_draw[] =
676 "OleObject_QueryInterface",
678 "OleObject_QueryInterface",
679 "OleObjectPersistStg_AddRef",
680 "OleObjectPersistStg_InitNew",
681 "OleObjectPersistStg_Release",
682 "OleObject_QueryInterface",
683 "OleObjectRunnable_AddRef",
684 "OleObjectRunnable_Run",
685 "OleObjectRunnable_Release",
686 "OleObject_QueryInterface",
687 "OleObjectCache_AddRef",
688 "OleObjectCache_Cache",
689 "OleObjectCache_Release",
693 static const char *methods_olerender_format[] =
695 "OleObject_QueryInterface",
697 "OleObject_QueryInterface",
699 "OleObject_GetMiscStatus",
700 "OleObject_QueryInterface",
701 "OleObjectPersistStg_AddRef",
702 "OleObjectPersistStg_InitNew",
703 "OleObjectPersistStg_Release",
704 "OleObject_SetClientSite",
706 "OleObject_QueryInterface",
707 "OleObjectRunnable_AddRef",
708 "OleObjectRunnable_Run",
709 "OleObjectRunnable_Release",
710 "OleObject_QueryInterface",
711 "OleObjectCache_AddRef",
712 "OleObjectCache_Cache",
713 "OleObjectCache_Release",
717 static const char *methods_olerender_asis[] =
719 "OleObject_QueryInterface",
721 "OleObject_QueryInterface",
722 "OleObjectPersistStg_AddRef",
723 "OleObjectPersistStg_InitNew",
724 "OleObjectPersistStg_Release",
728 static const char *methods_olerender_draw_no_runnable[] =
730 "OleObject_QueryInterface",
732 "OleObject_QueryInterface",
733 "OleObjectPersistStg_AddRef",
734 "OleObjectPersistStg_InitNew",
735 "OleObjectPersistStg_Release",
736 "OleObject_QueryInterface",
737 "OleObject_QueryInterface",
738 "OleObjectCache_AddRef",
739 "OleObjectCache_Cache",
740 "OleObjectCache_Release",
744 static const char *methods_olerender_draw_no_cache[] =
746 "OleObject_QueryInterface",
748 "OleObject_QueryInterface",
749 "OleObjectPersistStg_AddRef",
750 "OleObjectPersistStg_InitNew",
751 "OleObjectPersistStg_Release",
752 "OleObject_QueryInterface",
753 "OleObjectRunnable_AddRef",
754 "OleObjectRunnable_Run",
755 "OleObjectRunnable_Release",
756 "OleObject_QueryInterface",
761 runnable = &OleObjectRunnable;
762 cache = &OleObjectCache;
763 expected_method_list = methods_olerender_none;
764 trace("OleCreate with OLERENDER_NONE:\n");
765 hr = OleCreate(&CLSID_Equation3, &IID_IOleObject, OLERENDER_NONE, NULL, NULL, pStorage, (void **)&pObject);
766 ok_ole_success(hr, "OleCreate");
767 IOleObject_Release(pObject);
768 ok(!*expected_method_list, "Method sequence starting from %s not called\n", *expected_method_list);
770 expected_method_list = methods_olerender_draw;
771 trace("OleCreate with OLERENDER_DRAW:\n");
772 hr = OleCreate(&CLSID_Equation3, &IID_IOleObject, OLERENDER_DRAW, NULL, NULL, pStorage, (void **)&pObject);
773 ok_ole_success(hr, "OleCreate");
774 IOleObject_Release(pObject);
775 ok(!*expected_method_list, "Method sequence starting from %s not called\n", *expected_method_list);
777 formatetc.cfFormat = CF_TEXT;
778 formatetc.ptd = NULL;
779 formatetc.dwAspect = DVASPECT_CONTENT;
780 formatetc.lindex = -1;
781 formatetc.tymed = TYMED_HGLOBAL;
782 expected_method_list = methods_olerender_format;
783 trace("OleCreate with OLERENDER_FORMAT:\n");
784 hr = OleCreate(&CLSID_Equation3, &IID_IOleObject, OLERENDER_FORMAT, &formatetc, (IOleClientSite *)0xdeadbeef, pStorage, (void **)&pObject);
785 ok_ole_success(hr, "OleCreate");
786 IOleObject_Release(pObject);
787 ok(!*expected_method_list, "Method sequence starting from %s not called\n", *expected_method_list);
789 expected_method_list = methods_olerender_asis;
790 trace("OleCreate with OLERENDER_ASIS:\n");
791 hr = OleCreate(&CLSID_Equation3, &IID_IOleObject, OLERENDER_ASIS, NULL, NULL, pStorage, (void **)&pObject);
792 ok_ole_success(hr, "OleCreate");
793 IOleObject_Release(pObject);
794 ok(!*expected_method_list, "Method sequence starting from %s not called\n", *expected_method_list);
797 expected_method_list = methods_olerender_draw_no_runnable;
798 trace("OleCreate with OLERENDER_DRAW (no IOlObjectRunnable):\n");
799 hr = OleCreate(&CLSID_Equation3, &IID_IOleObject, OLERENDER_DRAW, NULL, NULL, pStorage, (void **)&pObject);
800 ok_ole_success(hr, "OleCreate");
801 IOleObject_Release(pObject);
802 ok(!*expected_method_list, "Method sequence starting from %s not called\n", *expected_method_list);
804 runnable = &OleObjectRunnable;
806 expected_method_list = methods_olerender_draw_no_cache;
807 trace("OleCreate with OLERENDER_DRAW (no IOlObjectRunnable):\n");
808 hr = OleCreate(&CLSID_Equation3, &IID_IOleObject, OLERENDER_DRAW, NULL, NULL, pStorage, (void **)&pObject);
809 ok_ole_success(hr, "OleCreate");
810 IOleObject_Release(pObject);
811 ok(!*expected_method_list, "Method sequence starting from %s not called\n", *expected_method_list);
815 static void test_OleLoad(IStorage *pStorage)
820 static const char *methods_oleload[] =
822 "OleObject_QueryInterface",
824 "OleObject_QueryInterface",
826 "OleObject_GetMiscStatus",
827 "OleObject_QueryInterface",
828 "OleObjectPersistStg_AddRef",
829 "OleObjectPersistStg_Load",
830 "OleObjectPersistStg_Release",
831 "OleObject_SetClientSite",
833 "OleObject_QueryInterface",
838 expected_method_list = methods_oleload;
840 hr = OleLoad(pStorage, &IID_IOleObject, (IOleClientSite *)0xdeadbeef, (void **)&pObject);
841 ok_ole_success(hr, "OleLoad");
842 IOleObject_Release(pObject);
843 ok(!*expected_method_list, "Method sequence starting from %s not called\n", *expected_method_list);
846 static BOOL STDMETHODCALLTYPE draw_continue(ULONG_PTR param)
848 CHECK_EXPECTED_METHOD("draw_continue");
852 static HRESULT WINAPI AdviseSink_QueryInterface(IAdviseSink *iface, REFIID riid, void **ppv)
854 if (IsEqualIID(riid, &IID_IAdviseSink) || IsEqualIID(riid, &IID_IUnknown))
857 IUnknown_AddRef(iface);
861 return E_NOINTERFACE;
864 static ULONG WINAPI AdviseSink_AddRef(IAdviseSink *iface)
869 static ULONG WINAPI AdviseSink_Release(IAdviseSink *iface)
875 static void WINAPI AdviseSink_OnDataChange(
877 FORMATETC *pFormatetc,
880 CHECK_EXPECTED_METHOD("AdviseSink_OnDataChange");
883 static void WINAPI AdviseSink_OnViewChange(
888 CHECK_EXPECTED_METHOD("AdviseSink_OnViewChange");
891 static void WINAPI AdviseSink_OnRename(
895 CHECK_EXPECTED_METHOD("AdviseSink_OnRename");
898 static void WINAPI AdviseSink_OnSave(IAdviseSink *iface)
900 CHECK_EXPECTED_METHOD("AdviseSink_OnSave");
903 static void WINAPI AdviseSink_OnClose(IAdviseSink *iface)
905 CHECK_EXPECTED_METHOD("AdviseSink_OnClose");
908 static const IAdviseSinkVtbl AdviseSinkVtbl =
910 AdviseSink_QueryInterface,
913 AdviseSink_OnDataChange,
914 AdviseSink_OnViewChange,
920 static IAdviseSink AdviseSink = { &AdviseSinkVtbl };
922 static HRESULT WINAPI DataObject_QueryInterface(
927 if (IsEqualIID(riid, &IID_IDataObject) || IsEqualIID(riid, &IID_IUnknown))
936 static ULONG WINAPI DataObject_AddRef(
942 static ULONG WINAPI DataObject_Release(
948 static HRESULT WINAPI DataObject_GetData(
950 LPFORMATETC pformatetcIn,
953 CHECK_EXPECTED_METHOD("DataObject_GetData");
957 static HRESULT WINAPI DataObject_GetDataHere(
959 LPFORMATETC pformatetc,
962 CHECK_EXPECTED_METHOD("DataObject_GetDataHere");
966 static HRESULT WINAPI DataObject_QueryGetData(
968 LPFORMATETC pformatetc)
970 CHECK_EXPECTED_METHOD("DataObject_QueryGetData");
974 static HRESULT WINAPI DataObject_GetCanonicalFormatEtc(
976 LPFORMATETC pformatectIn,
977 LPFORMATETC pformatetcOut)
979 CHECK_EXPECTED_METHOD("DataObject_GetCanonicalFormatEtc");
983 static HRESULT WINAPI DataObject_SetData(
985 LPFORMATETC pformatetc,
989 CHECK_EXPECTED_METHOD("DataObject_SetData");
993 static HRESULT WINAPI DataObject_EnumFormatEtc(
996 IEnumFORMATETC** ppenumFormatEtc)
998 CHECK_EXPECTED_METHOD("DataObject_EnumFormatEtc");
1002 static HRESULT WINAPI DataObject_DAdvise(
1004 FORMATETC* pformatetc,
1006 IAdviseSink* pAdvSink,
1007 DWORD* pdwConnection)
1009 CHECK_EXPECTED_METHOD("DataObject_DAdvise");
1014 static HRESULT WINAPI DataObject_DUnadvise(
1018 CHECK_EXPECTED_METHOD("DataObject_DUnadvise");
1022 static HRESULT WINAPI DataObject_EnumDAdvise(
1024 IEnumSTATDATA** ppenumAdvise)
1026 CHECK_EXPECTED_METHOD("DataObject_EnumDAdvise");
1027 return OLE_E_ADVISENOTSUPPORTED;
1030 static IDataObjectVtbl DataObjectVtbl =
1032 DataObject_QueryInterface,
1036 DataObject_GetDataHere,
1037 DataObject_QueryGetData,
1038 DataObject_GetCanonicalFormatEtc,
1040 DataObject_EnumFormatEtc,
1042 DataObject_DUnadvise,
1043 DataObject_EnumDAdvise
1046 static IDataObject DataObject = { &DataObjectVtbl };
1048 static void test_data_cache(void)
1051 IOleCache2 *pOleCache;
1053 IPersistStorage *pPS;
1054 IViewObject *pViewObject;
1055 IOleCacheControl *pOleCacheControl;
1057 STGMEDIUM stgmedium;
1063 char szSystemDir[MAX_PATH];
1064 WCHAR wszPath[MAX_PATH];
1065 static const WCHAR wszShell32[] = {'\\','s','h','e','l','l','3','2','.','d','l','l',0};
1067 static const char *methods_cacheinitnew[] =
1069 "AdviseSink_OnViewChange",
1070 "AdviseSink_OnViewChange",
1072 "DataObject_DAdvise",
1073 "DataObject_DAdvise",
1074 "DataObject_DUnadvise",
1075 "DataObject_DUnadvise",
1078 static const char *methods_cacheload[] =
1080 "AdviseSink_OnViewChange",
1084 "DataObject_GetData",
1085 "DataObject_GetData",
1086 "DataObject_GetData",
1090 GetSystemDirectory(szSystemDir, sizeof(szSystemDir)/sizeof(szSystemDir[0]));
1092 expected_method_list = methods_cacheinitnew;
1094 fmtetc.cfFormat = CF_METAFILEPICT;
1095 fmtetc.dwAspect = DVASPECT_ICON;
1098 fmtetc.tymed = TYMED_MFPICT;
1100 hr = StgCreateDocfile(NULL, STGM_READWRITE | STGM_CREATE | STGM_SHARE_EXCLUSIVE | STGM_DELETEONRELEASE, 0, &pStorage);
1101 ok_ole_success(hr, "StgCreateDocfile");
1103 /* Test with new data */
1105 hr = CreateDataCache(NULL, &CLSID_NULL, &IID_IOleCache2, (LPVOID *)&pOleCache);
1106 ok_ole_success(hr, "CreateDataCache");
1108 hr = IOleCache_QueryInterface(pOleCache, &IID_IPersistStorage, (LPVOID *)&pPS);
1109 ok_ole_success(hr, "IOleCache_QueryInterface(IID_IPersistStorage)");
1110 hr = IOleCache_QueryInterface(pOleCache, &IID_IViewObject, (LPVOID *)&pViewObject);
1111 ok_ole_success(hr, "IOleCache_QueryInterface(IID_IViewObject)");
1112 hr = IOleCache_QueryInterface(pOleCache, &IID_IOleCacheControl, (LPVOID *)&pOleCacheControl);
1113 ok_ole_success(hr, "IOleCache_QueryInterface(IID_IOleCacheControl)");
1115 hr = IViewObject_SetAdvise(pViewObject, DVASPECT_ICON, ADVF_PRIMEFIRST, &AdviseSink);
1116 ok_ole_success(hr, "IViewObject_SetAdvise");
1118 hr = IPersistStorage_InitNew(pPS, pStorage);
1119 ok_ole_success(hr, "IPersistStorage_InitNew");
1121 hr = IPersistStorage_IsDirty(pPS);
1122 ok_ole_success(hr, "IPersistStorage_IsDirty");
1124 hr = IPersistStorage_GetClassID(pPS, &clsid);
1125 ok_ole_success(hr, "IPersistStorage_GetClassID");
1126 ok(IsEqualCLSID(&clsid, &IID_NULL), "clsid should be blank\n");
1128 hr = IOleCache_Uncache(pOleCache, 0xdeadbeef);
1129 ok(hr == OLE_E_NOCONNECTION, "IOleCache_Uncache with invalid value should return OLE_E_NOCONNECTION instead of 0x%x\n", hr);
1131 for (fmtetc.cfFormat = CF_TEXT; fmtetc.cfFormat < CF_MAX; fmtetc.cfFormat++)
1134 fmtetc.dwAspect = DVASPECT_THUMBNAIL;
1135 for (i = 0; i < 7; i++)
1137 fmtetc.tymed = 1 << i;
1138 hr = IOleCache_Cache(pOleCache, &fmtetc, 0, &dwConnection);
1139 if ((fmtetc.cfFormat == CF_METAFILEPICT && fmtetc.tymed == TYMED_MFPICT) ||
1140 (fmtetc.cfFormat == CF_BITMAP && fmtetc.tymed == TYMED_GDI) ||
1141 (fmtetc.cfFormat == CF_DIB && fmtetc.tymed == TYMED_HGLOBAL) ||
1142 (fmtetc.cfFormat == CF_ENHMETAFILE && fmtetc.tymed == TYMED_ENHMF))
1143 ok(hr == S_OK, "IOleCache_Cache cfFormat = %d, tymed = %d should have returned S_OK instead of 0x%08x\n",
1144 fmtetc.cfFormat, fmtetc.tymed, hr);
1145 else if (fmtetc.tymed == TYMED_HGLOBAL)
1146 ok(hr == CACHE_S_FORMATETC_NOTSUPPORTED,
1147 "IOleCache_Cache cfFormat = %d, tymed = %d should have returned CACHE_S_FORMATETC_NOTSUPPORTED instead of 0x%08x\n",
1148 fmtetc.cfFormat, fmtetc.tymed, hr);
1150 ok(hr == DV_E_TYMED, "IOleCache_Cache cfFormat = %d, tymed = %d should have returned DV_E_TYMED instead of 0x%08x\n",
1151 fmtetc.cfFormat, fmtetc.tymed, hr);
1154 hr = IOleCache_Uncache(pOleCache, dwConnection);
1155 ok_ole_success(hr, "IOleCache_Uncache");
1160 fmtetc.cfFormat = CF_BITMAP;
1161 fmtetc.dwAspect = DVASPECT_THUMBNAIL;
1162 fmtetc.tymed = TYMED_GDI;
1163 hr = IOleCache_Cache(pOleCache, &fmtetc, 0, &dwConnection);
1164 ok_ole_success(hr, "IOleCache_Cache");
1166 fmtetc.cfFormat = 0;
1167 fmtetc.dwAspect = DVASPECT_ICON;
1168 fmtetc.tymed = TYMED_MFPICT;
1169 hr = IOleCache_Cache(pOleCache, &fmtetc, 0, &dwConnection);
1170 ok_ole_success(hr, "IOleCache_Cache");
1172 MultiByteToWideChar(CP_ACP, 0, szSystemDir, -1, wszPath, sizeof(wszPath)/sizeof(wszPath[0]));
1173 memcpy(wszPath+lstrlenW(wszPath), wszShell32, sizeof(wszShell32));
1175 fmtetc.cfFormat = CF_METAFILEPICT;
1176 stgmedium.tymed = TYMED_MFPICT;
1177 U(stgmedium).hMetaFilePict = OleMetafilePictFromIconAndLabel(
1178 LoadIcon(NULL, IDI_APPLICATION), wszPath, wszPath, 0);
1179 stgmedium.pUnkForRelease = NULL;
1181 fmtetc.dwAspect = DVASPECT_CONTENT;
1182 hr = IOleCache_SetData(pOleCache, &fmtetc, &stgmedium, FALSE);
1183 ok(hr == OLE_E_BLANK, "IOleCache_SetData for aspect not in cache should have return OLE_E_BLANK instead of 0x%08x\n", hr);
1185 fmtetc.dwAspect = DVASPECT_ICON;
1186 hr = IOleCache_SetData(pOleCache, &fmtetc, &stgmedium, FALSE);
1187 ok_ole_success(hr, "IOleCache_SetData");
1189 hr = IViewObject_Freeze(pViewObject, DVASPECT_ICON, -1, NULL, &dwFreeze);
1191 ok_ole_success(hr, "IViewObject_Freeze");
1192 hr = IViewObject_Freeze(pViewObject, DVASPECT_CONTENT, -1, NULL, &dwFreeze);
1193 ok(hr == OLE_E_BLANK, "IViewObject_Freeze with uncached aspect should have returned OLE_E_BLANK instead of 0x%08x\n", hr);
1198 rcBounds.right = 100;
1199 rcBounds.bottom = 100;
1200 hdcMem = CreateCompatibleDC(NULL);
1202 hr = IViewObject_Draw(pViewObject, DVASPECT_ICON, -1, NULL, NULL, NULL, hdcMem, &rcBounds, NULL, draw_continue, 0xdeadbeef);
1203 ok_ole_success(hr, "IViewObject_Draw");
1205 hr = IViewObject_Draw(pViewObject, DVASPECT_CONTENT, -1, NULL, NULL, NULL, hdcMem, &rcBounds, NULL, draw_continue, 0xdeadbeef);
1206 ok(hr == OLE_E_BLANK, "IViewObject_Draw with uncached aspect should have returned OLE_E_BLANK instead of 0x%08x\n", hr);
1210 hr = IOleCacheControl_OnRun(pOleCacheControl, &DataObject);
1212 ok_ole_success(hr, "IOleCacheControl_OnRun");
1215 hr = IPersistStorage_Save(pPS, pStorage, TRUE);
1216 ok_ole_success(hr, "IPersistStorage_Save");
1218 hr = IPersistStorage_SaveCompleted(pPS, NULL);
1219 ok_ole_success(hr, "IPersistStorage_SaveCompleted");
1221 hr = IPersistStorage_IsDirty(pPS);
1222 ok(hr == S_FALSE, "IPersistStorage_IsDirty should have returned S_FALSE instead of 0x%x\n", hr);
1224 IPersistStorage_Release(pPS);
1225 IViewObject_Release(pViewObject);
1226 IOleCache_Release(pOleCache);
1227 IOleCacheControl_Release(pOleCacheControl);
1230 ok(!*expected_method_list, "Method sequence starting from %s not called\n", *expected_method_list);
1233 /* Test with loaded data */
1234 trace("Testing loaded data with CreateDataCache:\n");
1235 expected_method_list = methods_cacheload;
1237 hr = CreateDataCache(NULL, &CLSID_NULL, &IID_IOleCache2, (LPVOID *)&pOleCache);
1238 ok_ole_success(hr, "CreateDataCache");
1240 hr = IOleCache_QueryInterface(pOleCache, &IID_IPersistStorage, (LPVOID *)&pPS);
1241 ok_ole_success(hr, "IOleCache_QueryInterface(IID_IPersistStorage)");
1242 hr = IOleCache_QueryInterface(pOleCache, &IID_IViewObject, (LPVOID *)&pViewObject);
1243 ok_ole_success(hr, "IOleCache_QueryInterface(IID_IViewObject)");
1245 hr = IViewObject_SetAdvise(pViewObject, DVASPECT_ICON, ADVF_PRIMEFIRST, &AdviseSink);
1246 ok_ole_success(hr, "IViewObject_SetAdvise");
1248 hr = IPersistStorage_Load(pPS, pStorage);
1249 ok_ole_success(hr, "IPersistStorage_Load");
1251 hr = IPersistStorage_IsDirty(pPS);
1252 ok(hr == S_FALSE, "IPersistStorage_IsDirty should have returned S_FALSE instead of 0x%x\n", hr);
1254 fmtetc.cfFormat = 0;
1255 fmtetc.dwAspect = DVASPECT_ICON;
1258 fmtetc.tymed = TYMED_MFPICT;
1259 hr = IOleCache_Cache(pOleCache, &fmtetc, 0, &dwConnection);
1260 ok(hr == CACHE_S_SAMECACHE, "IOleCache_Cache with already loaded data format type should return CACHE_S_SAMECACHE instead of 0x%x\n", hr);
1264 rcBounds.right = 100;
1265 rcBounds.bottom = 100;
1266 hdcMem = CreateCompatibleDC(NULL);
1268 hr = IViewObject_Draw(pViewObject, DVASPECT_ICON, -1, NULL, NULL, NULL, hdcMem, &rcBounds, NULL, draw_continue, 0xdeadbeef);
1269 ok_ole_success(hr, "IViewObject_Draw");
1271 hr = IViewObject_Draw(pViewObject, DVASPECT_CONTENT, -1, NULL, NULL, NULL, hdcMem, &rcBounds, NULL, draw_continue, 0xdeadbeef);
1272 ok(hr == OLE_E_BLANK, "IViewObject_Draw with uncached aspect should have returned OLE_E_BLANK instead of 0x%08x\n", hr);
1274 /* unload the cached storage object, causing it to be reloaded */
1275 hr = IOleCache2_DiscardCache(pOleCache, DISCARDCACHE_NOSAVE);
1276 ok_ole_success(hr, "IOleCache2_DiscardCache");
1277 hr = IViewObject_Draw(pViewObject, DVASPECT_ICON, -1, NULL, NULL, NULL, hdcMem, &rcBounds, NULL, draw_continue, 0xdeadbeef);
1278 ok_ole_success(hr, "IViewObject_Draw");
1280 /* unload the cached storage object, but don't allow it to be reloaded */
1281 hr = IPersistStorage_HandsOffStorage(pPS);
1282 ok_ole_success(hr, "IPersistStorage_HandsOffStorage");
1283 hr = IViewObject_Draw(pViewObject, DVASPECT_ICON, -1, NULL, NULL, NULL, hdcMem, &rcBounds, NULL, draw_continue, 0xdeadbeef);
1284 ok_ole_success(hr, "IViewObject_Draw");
1285 hr = IOleCache2_DiscardCache(pOleCache, DISCARDCACHE_NOSAVE);
1286 ok_ole_success(hr, "IOleCache2_DiscardCache");
1287 hr = IViewObject_Draw(pViewObject, DVASPECT_ICON, -1, NULL, NULL, NULL, hdcMem, &rcBounds, NULL, draw_continue, 0xdeadbeef);
1288 ok(hr == OLE_E_BLANK, "IViewObject_Draw with uncached aspect should have returned OLE_E_BLANK instead of 0x%08x\n", hr);
1293 hr = IOleCache_InitCache(pOleCache, &DataObject);
1294 ok(hr == CACHE_E_NOCACHE_UPDATED, "IOleCache_InitCache should have returned CACHE_E_NOCACHE_UPDATED instead of 0x%08x\n", hr);
1297 IPersistStorage_Release(pPS);
1298 IViewObject_Release(pViewObject);
1299 IOleCache_Release(pOleCache);
1302 ok(!*expected_method_list, "Method sequence starting from %s not called\n", *expected_method_list);
1305 IStorage_Release(pStorage);
1306 ReleaseStgMedium(&stgmedium);
1309 static void test_default_handler(void)
1312 IOleObject *pObject;
1313 IRunnableObject *pRunnableObject;
1314 IOleClientSite *pClientSite;
1315 IDataObject *pDataObject;
1319 LPOLESTR pszUserType;
1324 IOleInPlaceObject *pInPlaceObj;
1325 IEnumOLEVERB *pEnumVerbs;
1326 static const WCHAR wszUnknown[] = {'U','n','k','n','o','w','n',0};
1327 static const WCHAR wszHostName[] = {'W','i','n','e',' ','T','e','s','t',' ','P','r','o','g','r','a','m',0};
1328 static const WCHAR wszDelim[] = {'!',0};
1330 hr = CoCreateInstance(&CLSID_WineTest, NULL, CLSCTX_INPROC_HANDLER, &IID_IOleObject, (void **)&pObject);
1331 ok(hr == REGDB_E_CLASSNOTREG, "CoCreateInstance should have failed with REGDB_E_CLASSNOTREG instead of 0x%08x\n", hr);
1333 hr = OleCreateDefaultHandler(&CLSID_WineTest, NULL, &IID_IOleObject, (void **)&pObject);
1334 ok_ole_success(hr, "OleCreateDefaultHandler");
1336 hr = IOleObject_QueryInterface(pObject, &IID_IOleInPlaceObject, (void **)&pInPlaceObj);
1337 ok(hr == E_NOINTERFACE, "IOleObject_QueryInterface(&IID_IOleInPlaceObject) should return E_NOINTERFACE instead of 0x%08x\n", hr);
1339 hr = IOleObject_Advise(pObject, &AdviseSink, &dwAdvConn);
1340 ok_ole_success(hr, "IOleObject_Advise");
1342 hr = IOleObject_Close(pObject, OLECLOSE_NOSAVE);
1343 ok_ole_success(hr, "IOleObject_Close");
1345 /* FIXME: test IOleObject_EnumAdvise */
1347 hr = IOleObject_EnumVerbs(pObject, &pEnumVerbs);
1348 ok(hr == REGDB_E_CLASSNOTREG, "IOleObject_EnumVerbs should have returned REGDB_E_CLASSNOTREG instead of 0x%08x\n", hr);
1350 hr = IOleObject_GetClientSite(pObject, &pClientSite);
1351 ok_ole_success(hr, "IOleObject_GetClientSite");
1353 hr = IOleObject_GetClipboardData(pObject, 0, &pDataObject);
1354 ok(hr == OLE_E_NOTRUNNING,
1355 "IOleObject_GetClipboardData should have returned OLE_E_NOTRUNNING instead of 0x%08x\n",
1358 hr = IOleObject_GetExtent(pObject, DVASPECT_CONTENT, &sizel);
1359 ok(hr == OLE_E_BLANK, "IOleObject_GetExtent should have returned OLE_E_BLANK instead of 0x%08x\n",
1362 hr = IOleObject_GetMiscStatus(pObject, DVASPECT_CONTENT, &dwStatus);
1364 ok(hr == REGDB_E_CLASSNOTREG, "IOleObject_GetMiscStatus should have returned REGDB_E_CLASSNOTREG instead of 0x%08x\n", hr);
1366 hr = IOleObject_GetUserClassID(pObject, &clsid);
1367 ok_ole_success(hr, "IOleObject_GetUserClassID");
1368 ok(IsEqualCLSID(&clsid, &CLSID_WineTest), "clsid != CLSID_WineTest\n");
1370 hr = IOleObject_GetUserType(pObject, USERCLASSTYPE_FULL, &pszUserType);
1372 ok_ole_success(hr, "IOleObject_GetUserType");
1373 ok(!lstrcmpW(pszUserType, wszUnknown), "Retrieved user type was wrong\n");
1376 hr = IOleObject_InitFromData(pObject, NULL, TRUE, 0);
1377 ok(hr == OLE_E_NOTRUNNING, "IOleObject_InitFromData should have returned OLE_E_NOTRUNNING instead of 0x%08x\n", hr);
1379 hr = IOleObject_IsUpToDate(pObject);
1380 ok(hr == OLE_E_NOTRUNNING, "IOleObject_IsUpToDate should have returned OLE_E_NOTRUNNING instead of 0x%08x\n", hr);
1382 palette.palNumEntries = 1;
1383 palette.palVersion = 2;
1384 memset(&palette.palPalEntry[0], 0, sizeof(palette.palPalEntry[0]));
1385 hr = IOleObject_SetColorScheme(pObject, &palette);
1386 ok(hr == OLE_E_NOTRUNNING, "IOleObject_SetColorScheme should have returned OLE_E_NOTRUNNING instead of 0x%08x\n", hr);
1388 sizel.cx = sizel.cy = 0;
1389 hr = IOleObject_SetExtent(pObject, DVASPECT_CONTENT, &sizel);
1391 hr = IOleObject_SetHostNames(pObject, wszHostName, NULL);
1392 ok_ole_success(hr, "IOleObject_SetHostNames");
1394 hr = CreateItemMoniker(wszDelim, wszHostName, &pMoniker);
1395 ok_ole_success(hr, "CreateItemMoniker");
1396 hr = IOleObject_SetMoniker(pObject, OLEWHICHMK_CONTAINER, pMoniker);
1397 ok_ole_success(hr, "IOleObject_SetMoniker");
1399 hr = IOleObject_GetMoniker(pObject, OLEGETMONIKER_ONLYIFTHERE, OLEWHICHMK_CONTAINER, &pMoniker);
1400 ok(hr == E_FAIL, "IOleObject_GetMoniker should have returned E_FAIL instead of 0x%08x\n", hr);
1402 hr = IOleObject_Update(pObject);
1404 ok(hr == REGDB_E_CLASSNOTREG, "IOleObject_Update should have returned REGDB_E_CLASSNOTREG instead of 0x%08x\n", hr);
1406 hr = IOleObject_QueryInterface(pObject, &IID_IDataObject, (void **)&pDataObject);
1407 ok_ole_success(hr, "IOleObject_QueryInterface");
1409 fmtetc.cfFormat = CF_TEXT;
1411 fmtetc.dwAspect = DVASPECT_CONTENT;
1413 fmtetc.tymed = TYMED_NULL;
1414 hr = IDataObject_DAdvise(pDataObject, &fmtetc, 0, &AdviseSink, &dwAdvConn);
1415 ok_ole_success(hr, "IDataObject_DAdvise");
1417 fmtetc.cfFormat = CF_ENHMETAFILE;
1419 fmtetc.dwAspect = DVASPECT_CONTENT;
1421 fmtetc.tymed = TYMED_ENHMF;
1422 hr = IDataObject_DAdvise(pDataObject, &fmtetc, 0, &AdviseSink, &dwAdvConn);
1423 ok_ole_success(hr, "IDataObject_DAdvise");
1425 fmtetc.cfFormat = CF_ENHMETAFILE;
1427 fmtetc.dwAspect = DVASPECT_CONTENT;
1429 fmtetc.tymed = TYMED_ENHMF;
1430 hr = IDataObject_QueryGetData(pDataObject, &fmtetc);
1432 ok(hr == OLE_E_NOTRUNNING, "IDataObject_QueryGetData should have returned OLE_E_NOTRUNNING instead of 0x%08x\n", hr);
1434 fmtetc.cfFormat = CF_TEXT;
1436 fmtetc.dwAspect = DVASPECT_CONTENT;
1438 fmtetc.tymed = TYMED_NULL;
1439 hr = IDataObject_QueryGetData(pDataObject, &fmtetc);
1441 ok(hr == OLE_E_NOTRUNNING, "IDataObject_QueryGetData should have returned OLE_E_NOTRUNNING instead of 0x%08x\n", hr);
1443 hr = IOleObject_QueryInterface(pObject, &IID_IRunnableObject, (void **)&pRunnableObject);
1444 ok_ole_success(hr, "IOleObject_QueryInterface");
1446 hr = IRunnableObject_SetContainedObject(pRunnableObject, TRUE);
1447 ok_ole_success(hr, "IRunnableObject_SetContainedObject");
1449 hr = IRunnableObject_Run(pRunnableObject, NULL);
1450 ok(hr == REGDB_E_CLASSNOTREG, "IOleObject_Run should have returned REGDB_E_CLASSNOTREG instead of 0x%08x\n", hr);
1452 hr = IOleObject_Close(pObject, OLECLOSE_NOSAVE);
1453 ok_ole_success(hr, "IOleObject_Close");
1455 IRunnableObject_Release(pRunnableObject);
1456 IOleObject_Release(pObject);
1459 void test_runnable(void)
1461 static const char *methods_query_runnable[] =
1463 "OleObject_QueryInterface",
1464 "OleObjectRunnable_AddRef",
1465 "OleObjectRunnable_IsRunning",
1466 "OleObjectRunnable_Release",
1470 static const char *methods_no_runnable[] =
1472 "OleObject_QueryInterface",
1476 IOleObject *object = (IOleObject *)&OleObject;
1478 expected_method_list = methods_query_runnable;
1479 ok(OleIsRunning(object), "Object should be running\n");
1480 ok(!*expected_method_list, "Method sequence starting from %s not called\n", *expected_method_list);
1482 g_isRunning = FALSE;
1483 expected_method_list = methods_query_runnable;
1484 ok(OleIsRunning(object) == FALSE, "Object should not be running\n");
1485 ok(!*expected_method_list, "Method sequence starting from %s not called\n", *expected_method_list);
1487 g_showRunnable = FALSE; /* QueryInterface(IID_IRunnableObject, ...) will fail */
1488 expected_method_list = methods_no_runnable;
1489 ok(OleIsRunning(object), "Object without IRunnableObject should be running\n");
1490 ok(!*expected_method_list, "Method sequence starting from %s not called\n", *expected_method_list);
1493 g_showRunnable = TRUE;
1505 hr = CoRegisterClassObject(&CLSID_Equation3, (IUnknown *)&OleObjectCF, CLSCTX_INPROC_SERVER, REGCLS_MULTIPLEUSE, &dwRegister);
1506 ok_ole_success(hr, "CoRegisterClassObject");
1508 hr = StgCreateDocfile(NULL, STGM_READWRITE | STGM_CREATE | STGM_SHARE_EXCLUSIVE | STGM_DELETEONRELEASE, 0, &pStorage);
1509 ok_ole_success(hr, "StgCreateDocfile");
1511 test_OleCreate(pStorage);
1513 hr = IStorage_Stat(pStorage, &statstg, STATFLAG_NONAME);
1514 ok_ole_success(hr, "IStorage_Stat");
1515 ok(IsEqualCLSID(&CLSID_Equation3, &statstg.clsid), "Wrong CLSID in storage\n");
1517 test_OleLoad(pStorage);
1519 IStorage_Release(pStorage);
1521 hr = CoRevokeClassObject(dwRegister);
1522 ok_ole_success(hr, "CoRevokeClassObject");
1525 test_default_handler();