ReactOS  0.4.14-dev-614-gbfd8a84
misc.c File Reference
#include "wine/test.h"
#include "dshow.h"
Include dependency graph for misc.c:

Go to the source code of this file.

Macros

#define COBJMACROS
 
#define QI_SUCCEED(iface, riid, ppv)
 
#define QI_FAIL(iface, riid, ppv)
 
#define ADDREF_EXPECT(iface, num)
 
#define RELEASE_EXPECT(iface, num)
 

Functions

static void test_aggregation (const CLSID clsidOuter, const CLSID clsidInner, const IID iidOuter, const IID iidInner)
 
static void test_null_renderer_aggregations (void)
 
static void test_video_renderer_aggregations (void)
 
static void test_filter_graph_aggregations (void)
 
static void test_filter_mapper_aggregations (void)
 
 START_TEST (misc)
 

Macro Definition Documentation

◆ ADDREF_EXPECT

#define ADDREF_EXPECT (   iface,
  num 
)
Value:
if (iface) { \
refCount = IUnknown_AddRef(iface); \
ok(refCount == num, "IUnknown_AddRef should return %d, got %d\n", num, refCount); \
}
GLuint GLuint num
Definition: glext.h:9618

Definition at line 34 of file misc.c.

◆ COBJMACROS

#define COBJMACROS

Definition at line 21 of file misc.c.

◆ QI_FAIL

#define QI_FAIL (   iface,
  riid,
  ppv 
)
Value:
hr = IUnknown_QueryInterface(iface, &riid, (LPVOID*)&ppv); \
ok(hr == E_NOINTERFACE, "IUnknown_QueryInterface returned %x\n", hr); \
ok(ppv == NULL, "Pointer is %p\n", ppv);
#define E_NOINTERFACE
Definition: winerror.h:2364
HRESULT hr
Definition: shlfolder.c:183
REFIID riid
Definition: precomp.h:44
REFIID LPVOID * ppv
Definition: atlbase.h:39
smooth NULL
Definition: ftsmooth.c:416

Definition at line 30 of file misc.c.

◆ QI_SUCCEED

#define QI_SUCCEED (   iface,
  riid,
  ppv 
)
Value:
hr = IUnknown_QueryInterface(iface, &riid, (LPVOID*)&ppv); \
ok(hr == S_OK, "IUnknown_QueryInterface returned %x\n", hr); \
ok(ppv != NULL, "Pointer is NULL\n");
HRESULT hr
Definition: shlfolder.c:183
REFIID riid
Definition: precomp.h:44
REFIID LPVOID * ppv
Definition: atlbase.h:39
smooth NULL
Definition: ftsmooth.c:416
#define S_OK
Definition: intsafe.h:59

Definition at line 26 of file misc.c.

◆ RELEASE_EXPECT

#define RELEASE_EXPECT (   iface,
  num 
)
Value:
if (iface) { \
refCount = IUnknown_Release(iface); \
ok(refCount == num, "IUnknown_Release should return %d, got %d\n", num, refCount); \
}
GLuint GLuint num
Definition: glext.h:9618

Definition at line 39 of file misc.c.

Function Documentation

◆ START_TEST()

START_TEST ( misc  )

Definition at line 223 of file misc.c.

224 {
226 
231 
232  CoUninitialize();
233 }
static void test_filter_graph_aggregations(void)
Definition: misc.c:192
smooth NULL
Definition: ftsmooth.c:416
static void test_null_renderer_aggregations(void)
Definition: misc.c:165
void WINAPI DECLSPEC_HOTPATCH CoUninitialize(void)
Definition: compobj.c:2067
static void test_filter_mapper_aggregations(void)
Definition: misc.c:209
HRESULT WINAPI CoInitialize(LPVOID lpReserved)
Definition: compobj.c:1964
static void test_video_renderer_aggregations(void)
Definition: misc.c:178

◆ test_aggregation()

static void test_aggregation ( const CLSID  clsidOuter,
const CLSID  clsidInner,
const IID  iidOuter,
const IID  iidInner 
)
static

Definition at line 44 of file misc.c.

