Commit ae41ce2d authored by Akihiro Sagawa's avatar Akihiro Sagawa Committed by Alexandre Julliard

quartz/tests: Introduce commit_allocator helper in vmr7.c.

parent 649385e7
...@@ -1021,6 +1021,18 @@ static HRESULT join_thread_(int line, HANDLE thread) ...@@ -1021,6 +1021,18 @@ static HRESULT join_thread_(int line, HANDLE thread)
} }
#define join_thread(a) join_thread_(__LINE__, a) #define join_thread(a) join_thread_(__LINE__, a)
static void commit_allocator(IMemInputPin *input)
{
IMemAllocator *allocator;
HRESULT hr;
hr = IMemInputPin_GetAllocator(input, &allocator);
ok(hr == S_OK, "Got hr %#x.\n", hr);
hr = IMemAllocator_Commit(allocator);
ok(hr == S_OK, "Got hr %#x.\n", hr);
IMemAllocator_Release(allocator);
}
static void test_filter_state(IMemInputPin *input, IMediaControl *control) static void test_filter_state(IMemInputPin *input, IMediaControl *control)
{ {
IMemAllocator *allocator; IMemAllocator *allocator;
...@@ -1130,9 +1142,7 @@ static void test_filter_state(IMemInputPin *input, IMediaControl *control) ...@@ -1130,9 +1142,7 @@ static void test_filter_state(IMemInputPin *input, IMediaControl *control)
hr = IMediaControl_GetState(control, 0, &state); hr = IMediaControl_GetState(control, 0, &state);
ok(hr == S_OK, "Got hr %#x.\n", hr); ok(hr == S_OK, "Got hr %#x.\n", hr);
hr = IMemAllocator_Commit(allocator); commit_allocator(input);
ok(hr == S_OK, "Got hr %#x.\n", hr);
hr = IMediaControl_Pause(control); hr = IMediaControl_Pause(control);
ok(hr == S_FALSE, "Got hr %#x.\n", hr); ok(hr == S_FALSE, "Got hr %#x.\n", hr);
...@@ -1163,17 +1173,11 @@ static void test_filter_state(IMemInputPin *input, IMediaControl *control) ...@@ -1163,17 +1173,11 @@ static void test_filter_state(IMemInputPin *input, IMediaControl *control)
static void test_flushing(IPin *pin, IMemInputPin *input, IMediaControl *control) static void test_flushing(IPin *pin, IMemInputPin *input, IMediaControl *control)
{ {
IMemAllocator *allocator;
OAFilterState state; OAFilterState state;
HANDLE thread; HANDLE thread;
HRESULT hr; HRESULT hr;
hr = IMemInputPin_GetAllocator(input, &allocator); commit_allocator(input);
ok(hr == S_OK, "Got hr %#x.\n", hr);
hr = IMemAllocator_Commit(allocator);
ok(hr == S_OK, "Got hr %#x.\n", hr);
IMemAllocator_Release(allocator);
hr = IMediaControl_Pause(control); hr = IMediaControl_Pause(control);
ok(hr == S_FALSE, "Got hr %#x.\n", hr); ok(hr == S_FALSE, "Got hr %#x.\n", hr);
...@@ -1239,7 +1243,6 @@ static void test_current_image(IBaseFilter *filter, IMemInputPin *input, ...@@ -1239,7 +1243,6 @@ static void test_current_image(IBaseFilter *filter, IMemInputPin *input,
const BITMAPINFOHEADER *bih = (BITMAPINFOHEADER *)buffer; const BITMAPINFOHEADER *bih = (BITMAPINFOHEADER *)buffer;
const DWORD *data = (DWORD *)((char *)buffer + sizeof(BITMAPINFOHEADER)); const DWORD *data = (DWORD *)((char *)buffer + sizeof(BITMAPINFOHEADER));
BITMAPINFOHEADER expect_bih = *req_bih; BITMAPINFOHEADER expect_bih = *req_bih;
IMemAllocator *allocator;
OAFilterState state; OAFilterState state;
IBasicVideo *video; IBasicVideo *video;
unsigned int i; unsigned int i;
...@@ -1272,12 +1275,7 @@ static void test_current_image(IBaseFilter *filter, IMemInputPin *input, ...@@ -1272,12 +1275,7 @@ static void test_current_image(IBaseFilter *filter, IMemInputPin *input,
ok(!memcmp(bih, &expect_bih, sizeof(BITMAPINFOHEADER)), "Bitmap headers didn't match.\n"); ok(!memcmp(bih, &expect_bih, sizeof(BITMAPINFOHEADER)), "Bitmap headers didn't match.\n");
/* The contents seem to reflect the last frame rendered. */ /* The contents seem to reflect the last frame rendered. */
hr = IMemInputPin_GetAllocator(input, &allocator); commit_allocator(input);
ok(hr == S_OK, "Got hr %#x.\n", hr);
hr = IMemAllocator_Commit(allocator);
ok(hr == S_OK, "Got hr %#x.\n", hr);
IMemAllocator_Release(allocator);
hr = IMediaControl_Pause(control); hr = IMediaControl_Pause(control);
ok(hr == S_FALSE, "Got hr %#x.\n", hr); ok(hr == S_FALSE, "Got hr %#x.\n", hr);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment