quartz/tests: Add some tests for querying ACM wrapper pin information.
Signed-off-by: Zebediah Figura <z.figura12@gmail.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
92236655e8
commit
865f471a64
|
@ -251,6 +251,81 @@ static void test_find_pin(void)
|
||||||
ok(!ref, "Got outstanding refcount %d.\n", ref);
|
ok(!ref, "Got outstanding refcount %d.\n", ref);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void test_pin_info(void)
|
||||||
|
{
|
||||||
|
IBaseFilter *filter = create_acm_wrapper();
|
||||||
|
PIN_DIRECTION dir;
|
||||||
|
PIN_INFO info;
|
||||||
|
HRESULT hr;
|
||||||
|
WCHAR *id;
|
||||||
|
ULONG ref;
|
||||||
|
IPin *pin;
|
||||||
|
|
||||||
|
hr = IBaseFilter_FindPin(filter, sink_id, &pin);
|
||||||
|
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||||
|
ref = get_refcount(filter);
|
||||||
|
todo_wine ok(ref == 2, "Got unexpected refcount %d.\n", ref);
|
||||||
|
ref = get_refcount(pin);
|
||||||
|
ok(ref == 2, "Got unexpected refcount %d.\n", ref);
|
||||||
|
|
||||||
|
hr = IPin_QueryPinInfo(pin, &info);
|
||||||
|
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||||
|
ok(info.pFilter == filter, "Expected filter %p, got %p.\n", filter, info.pFilter);
|
||||||
|
ok(info.dir == PINDIR_INPUT, "Got direction %d.\n", info.dir);
|
||||||
|
todo_wine
|
||||||
|
ok(!lstrcmpW(info.achName, sink_name), "Got name %s.\n", wine_dbgstr_w(info.achName));
|
||||||
|
ref = get_refcount(filter);
|
||||||
|
todo_wine ok(ref == 3, "Got unexpected refcount %d.\n", ref);
|
||||||
|
ref = get_refcount(pin);
|
||||||
|
todo_wine ok(ref == 3, "Got unexpected refcount %d.\n", ref);
|
||||||
|
IBaseFilter_Release(info.pFilter);
|
||||||
|
|
||||||
|
hr = IPin_QueryDirection(pin, &dir);
|
||||||
|
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||||
|
ok(dir == PINDIR_INPUT, "Got direction %d.\n", dir);
|
||||||
|
|
||||||
|
hr = IPin_QueryId(pin, &id);
|
||||||
|
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||||
|
ok(!lstrcmpW(id, sink_id), "Got id %s.\n", wine_dbgstr_w(id));
|
||||||
|
CoTaskMemFree(id);
|
||||||
|
|
||||||
|
hr = IPin_QueryInternalConnections(pin, NULL, NULL);
|
||||||
|
ok(hr == E_NOTIMPL, "Got hr %#x.\n", hr);
|
||||||
|
|
||||||
|
IPin_Release(pin);
|
||||||
|
|
||||||
|
hr = IBaseFilter_FindPin(filter, source_id, &pin);
|
||||||
|
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||||
|
|
||||||
|
check_interface(pin, &IID_IPin, TRUE);
|
||||||
|
check_interface(pin, &IID_IMediaSeeking, TRUE);
|
||||||
|
|
||||||
|
hr = IPin_QueryPinInfo(pin, &info);
|
||||||
|
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||||
|
ok(info.pFilter == filter, "Expected filter %p, got %p.\n", filter, info.pFilter);
|
||||||
|
ok(info.dir == PINDIR_OUTPUT, "Got direction %d.\n", info.dir);
|
||||||
|
todo_wine
|
||||||
|
ok(!lstrcmpW(info.achName, source_name), "Got name %s.\n", wine_dbgstr_w(info.achName));
|
||||||
|
IBaseFilter_Release(info.pFilter);
|
||||||
|
|
||||||
|
hr = IPin_QueryDirection(pin, &dir);
|
||||||
|
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||||
|
ok(dir == PINDIR_OUTPUT, "Got direction %d.\n", dir);
|
||||||
|
|
||||||
|
hr = IPin_QueryId(pin, &id);
|
||||||
|
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||||
|
ok(!lstrcmpW(id, source_id), "Got id %s.\n", wine_dbgstr_w(id));
|
||||||
|
CoTaskMemFree(id);
|
||||||
|
|
||||||
|
hr = IPin_QueryInternalConnections(pin, NULL, NULL);
|
||||||
|
ok(hr == E_NOTIMPL, "Got hr %#x.\n", hr);
|
||||||
|
|
||||||
|
IPin_Release(pin);
|
||||||
|
|
||||||
|
ref = IBaseFilter_Release(filter);
|
||||||
|
ok(!ref, "Got outstanding refcount %d.\n", ref);
|
||||||
|
}
|
||||||
|
|
||||||
START_TEST(acmwrapper)
|
START_TEST(acmwrapper)
|
||||||
{
|
{
|
||||||
CoInitialize(NULL);
|
CoInitialize(NULL);
|
||||||
|
@ -258,6 +333,7 @@ START_TEST(acmwrapper)
|
||||||
test_interfaces();
|
test_interfaces();
|
||||||
test_enum_pins();
|
test_enum_pins();
|
||||||
test_find_pin();
|
test_find_pin();
|
||||||
|
test_pin_info();
|
||||||
|
|
||||||
CoUninitialize();
|
CoUninitialize();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue