Module: wine Branch: master Commit: 98923665105334ca6aaf39a756b62da606ecc861 URL: http://source.winehq.org/git/wine.git/?a=commit;h=98923665105334ca6aaf39a756...
Author: Fabian Maurer dark.shadow4@web.de Date: Wed Sep 20 14:03:36 2017 +0200
evr/tests: Add tests.
Signed-off-by: Fabian Maurer dark.shadow4@web.de Signed-off-by: Alexandre Julliard julliard@winehq.org
---
configure | 1 + configure.ac | 1 + dlls/evr/tests/Makefile.in | 5 ++ dlls/evr/tests/filter.c | 185 +++++++++++++++++++++++++++++++++++++++++++++ 4 files changed, 192 insertions(+)
diff --git a/configure b/configure index 8f20593..f53bea5 100755 --- a/configure +++ b/configure @@ -18339,6 +18339,7 @@ wine_fn_config_lib dxguid wine_fn_config_dll dxva2 enable_dxva2 wine_fn_config_dll esent enable_esent wine_fn_config_dll evr enable_evr +wine_fn_config_test dlls/evr/tests evr_test wine_fn_config_dll explorerframe enable_explorerframe clean wine_fn_config_test dlls/explorerframe/tests explorerframe_test wine_fn_config_dll ext-ms-win-authz-context-l1-1-0 enable_ext_ms_win_authz_context_l1_1_0 diff --git a/configure.ac b/configure.ac index 54c1024..edeeb0d 100644 --- a/configure.ac +++ b/configure.ac @@ -3122,6 +3122,7 @@ WINE_CONFIG_LIB(dxguid) WINE_CONFIG_DLL(dxva2) WINE_CONFIG_DLL(esent) WINE_CONFIG_DLL(evr) +WINE_CONFIG_TEST(dlls/evr/tests) WINE_CONFIG_DLL(explorerframe,,[clean]) WINE_CONFIG_TEST(dlls/explorerframe/tests) WINE_CONFIG_DLL(ext-ms-win-authz-context-l1-1-0) diff --git a/dlls/evr/tests/Makefile.in b/dlls/evr/tests/Makefile.in new file mode 100644 index 0000000..c370646 --- /dev/null +++ b/dlls/evr/tests/Makefile.in @@ -0,0 +1,5 @@ +TESTDLL = evr.dll +IMPORTS = mfuuid strmiids strmbase uuid ole32 oleaut32 + +C_SRCS = \ + filter.c diff --git a/dlls/evr/tests/filter.c b/dlls/evr/tests/filter.c new file mode 100644 index 0000000..4f82b14 --- /dev/null +++ b/dlls/evr/tests/filter.c @@ -0,0 +1,185 @@ +/* + * Copyright 2017 Fabian Maurer + * + * 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 + */ + +#define COBJMACROS + +#include <stdio.h> + +#include "dshow.h" +#include "evr.h" +#include "d3d9.h" +#include "initguid.h" +#include "dxva2api.h" + +#include "wine/test.h" + +#define QI_SUCCEED(iface, riid, ppv) hr = IUnknown_QueryInterface(iface, &riid, (LPVOID*)&ppv); \ + ok(hr == S_OK, "%s: run %d: IUnknown_QueryInterface returned %x\n", testid, testrun, hr); \ + ok(ppv != NULL, "%s: run %d: Pointer is NULL\n", testid, testrun); + +#define QI_FAIL(iface, riid, ppv) hr = IUnknown_QueryInterface(iface, &riid, (LPVOID*)&ppv); \ + ok(hr == E_NOINTERFACE, "%s: run %d: IUnknown_QueryInterface returned %x\n", testid, testrun, hr); \ + ok(ppv == NULL, "%s: run %d: Pointer is %p\n", testid, testrun, ppv); + +#define ADDREF_EXPECT(iface, num) if (iface) { \ + refCount = IUnknown_AddRef(iface); \ + ok(refCount == num, "%s: run %d: IUnknown_AddRef should return %d, got %d\n", testid, testrun, num, refCount); \ +} + +#define RELEASE_EXPECT(iface, num) if (iface) { \ + refCount = IUnknown_Release(iface); \ + ok(refCount == num, "%s: run %d: IUnknown_Release should return %d, got %d\n", testid, testrun, num, refCount); \ +} + +static void test_aggregation(const CLSID clsid_inner, const IID iid_inner, const char *testid, int testrun) +{ + const CLSID clsid_outer = CLSID_SystemClock; + const IID iid_outer = IID_IReferenceClock; + HRESULT hr; + ULONG refCount; + IUnknown *unk_outer = NULL; + IUnknown *unk_inner = NULL; + IUnknown *unk_inner_fail = NULL; + IUnknown *unk_outer_test = NULL; + IUnknown *unk_inner_test = NULL; + IUnknown *unk_aggregatee = NULL; + IUnknown *unk_aggregator = NULL; + IUnknown *unk_test = NULL; + + hr = CoCreateInstance(&clsid_outer, NULL, CLSCTX_INPROC_SERVER, &IID_IUnknown, (LPVOID*)&unk_outer); + ok(hr == S_OK, "%s: run %d: First CoCreateInstance failed with %x\n", testid, testrun, hr); + ok(unk_outer != NULL, "%s: run %d: unk_outer is NULL\n", testid, testrun); + + if (!unk_outer) + { + skip("%s: run %d: unk_outer is NULL\n", testid, testrun); + return; + } + + /* for aggregation, we should only be able to request IUnknown */ + hr = CoCreateInstance(&clsid_inner, unk_outer, CLSCTX_INPROC_SERVER, &iid_inner, (LPVOID*)&unk_inner_fail); + if (hr == REGDB_E_CLASSNOTREG) + { + skip("%s: run %d: Class not registered\n", testid, testrun); + return; + } + ok(hr == E_NOINTERFACE, "%s: run %d: Second CoCreateInstance returned %x\n", testid, testrun, hr); + ok(unk_inner_fail == NULL, "%s: run %d: unk_inner_fail is not NULL\n", testid, testrun); + + /* aggregation, request IUnknown */ + hr = CoCreateInstance(&clsid_inner, unk_outer, CLSCTX_INPROC_SERVER, &IID_IUnknown, (LPVOID*)&unk_inner); + ok(hr == S_OK, "%s: run %d: Third CoCreateInstance returned %x\n", testid, testrun, hr); + ok(unk_inner != NULL, "%s: run %d: unk_inner is NULL\n", testid, testrun); + + if (!unk_inner) + { + skip("%s: run %d: unk_inner is NULL\n", testid, testrun); + return; + } + + ADDREF_EXPECT(unk_outer, 2); + ADDREF_EXPECT(unk_inner, 2); + RELEASE_EXPECT(unk_outer, 1); + RELEASE_EXPECT(unk_inner, 1); + + QI_FAIL(unk_outer, iid_inner, unk_aggregatee); + QI_FAIL(unk_inner, iid_outer, unk_aggregator); + + QI_SUCCEED(unk_outer, iid_outer, unk_aggregator); + QI_SUCCEED(unk_outer, IID_IUnknown, unk_outer_test); + QI_SUCCEED(unk_inner, iid_inner, unk_aggregatee); + QI_SUCCEED(unk_inner, IID_IUnknown, unk_inner_test); + + if (!unk_aggregator || !unk_outer_test || !unk_aggregatee || !unk_inner_test) + { + skip("%s: run %d: One of the required interfaces is NULL\n", testid, testrun); + return; + } + + ADDREF_EXPECT(unk_aggregator, 5); + ADDREF_EXPECT(unk_outer_test, 6); + ADDREF_EXPECT(unk_aggregatee, 7); + ADDREF_EXPECT(unk_inner_test, 3); + RELEASE_EXPECT(unk_aggregator, 6); + RELEASE_EXPECT(unk_outer_test, 5); + RELEASE_EXPECT(unk_aggregatee, 4); + RELEASE_EXPECT(unk_inner_test, 2); + + QI_SUCCEED(unk_aggregator, IID_IUnknown, unk_test); + QI_SUCCEED(unk_outer_test, IID_IUnknown, unk_test); + QI_SUCCEED(unk_aggregatee, IID_IUnknown, unk_test); + QI_SUCCEED(unk_inner_test, IID_IUnknown, unk_test); + + QI_FAIL(unk_aggregator, iid_inner, unk_test); + QI_FAIL(unk_outer_test, iid_inner, unk_test); + QI_FAIL(unk_aggregatee, iid_inner, unk_test); + QI_SUCCEED(unk_inner_test, iid_inner, unk_test); + + QI_SUCCEED(unk_aggregator, iid_outer, unk_test); + QI_SUCCEED(unk_outer_test, iid_outer, unk_test); + QI_SUCCEED(unk_aggregatee, iid_outer, unk_test); + QI_FAIL(unk_inner_test, iid_outer, unk_test); + + RELEASE_EXPECT(unk_aggregator, 10); + RELEASE_EXPECT(unk_outer_test, 9); + RELEASE_EXPECT(unk_aggregatee, 8); + RELEASE_EXPECT(unk_inner_test, 2); + RELEASE_EXPECT(unk_outer, 7); + RELEASE_EXPECT(unk_inner, 1); + + do + { + refCount = IUnknown_Release(unk_inner); + } while (refCount); + + do + { + refCount = IUnknown_Release(unk_outer); + } while (refCount); +} + +static void test_evr_filter_aggregations(void) +{ + const IID * iids[] = { + &IID_IAMCertifiedOutputProtection, &IID_IAMFilterMiscFlags, &IID_IBaseFilter, + &IID_IKsPropertySet, &IID_IMediaEventSink, &IID_IMediaSeeking, &IID_IQualityControl, + &IID_IQualProp, &IID_IEVRFilterConfig, &IID_IMFGetService, &IID_IMFVideoPositionMapper, + &IID_IMFVideoRenderer, &IID_IQualityControl + }; + int i; + + if(!strcmp(winetest_platform, "wine")) + { + skip("Not supported yet.\n"); + return; + } + + for (i = 0; i < sizeof(iids) / sizeof(iids[0]); i++) + { + test_aggregation(CLSID_EnhancedVideoRenderer, *iids[i], "filter", i); + } +} + +START_TEST(filter) +{ + CoInitialize(NULL); + + test_evr_filter_aggregations(); + + CoUninitialize(); +}