46 {
47  HRESULT hr;
48  ULONG refCount;
49  IUnknown *pUnkOuter = NULL;
50  IUnknown *pUnkInner = NULL;
51  IUnknown *pUnkInnerFail = NULL;
52  IUnknown *pUnkOuterTest = NULL;
53  IUnknown *pUnkInnerTest = NULL;
54  IUnknown *pUnkAggregatee = NULL;
55  IUnknown *pUnkAggregator = NULL;
56  IUnknown *pUnkTest = NULL;
57 
58  hr = CoCreateInstance(&clsidOuter, NULL, CLSCTX_INPROC_SERVER,
59  &IID_IUnknown, (LPVOID*)&pUnkOuter);
60  ok(hr == S_OK, "CoCreateInstance failed with %x\n", hr);
61  ok(pUnkOuter != NULL, "pUnkOuter is NULL\n");
62 
63  if (!pUnkOuter)
64  {
65  skip("pUnkOuter is NULL\n");
66  return;
67  }
68 
69  /* for aggregation, we should only be able to request IUnknown */
70  hr = CoCreateInstance(&clsidInner, pUnkOuter, CLSCTX_INPROC_SERVER,
71  &iidInner, (LPVOID*)&pUnkInnerFail);
72  if (hr == REGDB_E_CLASSNOTREG)
73  {
74  skip("Class not registered\n");
75  return;
76  }
77  ok(hr == E_NOINTERFACE, "CoCreateInstance returned %x\n", hr);
78  ok(pUnkInnerFail == NULL, "pUnkInnerFail is not NULL\n");
79 
80  /* aggregation, request IUnknown */
81  hr = CoCreateInstance(&clsidInner, pUnkOuter, CLSCTX_INPROC_SERVER,
82  &IID_IUnknown, (LPVOID*)&pUnkInner);
83  ok(hr == S_OK, "CoCreateInstance returned %x\n", hr);
84  ok(pUnkInner != NULL, "pUnkInner is NULL\n");
85 
86  if (!pUnkInner)
87  {
88  skip("pUnkInner is NULL\n");
89  return;
90  }
91 
92  ADDREF_EXPECT(pUnkOuter, 2);
93  ADDREF_EXPECT(pUnkInner, 2);
94  RELEASE_EXPECT(pUnkOuter, 1);
95  RELEASE_EXPECT(pUnkInner, 1);
96 
97  QI_FAIL(pUnkOuter, iidInner, pUnkAggregatee);
98  QI_FAIL(pUnkInner, iidOuter, pUnkAggregator);
99 
100  /* these QueryInterface calls should work */
101  QI_SUCCEED(pUnkOuter, iidOuter, pUnkAggregator);
102  QI_SUCCEED(pUnkOuter, IID_IUnknown, pUnkOuterTest);
103  /* IGraphConfig interface comes with DirectShow 9 */
104  if(IsEqualGUID(&IID_IGraphConfig, &iidInner))
105  {
106  hr = IUnknown_QueryInterface(pUnkInner, &iidInner, (LPVOID*)&pUnkAggregatee);
107  ok(hr == S_OK || broken(hr == E_NOINTERFACE), "IUnknown_QueryInterface returned %x\n", hr);
108  ok(pUnkAggregatee != NULL || broken(!pUnkAggregatee), "Pointer is NULL\n");
109  }
110  else
111  {
112  QI_SUCCEED(pUnkInner, iidInner, pUnkAggregatee);
113  }
114  QI_SUCCEED(pUnkInner, IID_IUnknown, pUnkInnerTest);
115 
116  if (!pUnkAggregator || !pUnkOuterTest || !pUnkAggregatee
117  || !pUnkInnerTest)
118  {
119  skip("One of the required interfaces is NULL\n");
120  return;
121  }
122 
123  ADDREF_EXPECT(pUnkAggregator, 5);
124  ADDREF_EXPECT(pUnkOuterTest, 6);
125  ADDREF_EXPECT(pUnkAggregatee, 7);
126  ADDREF_EXPECT(pUnkInnerTest, 3);
127  RELEASE_EXPECT(pUnkAggregator, 6);
128  RELEASE_EXPECT(pUnkOuterTest, 5);
129  RELEASE_EXPECT(pUnkAggregatee, 4);
130  RELEASE_EXPECT(pUnkInnerTest, 2);
131 
132  QI_SUCCEED(pUnkAggregator, IID_IUnknown, pUnkTest);
133  QI_SUCCEED(pUnkOuterTest, IID_IUnknown, pUnkTest);
134  QI_SUCCEED(pUnkAggregatee, IID_IUnknown, pUnkTest);
135  QI_SUCCEED(pUnkInnerTest, IID_IUnknown, pUnkTest);
136 
137  QI_FAIL(pUnkAggregator, iidInner, pUnkTest);
138  QI_FAIL(pUnkOuterTest, iidInner, pUnkTest);
139  QI_FAIL(pUnkAggregatee, iidInner, pUnkTest);
140  QI_SUCCEED(pUnkInnerTest, iidInner, pUnkTest);
141 
142  QI_SUCCEED(pUnkAggregator, iidOuter, pUnkTest);
143  QI_SUCCEED(pUnkOuterTest, iidOuter, pUnkTest);
144  QI_SUCCEED(pUnkAggregatee, iidOuter, pUnkTest);
145  QI_FAIL(pUnkInnerTest, iidOuter, pUnkTest);
146 
147  RELEASE_EXPECT(pUnkAggregator, 10);
148  RELEASE_EXPECT(pUnkOuterTest, 9);
149  RELEASE_EXPECT(pUnkAggregatee, 8);
150  RELEASE_EXPECT(pUnkInnerTest, 2);
151  RELEASE_EXPECT(pUnkOuter, 7);
152  RELEASE_EXPECT(pUnkInner, 1);
153 
154  do
155  {
156  refCount = IUnknown_Release(pUnkInner);
157  } while (refCount);
158 
159  do
160  {
161  refCount = IUnknown_Release(pUnkOuter);
162  } while (refCount);
163 }
#define E_NOINTERFACE
Definition: winerror.h:2364
HRESULT hr
Definition: shlfolder.c:183
#define RELEASE_EXPECT(iface, num)
Definition: misc.c:39
smooth NULL
Definition: ftsmooth.c:416
#define QI_SUCCEED(iface, riid, ppv)
Definition: misc.c:26
LONG HRESULT
Definition: typedefs.h:77
const GUID IID_IUnknown
#define QI_FAIL(iface, riid, ppv)
Definition: misc.c:30
#define broken(x)
Definition: _sntprintf.h:21
HRESULT WINAPI DECLSPEC_HOTPATCH CoCreateInstance(REFCLSID rclsid, LPUNKNOWN pUnkOuter, DWORD dwClsContext, REFIID iid, LPVOID *ppv)
Definition: compobj.c:3325
#define S_OK
Definition: intsafe.h:59
#define REGDB_E_CLASSNOTREG
Definition: winerror.h:2696
#define ok(value,...)
Definition: atltest.h:57
BOOL WINAPI IsEqualGUID(REFGUID rguid1, REFGUID rguid2)
Definition: compobj.c:4112
#define skip(...)
Definition: atltest.h:64
unsigned int ULONG
Definition: retypes.h:1
#define ADDREF_EXPECT(iface, num)
Definition: misc.c:34

