ole32: Allow some optional methods to be called in the OleCreate tests.

Fixes failures in these tests on NT4.
This commit is contained in:
Rob Shearman 2009-02-08 18:03:27 +00:00 committed by Alexandre Julliard
parent d26250fd08
commit b859d2052b
1 changed files with 22 additions and 2 deletions

View File

@ -683,10 +683,14 @@ static void test_OleCreate(IStorage *pStorage)
{ "OleObject_QueryInterface", 0 }, { "OleObject_QueryInterface", 0 },
{ "OleObject_AddRef", 0 }, { "OleObject_AddRef", 0 },
{ "OleObject_QueryInterface", 0 }, { "OleObject_QueryInterface", 0 },
{ "OleObject_AddRef", TEST_OPTIONAL },
{ "OleObject_Release", TEST_OPTIONAL },
{ "OleObject_QueryInterface", TEST_OPTIONAL },
{ "OleObjectPersistStg_AddRef", 0 }, { "OleObjectPersistStg_AddRef", 0 },
{ "OleObjectPersistStg_InitNew", 0 }, { "OleObjectPersistStg_InitNew", 0 },
{ "OleObjectPersistStg_Release", 0 }, { "OleObjectPersistStg_Release", 0 },
{ "OleObject_Release", 0 }, { "OleObject_Release", 0 },
{ "OleObject_Release", TEST_OPTIONAL },
{ NULL, 0 } { NULL, 0 }
}; };
static const struct expected_method methods_olerender_draw[] = static const struct expected_method methods_olerender_draw[] =
@ -694,6 +698,9 @@ static void test_OleCreate(IStorage *pStorage)
{ "OleObject_QueryInterface", 0 }, { "OleObject_QueryInterface", 0 },
{ "OleObject_AddRef", 0 }, { "OleObject_AddRef", 0 },
{ "OleObject_QueryInterface", 0 }, { "OleObject_QueryInterface", 0 },
{ "OleObject_AddRef", TEST_OPTIONAL /* NT4 only */ },
{ "OleObject_Release", TEST_OPTIONAL /* NT4 only */ },
{ "OleObject_QueryInterface", TEST_OPTIONAL /* NT4 only */ },
{ "OleObjectPersistStg_AddRef", 0 }, { "OleObjectPersistStg_AddRef", 0 },
{ "OleObjectPersistStg_InitNew", 0 }, { "OleObjectPersistStg_InitNew", 0 },
{ "OleObjectPersistStg_Release", 0 }, { "OleObjectPersistStg_Release", 0 },
@ -706,6 +713,7 @@ static void test_OleCreate(IStorage *pStorage)
{ "OleObjectCache_Cache", 0 }, { "OleObjectCache_Cache", 0 },
{ "OleObjectCache_Release", 0 }, { "OleObjectCache_Release", 0 },
{ "OleObject_Release", 0 }, { "OleObject_Release", 0 },
{ "OleObject_Release", TEST_OPTIONAL /* NT4 only */ },
{ NULL, 0 } { NULL, 0 }
}; };
static const struct expected_method methods_olerender_format[] = static const struct expected_method methods_olerender_format[] =
@ -737,10 +745,14 @@ static void test_OleCreate(IStorage *pStorage)
{ "OleObject_QueryInterface", 0 }, { "OleObject_QueryInterface", 0 },
{ "OleObject_AddRef", 0 }, { "OleObject_AddRef", 0 },
{ "OleObject_QueryInterface", 0 }, { "OleObject_QueryInterface", 0 },
{ "OleObject_AddRef", TEST_OPTIONAL /* NT4 only */ },
{ "OleObject_Release", TEST_OPTIONAL /* NT4 only */ },
{ "OleObject_QueryInterface", TEST_OPTIONAL /* NT4 only */ },
{ "OleObjectPersistStg_AddRef", 0 }, { "OleObjectPersistStg_AddRef", 0 },
{ "OleObjectPersistStg_InitNew", 0 }, { "OleObjectPersistStg_InitNew", 0 },
{ "OleObjectPersistStg_Release", 0 }, { "OleObjectPersistStg_Release", 0 },
{ "OleObject_Release", 0 }, { "OleObject_Release", 0 },
{ "OleObject_Release", TEST_OPTIONAL /* NT4 only */ },
{ NULL, 0 } { NULL, 0 }
}; };
static const struct expected_method methods_olerender_draw_no_runnable[] = static const struct expected_method methods_olerender_draw_no_runnable[] =
@ -748,6 +760,9 @@ static void test_OleCreate(IStorage *pStorage)
{ "OleObject_QueryInterface", 0 }, { "OleObject_QueryInterface", 0 },
{ "OleObject_AddRef", 0 }, { "OleObject_AddRef", 0 },
{ "OleObject_QueryInterface", 0 }, { "OleObject_QueryInterface", 0 },
{ "OleObject_AddRef", TEST_OPTIONAL /* NT4 only */ },
{ "OleObject_Release", TEST_OPTIONAL /* NT4 only */ },
{ "OleObject_QueryInterface", TEST_OPTIONAL /* NT4 only */ },
{ "OleObjectPersistStg_AddRef", 0 }, { "OleObjectPersistStg_AddRef", 0 },
{ "OleObjectPersistStg_InitNew", 0 }, { "OleObjectPersistStg_InitNew", 0 },
{ "OleObjectPersistStg_Release", 0 }, { "OleObjectPersistStg_Release", 0 },
@ -757,6 +772,7 @@ static void test_OleCreate(IStorage *pStorage)
{ "OleObjectCache_Cache", 0 }, { "OleObjectCache_Cache", 0 },
{ "OleObjectCache_Release", 0 }, { "OleObjectCache_Release", 0 },
{ "OleObject_Release", 0 }, { "OleObject_Release", 0 },
{ "OleObject_Release", TEST_OPTIONAL /* NT4 only */ },
{ NULL, 0 }, { NULL, 0 },
}; };
static const struct expected_method methods_olerender_draw_no_cache[] = static const struct expected_method methods_olerender_draw_no_cache[] =
@ -764,6 +780,9 @@ static void test_OleCreate(IStorage *pStorage)
{ "OleObject_QueryInterface", 0 }, { "OleObject_QueryInterface", 0 },
{ "OleObject_AddRef", 0 }, { "OleObject_AddRef", 0 },
{ "OleObject_QueryInterface", 0 }, { "OleObject_QueryInterface", 0 },
{ "OleObject_AddRef", TEST_OPTIONAL /* NT4 only */ },
{ "OleObject_Release", TEST_OPTIONAL /* NT4 only */ },
{ "OleObject_QueryInterface", TEST_OPTIONAL /* NT4 only */ },
{ "OleObjectPersistStg_AddRef", 0 }, { "OleObjectPersistStg_AddRef", 0 },
{ "OleObjectPersistStg_InitNew", 0 }, { "OleObjectPersistStg_InitNew", 0 },
{ "OleObjectPersistStg_Release", 0 }, { "OleObjectPersistStg_Release", 0 },
@ -773,6 +792,7 @@ static void test_OleCreate(IStorage *pStorage)
{ "OleObjectRunnable_Release", 0 }, { "OleObjectRunnable_Release", 0 },
{ "OleObject_QueryInterface", 0 }, { "OleObject_QueryInterface", 0 },
{ "OleObject_Release", 0 }, { "OleObject_Release", 0 },
{ "OleObject_Release", TEST_OPTIONAL /* NT4 only */ },
{ NULL, 0 } { NULL, 0 }
}; };
@ -818,7 +838,7 @@ static void test_OleCreate(IStorage *pStorage)
runnable = NULL; runnable = NULL;
expected_method_list = methods_olerender_draw_no_runnable; expected_method_list = methods_olerender_draw_no_runnable;
trace("OleCreate with OLERENDER_DRAW (no IOlObjectRunnable):\n"); trace("OleCreate with OLERENDER_DRAW (no IRunnableObject):\n");
hr = OleCreate(&CLSID_Equation3, &IID_IOleObject, OLERENDER_DRAW, NULL, NULL, pStorage, (void **)&pObject); hr = OleCreate(&CLSID_Equation3, &IID_IOleObject, OLERENDER_DRAW, NULL, NULL, pStorage, (void **)&pObject);
ok_ole_success(hr, "OleCreate"); ok_ole_success(hr, "OleCreate");
IOleObject_Release(pObject); IOleObject_Release(pObject);
@ -827,7 +847,7 @@ static void test_OleCreate(IStorage *pStorage)
runnable = &OleObjectRunnable; runnable = &OleObjectRunnable;
cache = NULL; cache = NULL;
expected_method_list = methods_olerender_draw_no_cache; expected_method_list = methods_olerender_draw_no_cache;
trace("OleCreate with OLERENDER_DRAW (no IOlObjectRunnable):\n"); trace("OleCreate with OLERENDER_DRAW (no IOleCache):\n");
hr = OleCreate(&CLSID_Equation3, &IID_IOleObject, OLERENDER_DRAW, NULL, NULL, pStorage, (void **)&pObject); hr = OleCreate(&CLSID_Equation3, &IID_IOleObject, OLERENDER_DRAW, NULL, NULL, pStorage, (void **)&pObject);
ok_ole_success(hr, "OleCreate"); ok_ole_success(hr, "OleCreate");
IOleObject_Release(pObject); IOleObject_Release(pObject);