qcap: Add initial ICaptureGraphBuilder2::RenderStream tests.

This commit is contained in:
Piotr Caban 2013-11-20 12:02:29 +01:00 committed by Alexandre Julliard
parent f810d14149
commit 2b1befb9a0
1 changed files with 822 additions and 0 deletions

View File

@ -31,6 +31,18 @@
#include "wine/strmbase.h"
#include "wine/test.h"
static const char *debugstr_guid(REFIID riid)
{
static char buf[50];
sprintf(buf, "{%08X-%04X-%04X-%02X%02X-%02X%02X%02X%02X%02X%02X}",
riid->Data1, riid->Data2, riid->Data3, riid->Data4[0],
riid->Data4[1], riid->Data4[2], riid->Data4[3], riid->Data4[4],
riid->Data4[5], riid->Data4[6], riid->Data4[7]);
return buf;
}
static void test_smart_tee_filter(void)
{
HRESULT hr;
@ -100,11 +112,821 @@ end:
IEnumPins_Release(enumPins);
}
typedef enum {
SOURCE_FILTER,
SINK_FILTER,
INTERMEDIATE_FILTER,
NOT_FILTER
} filter_type;
static const char* debugstr_filter_type(filter_type type)
{
switch(type) {
case SOURCE_FILTER:
return "SOURCE_FILTER";
case SINK_FILTER:
return "SINK_FILTER";
case INTERMEDIATE_FILTER:
return "INTERMEDIATE_FILTER";
default:
return "NOT_FILTER";
}
}
typedef enum {
BASEFILTER_ENUMPINS,
ENUMPINS_NEXT,
PIN_QUERYDIRECTION,
PIN_CONNECTEDTO,
PIN_QUERYPININFO,
KSPROPERTYSET_GET,
PIN_ENUMMEDIATYPES,
ENUMMEDIATYPES_RESET,
ENUMMEDIATYPES_NEXT,
GRAPHBUILDER_CONNECT,
BASEFILTER_GETSTATE,
BASEFILTER_QUERYINTERFACE,
END
} call_id;
static const struct {
call_id call_id;
filter_type filter_type;
BOOL wine_missing;
BOOL wine_extra;
} renderstream_cat_media[] = {
{BASEFILTER_QUERYINTERFACE, SOURCE_FILTER},
{BASEFILTER_ENUMPINS, SOURCE_FILTER},
{ENUMPINS_NEXT, SOURCE_FILTER},
{PIN_QUERYDIRECTION, SOURCE_FILTER},
{PIN_CONNECTEDTO, SOURCE_FILTER},
{PIN_QUERYPININFO, SOURCE_FILTER, TRUE},
{KSPROPERTYSET_GET, SOURCE_FILTER},
{PIN_ENUMMEDIATYPES, SOURCE_FILTER},
{ENUMMEDIATYPES_RESET, SOURCE_FILTER},
{ENUMMEDIATYPES_NEXT, SOURCE_FILTER},
{BASEFILTER_QUERYINTERFACE, SOURCE_FILTER},
{BASEFILTER_ENUMPINS, SOURCE_FILTER},
{ENUMPINS_NEXT, SOURCE_FILTER},
{PIN_QUERYDIRECTION, SOURCE_FILTER},
{PIN_CONNECTEDTO, SOURCE_FILTER},
{PIN_QUERYPININFO, SOURCE_FILTER, TRUE},
{KSPROPERTYSET_GET, SOURCE_FILTER},
{ENUMPINS_NEXT, SOURCE_FILTER},
{BASEFILTER_QUERYINTERFACE, SOURCE_FILTER, TRUE},
{BASEFILTER_ENUMPINS, SOURCE_FILTER, TRUE},
{ENUMPINS_NEXT, SOURCE_FILTER, TRUE},
{PIN_QUERYDIRECTION, SOURCE_FILTER, TRUE},
{PIN_CONNECTEDTO, SOURCE_FILTER, TRUE},
{PIN_QUERYPININFO, SOURCE_FILTER, TRUE},
{KSPROPERTYSET_GET, SOURCE_FILTER, TRUE},
{ENUMPINS_NEXT, SOURCE_FILTER, TRUE},
{BASEFILTER_QUERYINTERFACE, SOURCE_FILTER, TRUE},
{BASEFILTER_ENUMPINS, SOURCE_FILTER, TRUE},
{ENUMPINS_NEXT, SOURCE_FILTER, TRUE},
{PIN_QUERYDIRECTION, SOURCE_FILTER, TRUE},
{PIN_CONNECTEDTO, SOURCE_FILTER, TRUE},
{PIN_QUERYPININFO, SOURCE_FILTER, TRUE},
{KSPROPERTYSET_GET, SOURCE_FILTER, TRUE},
{ENUMPINS_NEXT, SOURCE_FILTER, TRUE},
{PIN_ENUMMEDIATYPES, SOURCE_FILTER, TRUE},
{ENUMMEDIATYPES_NEXT, SOURCE_FILTER, TRUE},
{BASEFILTER_QUERYINTERFACE, SINK_FILTER, FALSE, TRUE},
{BASEFILTER_ENUMPINS, SINK_FILTER},
{ENUMPINS_NEXT, SINK_FILTER},
{PIN_QUERYDIRECTION, SINK_FILTER},
{PIN_CONNECTEDTO, SINK_FILTER},
{GRAPHBUILDER_CONNECT, NOT_FILTER},
{BASEFILTER_GETSTATE, SOURCE_FILTER, TRUE},
{END, NOT_FILTER}
}, *current_calls_list;
int call_no;
static void check_calls_list(const char *func, call_id id, filter_type type)
{
while(current_calls_list[call_no].wine_missing || current_calls_list[call_no].wine_extra) {
if(current_calls_list[call_no].wine_missing) {
todo_wine ok(current_calls_list[call_no].call_id == id && current_calls_list[call_no].filter_type == type,
"missing call, got %s(%d), expected %d\n", func, id, current_calls_list[call_no].call_id);
if(current_calls_list[call_no].call_id != id || current_calls_list[call_no].filter_type != type)
call_no++;
else
break;
}else {
todo_wine ok(current_calls_list[call_no].call_id != id || current_calls_list[call_no].filter_type != type,
"extra call, got %s(%d)\n", func, id);
if(current_calls_list[call_no].call_id == id && current_calls_list[call_no].filter_type == type) {
call_no++;
return;
}
call_no++;
}
}
ok(current_calls_list[call_no].call_id == id, "unexpected call: %s on %s (%d)\n",
func, debugstr_filter_type(type), call_no);
if(current_calls_list[call_no].call_id != id)
return;
ok(current_calls_list[call_no].filter_type == type, "unexpected call: %s on %s (%d)\n",
func, debugstr_filter_type(type), call_no);
if(current_calls_list[call_no].filter_type != type)
return;
call_no++;
}
static HRESULT WINAPI GraphBuilder_QueryInterface(
IGraphBuilder *iface, REFIID riid, void **ppv)
{
if(IsEqualIID(riid, &IID_IUnknown) || IsEqualIID(riid, &IID_IFilterGraph)
|| IsEqualIID(riid, &IID_IGraphBuilder))
{
*ppv = iface;
return S_OK;
}
ok(IsEqualIID(riid, &IID_IMediaEvent), "QueryInterface(%s)\n", debugstr_guid(riid));
*ppv = NULL;
return E_NOINTERFACE;
}
static ULONG WINAPI GraphBuilder_AddRef(IGraphBuilder *iface)
{
return 2;
}
static ULONG WINAPI GraphBuilder_Release(IGraphBuilder *iface)
{
return 1;
}
static HRESULT WINAPI GraphBuilder_AddFilter(IGraphBuilder *iface,
IBaseFilter *pFilter, LPCWSTR pName)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI GraphBuilder_RemoveFilter(
IGraphBuilder *iface, IBaseFilter *pFilter)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI GraphBuilder_EnumFilters(
IGraphBuilder *iface, IEnumFilters **ppEnum)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI GraphBuilder_FindFilterByName(IGraphBuilder *iface,
LPCWSTR pName, IBaseFilter **ppFilter)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI GraphBuilder_ConnectDirect(IGraphBuilder *iface,
IPin *ppinOut, IPin *ppinIn, const AM_MEDIA_TYPE *pmt)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI GraphBuilder_Reconnect(IGraphBuilder *iface, IPin *ppin)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI GraphBuilder_Disconnect(IGraphBuilder *iface, IPin *ppin)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI GraphBuilder_SetDefaultSyncSource(IGraphBuilder *iface)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI GraphBuilder_Connect(IGraphBuilder *iface, IPin *ppinOut, IPin *ppinIn)
{
check_calls_list("GraphBuilder_Connect", GRAPHBUILDER_CONNECT, NOT_FILTER);
return S_OK;
}
static HRESULT WINAPI GraphBuilder_Render(IGraphBuilder *iface, IPin *ppinOut)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI GraphBuilder_RenderFile(IGraphBuilder *iface,
LPCWSTR lpcwstrFile, LPCWSTR lpcwstrPlayList)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI GraphBuilder_AddSourceFilter(IGraphBuilder *iface, LPCWSTR lpcwstrFileName,
LPCWSTR lpcwstrFilterName, IBaseFilter **ppFilter)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI GraphBuilder_SetLogFile(IGraphBuilder *iface, DWORD_PTR hFile)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI GraphBuilder_Abort(IGraphBuilder *iface)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI GraphBuilder_ShouldOperationContinue(IGraphBuilder *iface)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static IGraphBuilderVtbl GraphBuilder_vtbl = {
GraphBuilder_QueryInterface,
GraphBuilder_AddRef,
GraphBuilder_Release,
GraphBuilder_AddFilter,
GraphBuilder_RemoveFilter,
GraphBuilder_EnumFilters,
GraphBuilder_FindFilterByName,
GraphBuilder_ConnectDirect,
GraphBuilder_Reconnect,
GraphBuilder_Disconnect,
GraphBuilder_SetDefaultSyncSource,
GraphBuilder_Connect,
GraphBuilder_Render,
GraphBuilder_RenderFile,
GraphBuilder_AddSourceFilter,
GraphBuilder_SetLogFile,
GraphBuilder_Abort,
GraphBuilder_ShouldOperationContinue
};
static IGraphBuilder GraphBuilder = {&GraphBuilder_vtbl};
typedef struct {
IBaseFilter IBaseFilter_iface;
IEnumPins IEnumPins_iface;
IPin IPin_iface;
IKsPropertySet IKsPropertySet_iface;
IEnumMediaTypes IEnumMediaTypes_iface;
PIN_DIRECTION dir;
filter_type filter_type;
int enum_pins_pos;
int enum_media_types_pos;
} test_filter;
static test_filter* impl_from_IBaseFilter(IBaseFilter *iface)
{
return CONTAINING_RECORD(iface, test_filter, IBaseFilter_iface);
}
static HRESULT WINAPI BaseFilter_QueryInterface(IBaseFilter *iface, REFIID riid, void **ppv)
{
test_filter *This = impl_from_IBaseFilter(iface);
if(IsEqualIID(riid, &IID_IUnknown) || IsEqualIID(riid, &IID_IPersist)
|| IsEqualIID(riid, &IID_IMediaFilter) || IsEqualIID(riid, &IID_IBaseFilter)) {
*ppv = iface;
return S_OK;
}
check_calls_list("BaseFilter_QueryInterface", BASEFILTER_QUERYINTERFACE, This->filter_type);
ok(IsEqualIID(riid, &IID_IPin), "riid = %s\n", debugstr_guid(riid));
return E_NOINTERFACE;
}
static ULONG WINAPI BaseFilter_AddRef(IBaseFilter *iface)
{
return 2;
}
static ULONG WINAPI BaseFilter_Release(IBaseFilter *iface)
{
return 1;
}
static HRESULT WINAPI BaseFilter_GetClassID(IBaseFilter *iface, CLSID *pClassID)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI BaseFilter_Stop(IBaseFilter *iface)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI BaseFilter_Pause(IBaseFilter *iface)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI BaseFilter_Run(IBaseFilter *iface, REFERENCE_TIME tStart)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI BaseFilter_GetState(IBaseFilter *iface,
DWORD dwMilliSecsTimeout, FILTER_STATE *State)
{
test_filter *This = impl_from_IBaseFilter(iface);
check_calls_list("BaseFilter_GetState", BASEFILTER_GETSTATE, This->filter_type);
return E_NOTIMPL;
}
static HRESULT WINAPI BaseFilter_SetSyncSource(
IBaseFilter *iface, IReferenceClock *pClock)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI BaseFilter_GetSyncSource(
IBaseFilter *iface, IReferenceClock **pClock)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI BaseFilter_EnumPins(
IBaseFilter *iface, IEnumPins **ppEnum)
{
test_filter *This = impl_from_IBaseFilter(iface);
check_calls_list("BaseFilter_EnumPins", BASEFILTER_ENUMPINS, This->filter_type);
*ppEnum = &This->IEnumPins_iface;
This->enum_pins_pos = 0;
return S_OK;
}
static HRESULT WINAPI BaseFilter_FindPin(IBaseFilter *iface,
LPCWSTR Id, IPin **ppPin)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI BaseFilter_QueryFilterInfo(IBaseFilter *iface, FILTER_INFO *pInfo)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI BaseFilter_JoinFilterGraph(IBaseFilter *iface,
IFilterGraph *pGraph, LPCWSTR pName)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI BaseFilter_QueryVendorInfo(IBaseFilter *iface, LPWSTR *pVendorInfo)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static IBaseFilterVtbl BaseFilterVtbl = {
BaseFilter_QueryInterface,
BaseFilter_AddRef,
BaseFilter_Release,
BaseFilter_GetClassID,
BaseFilter_Stop,
BaseFilter_Pause,
BaseFilter_Run,
BaseFilter_GetState,
BaseFilter_SetSyncSource,
BaseFilter_GetSyncSource,
BaseFilter_EnumPins,
BaseFilter_FindPin,
BaseFilter_QueryFilterInfo,
BaseFilter_JoinFilterGraph,
BaseFilter_QueryVendorInfo
};
static test_filter* impl_from_IEnumPins(IEnumPins *iface)
{
return CONTAINING_RECORD(iface, test_filter, IEnumPins_iface);
}
static HRESULT WINAPI EnumPins_QueryInterface(IEnumPins *iface, REFIID riid, void **ppv)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static ULONG WINAPI EnumPins_AddRef(IEnumPins *iface)
{
return 2;
}
static ULONG WINAPI EnumPins_Release(IEnumPins *iface)
{
return 1;
}
static HRESULT WINAPI EnumPins_Next(IEnumPins *iface,
ULONG cPins, IPin **ppPins, ULONG *pcFetched)
{
test_filter *This = impl_from_IEnumPins(iface);
check_calls_list("EnumPins_Next", ENUMPINS_NEXT, This->filter_type);
ok(cPins == 1, "cPins = %d\n", cPins);
ok(ppPins != NULL, "ppPins == NULL\n");
ok(pcFetched != NULL, "pcFetched == NULL\n");
if(!This->enum_pins_pos++) {
*ppPins = &This->IPin_iface;
*pcFetched = 1;
return S_OK;
}
*pcFetched = 0;
return S_FALSE;
}
static HRESULT WINAPI EnumPins_Skip(IEnumPins *iface, ULONG cPins)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI EnumPins_Reset(IEnumPins *iface)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI EnumPins_Clone(IEnumPins *iface, IEnumPins **ppEnum)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static IEnumPinsVtbl EnumPinsVtbl = {
EnumPins_QueryInterface,
EnumPins_AddRef,
EnumPins_Release,
EnumPins_Next,
EnumPins_Skip,
EnumPins_Reset,
EnumPins_Clone
};
static test_filter* impl_from_IPin(IPin *iface)
{
return CONTAINING_RECORD(iface, test_filter, IPin_iface);
}
static HRESULT WINAPI Pin_QueryInterface(IPin *iface, REFIID riid, void **ppv)
{
test_filter *This = impl_from_IPin(iface);
if(IsEqualIID(riid, &IID_IUnknown) || IsEqualIID(riid, &IID_IPin)) {
*ppv = iface;
return S_OK;
}
if(IsEqualIID(riid, &IID_IKsPropertySet)) {
*ppv = &This->IKsPropertySet_iface;
return S_OK;
}
ok(0, "unexpected call\n");
*ppv = NULL;
return E_NOINTERFACE;
}
static ULONG WINAPI Pin_AddRef(IPin *iface)
{
return 2;
}
static ULONG WINAPI Pin_Release(IPin *iface)
{
return 1;
}
static HRESULT WINAPI Pin_Connect(IPin *iface, IPin *pReceivePin, const AM_MEDIA_TYPE *pmt)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI Pin_ReceiveConnection(IPin *iface,
IPin *pConnector, const AM_MEDIA_TYPE *pmt)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI Pin_Disconnect(IPin *iface)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI Pin_ConnectedTo(IPin *iface, IPin **pPin)
{
test_filter *This = impl_from_IPin(iface);
check_calls_list("Pin_ConnectedTo", PIN_CONNECTEDTO, This->filter_type);
*pPin = NULL;
return S_OK;
}
static HRESULT WINAPI Pin_ConnectionMediaType(IPin *iface, AM_MEDIA_TYPE *pmt)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI Pin_QueryPinInfo(IPin *iface, PIN_INFO *pInfo)
{
test_filter *This = impl_from_IPin(iface);
check_calls_list("Pin_QueryPinInfo", PIN_QUERYPININFO, This->filter_type);
return E_NOTIMPL;
}
static HRESULT WINAPI Pin_QueryDirection(IPin *iface, PIN_DIRECTION *pPinDir)
{
test_filter *This = impl_from_IPin(iface);
check_calls_list("Pin_QueryDirection", PIN_QUERYDIRECTION, This->filter_type);
*pPinDir = This->dir;
return S_OK;
}
static HRESULT WINAPI Pin_QueryId(IPin *iface, LPWSTR *Id)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI Pin_QueryAccept(IPin *iface, const AM_MEDIA_TYPE *pmt)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI Pin_EnumMediaTypes(IPin *iface, IEnumMediaTypes **ppEnum)
{
test_filter *This = impl_from_IPin(iface);
check_calls_list("Pin_EnumMediaTypes", PIN_ENUMMEDIATYPES, This->filter_type);
ok(ppEnum != NULL, "ppEnum == NULL\n");
*ppEnum = &This->IEnumMediaTypes_iface;
return S_OK;
}
static HRESULT WINAPI Pin_QueryInternalConnections(IPin *iface, IPin **apPin, ULONG *nPin)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI Pin_EndOfStream(IPin *iface)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI Pin_BeginFlush(IPin *iface)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI Pin_EndFlush(IPin *iface)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI Pin_NewSegment(IPin *iface, REFERENCE_TIME tStart,
REFERENCE_TIME tStop, double dRate)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static IPinVtbl PinVtbl = {
Pin_QueryInterface,
Pin_AddRef,
Pin_Release,
Pin_Connect,
Pin_ReceiveConnection,
Pin_Disconnect,
Pin_ConnectedTo,
Pin_ConnectionMediaType,
Pin_QueryPinInfo,
Pin_QueryDirection,
Pin_QueryId,
Pin_QueryAccept,
Pin_EnumMediaTypes,
Pin_QueryInternalConnections,
Pin_EndOfStream,
Pin_BeginFlush,
Pin_EndFlush,
Pin_NewSegment
};
static test_filter* impl_from_IKsPropertySet(IKsPropertySet *iface)
{
return CONTAINING_RECORD(iface, test_filter, IKsPropertySet_iface);
}
static HRESULT WINAPI KsPropertySet_QueryInterface(IKsPropertySet *iface, REFIID riid, void **ppv)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static ULONG WINAPI KsPropertySet_AddRef(IKsPropertySet *iface)
{
return 2;
}
static ULONG WINAPI KsPropertySet_Release(IKsPropertySet *iface)
{
return 1;
}
static HRESULT WINAPI KsPropertySet_Set(IKsPropertySet *iface, REFGUID guidPropSet, DWORD dwPropID,
LPVOID pInstanceData, DWORD cbInstanceData, LPVOID pPropData, DWORD cbPropData)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI KsPropertySet_Get(IKsPropertySet *iface, REFGUID guidPropSet, DWORD dwPropID,
LPVOID pInstanceData, DWORD cbInstanceData, LPVOID pPropData, DWORD cbPropData, DWORD *pcbReturned)
{
test_filter *This = impl_from_IKsPropertySet(iface);
check_calls_list("KsPropertySet_Get", KSPROPERTYSET_GET, This->filter_type);
ok(IsEqualIID(guidPropSet, &AMPROPSETID_Pin), "guidPropSet = %s\n", debugstr_guid(guidPropSet));
ok(dwPropID == 0, "dwPropID = %d\n", dwPropID);
ok(pInstanceData == NULL, "pInstanceData != NULL\n");
ok(cbInstanceData == 0, "cbInstanceData != 0\n");
ok(cbPropData == sizeof(GUID), "cbPropData = %d\n", cbPropData);
*pcbReturned = sizeof(GUID);
memcpy(pPropData, &PIN_CATEGORY_EDS, sizeof(GUID));
return S_OK;
}
static HRESULT WINAPI KsPropertySet_QuerySupported(IKsPropertySet *iface,
REFGUID guidPropSet, DWORD dwPropID, DWORD *pTypeSupport)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static IKsPropertySetVtbl KsPropertySetVtbl = {
KsPropertySet_QueryInterface,
KsPropertySet_AddRef,
KsPropertySet_Release,
KsPropertySet_Set,
KsPropertySet_Get,
KsPropertySet_QuerySupported
};
static test_filter* impl_from_IEnumMediaTypes(IEnumMediaTypes *iface)
{
return CONTAINING_RECORD(iface, test_filter, IEnumMediaTypes_iface);
}
static HRESULT WINAPI EnumMediaTypes_QueryInterface(IEnumMediaTypes *iface, REFIID riid, void **ppv)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static ULONG WINAPI EnumMediaTypes_AddRef(IEnumMediaTypes *iface)
{
return 2;
}
static ULONG WINAPI EnumMediaTypes_Release(IEnumMediaTypes *iface)
{
return 1;
}
static HRESULT WINAPI EnumMediaTypes_Next(IEnumMediaTypes *iface, ULONG cMediaTypes,
AM_MEDIA_TYPE **ppMediaTypes, ULONG *pcFetched)
{
test_filter *This = impl_from_IEnumMediaTypes(iface);
check_calls_list("EnumMediaTypes_Next", ENUMMEDIATYPES_NEXT, This->filter_type);
ok(cMediaTypes == 1, "cMediaTypes = %d\n", cMediaTypes);
ok(ppMediaTypes != NULL, "ppMediaTypes == NULL\n");
ok(pcFetched != NULL, "pcFetched == NULL\n");
if(!This->enum_media_types_pos++) {
ppMediaTypes[0] = CoTaskMemAlloc(sizeof(AM_MEDIA_TYPE));
memset(ppMediaTypes[0], 0, sizeof(AM_MEDIA_TYPE));
ppMediaTypes[0]->majortype = MEDIATYPE_Video;
*pcFetched = 1;
return S_OK;
}
*pcFetched = 0;
return S_FALSE;
}
static HRESULT WINAPI EnumMediaTypes_Skip(IEnumMediaTypes *iface, ULONG cMediaTypes)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static HRESULT WINAPI EnumMediaTypes_Reset(IEnumMediaTypes *iface)
{
test_filter *This = impl_from_IEnumMediaTypes(iface);
check_calls_list("EnumMediaTypes_Reset", ENUMMEDIATYPES_RESET, This->filter_type);
This->enum_media_types_pos = 0;
return E_FAIL;
}
static HRESULT WINAPI EnumMediaTypes_Clone(IEnumMediaTypes *iface, IEnumMediaTypes **ppEnum)
{
ok(0, "unexpected call\n");
return E_NOTIMPL;
}
static IEnumMediaTypesVtbl EnumMediaTypesVtbl = {
EnumMediaTypes_QueryInterface,
EnumMediaTypes_AddRef,
EnumMediaTypes_Release,
EnumMediaTypes_Next,
EnumMediaTypes_Skip,
EnumMediaTypes_Reset,
EnumMediaTypes_Clone
};
static void test_CaptureGraphBuilder_RenderStream(void)
{
test_filter source_filter = {{&BaseFilterVtbl}, {&EnumPinsVtbl}, {&PinVtbl},
{&KsPropertySetVtbl}, {&EnumMediaTypesVtbl}, PINDIR_OUTPUT, SOURCE_FILTER};
test_filter sink_filter = {{&BaseFilterVtbl}, {&EnumPinsVtbl}, {&PinVtbl},
{&KsPropertySetVtbl}, {&EnumMediaTypesVtbl}, PINDIR_INPUT, SINK_FILTER};
ICaptureGraphBuilder2 *cgb;
HRESULT hr;
hr = CoCreateInstance(&CLSID_CaptureGraphBuilder2, NULL, CLSCTX_INPROC_SERVER,
&IID_ICaptureGraphBuilder2, (void**)&cgb);
ok(hr == S_OK || broken(hr == REGDB_E_CLASSNOTREG),
"couldn't create CaptureGraphBuilder, hr = %08x\n", hr);
if(hr != S_OK) {
win_skip("CaptureGraphBuilder is not registered\n");
return;
}
hr = ICaptureGraphBuilder2_SetFiltergraph(cgb, &GraphBuilder);
ok(hr == S_OK, "SetFiltergraph failed: %08x\n", hr);
trace("RenderStream with category and mediatype test\n");
current_calls_list = renderstream_cat_media;
call_no = 0;
hr = ICaptureGraphBuilder2_RenderStream(cgb, &PIN_CATEGORY_EDS,
&MEDIATYPE_Video, (IUnknown*)&source_filter.IBaseFilter_iface,
NULL, &sink_filter.IBaseFilter_iface);
ok(hr == S_OK, "RenderStream failed: %08x\n", hr);
check_calls_list("test_CaptureGraphBuilder_RenderStream", END, NOT_FILTER);
ICaptureGraphBuilder2_Release(cgb);
}
START_TEST(qcap)
{
if (SUCCEEDED(CoInitialize(NULL)))
{
test_smart_tee_filter();
test_CaptureGraphBuilder_RenderStream();
CoUninitialize();
}
else