Referenced by test_filter_graph_aggregations(), test_filter_mapper_aggregations(), test_null_renderer_aggregations(), and test_video_renderer_aggregations().

◆ test_filter_graph_aggregations()

static void test_filter_graph_aggregations ( void  )
static

Definition at line 192 of file misc.c.

193 {
194  const IID * iids[] = {
195  &IID_IFilterGraph2, &IID_IMediaControl, &IID_IGraphBuilder,
196  &IID_IFilterGraph, &IID_IMediaSeeking, &IID_IBasicAudio, &IID_IBasicVideo,
197  &IID_IVideoWindow, &IID_IMediaEventEx, &IID_IMediaFilter,
198  &IID_IMediaEventSink, &IID_IGraphConfig, &IID_IMediaPosition
199  };
200  int i;
201 
202  for (i = 0; i < sizeof(iids) / sizeof(iids[0]); i++)
203  {
204  test_aggregation(CLSID_SystemClock, CLSID_FilterGraph,
205  IID_IReferenceClock, *iids[i]);
206  }
207 }
static void test_aggregation(const CLSID clsidOuter, const CLSID clsidInner, const IID iidOuter, const IID iidInner)
Definition: misc.c:44
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
Definition: glfuncs.h:248

Referenced by START_TEST().

◆ test_filter_mapper_aggregations()

static void test_filter_mapper_aggregations ( void  )
static

Definition at line 209 of file misc.c.

210 {
211  const IID * iids[] = {
212  &IID_IFilterMapper2, &IID_IFilterMapper
213  };
214  int i;
215 
216  for (i = 0; i < sizeof(iids) / sizeof(iids[0]); i++)
217  {
218  test_aggregation(CLSID_SystemClock, CLSID_FilterMapper2,
219  IID_IReferenceClock, *iids[i]);
220  }
221 }
static void test_aggregation(const CLSID clsidOuter, const CLSID clsidInner, const IID iidOuter, const IID iidInner)
Definition: misc.c:44
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
Definition: glfuncs.h:248

Referenced by START_TEST().

◆ test_null_renderer_aggregations()

static void test_null_renderer_aggregations ( void  )
static

Definition at line 165 of file misc.c.

166 {
167  const IID * iids[] = {
168  &IID_IMediaFilter, &IID_IBaseFilter
169  };
170  int i;
171 
172  for (i = 0; i < sizeof(iids) / sizeof(iids[0]); i++)
173  {
174  test_aggregation(CLSID_SystemClock, CLSID_NullRenderer, IID_IReferenceClock, *iids[i]);
175  }
176 }
const GUID IID_IBaseFilter
static void test_aggregation(const CLSID clsidOuter, const CLSID clsidInner, const IID iidOuter, const IID iidInner)
Definition: misc.c:44
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
Definition: glfuncs.h:248

Referenced by START_TEST().

◆ test_video_renderer_aggregations()

static void test_video_renderer_aggregations ( void  )
static

Definition at line 178 of file misc.c.

179 {
180  const IID * iids[] = {
181  &IID_IMediaFilter, &IID_IBaseFilter, &IID_IBasicVideo, &IID_IVideoWindow
182  };
183  int i;
184 
185  for (i = 0; i < sizeof(iids) / sizeof(iids[0]); i++)
186  {
187  test_aggregation(CLSID_SystemClock, CLSID_VideoRenderer,
188  IID_IReferenceClock, *iids[i]);
189  }
190 }
const GUID IID_IBaseFilter
static void test_aggregation(const CLSID clsidOuter, const CLSID clsidInner, const IID iidOuter, const IID iidInner)
Definition: misc.c:44
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
Definition: glfuncs.h:248

Referenced by START_TEST().