Commit 194f765b authored by Zebediah Figura's avatar Zebediah Figura Committed by Alexandre Julliard

quartz/tests: Add a test mp3 file.

parent 42263f9a
...@@ -41,6 +41,7 @@ typedef struct TestFilterImpl ...@@ -41,6 +41,7 @@ typedef struct TestFilterImpl
static const WCHAR avifile[] = {'t','e','s','t','.','a','v','i',0}; static const WCHAR avifile[] = {'t','e','s','t','.','a','v','i',0};
static const WCHAR mpegfile[] = {'t','e','s','t','.','m','p','g',0}; static const WCHAR mpegfile[] = {'t','e','s','t','.','m','p','g',0};
static const WCHAR mp3file[] = {'t','e','s','t','.','m','p','3',0};
static WCHAR *load_resource(const WCHAR *name) static WCHAR *load_resource(const WCHAR *name)
{ {
...@@ -530,57 +531,63 @@ todo_wine ...@@ -530,57 +531,63 @@ todo_wine
IMediaFilter_Release(filter); IMediaFilter_Release(filter);
} }
static void rungraph(IFilterGraph2 *graph) static void rungraph(IFilterGraph2 *graph, BOOL video)
{ {
test_basic_video(graph); if (video)
test_basic_video(graph);
test_media_seeking(graph); test_media_seeking(graph);
test_state_change(graph); test_state_change(graph);
test_media_event(graph); test_media_event(graph);
} }
static HRESULT test_graph_builder_connect_file(WCHAR *filename) static HRESULT test_graph_builder_connect_file(WCHAR *filename, BOOL audio, BOOL video)
{ {
static const WCHAR outputW[] = {'O','u','t','p','u','t',0}; static const WCHAR outputW[] = {'O','u','t','p','u','t',0};
static const WCHAR inW[] = {'I','n',0}; IBaseFilter *source_filter, *renderer;
IBaseFilter *source_filter, *video_filter;
IPin *pin_in, *pin_out; IPin *pin_in, *pin_out;
IFilterGraph2 *graph; IFilterGraph2 *graph;
IVideoWindow *window; IEnumPins *enumpins;
HRESULT hr; HRESULT hr;
if (video)
hr = CoCreateInstance(&CLSID_VideoRenderer, NULL, CLSCTX_INPROC_SERVER,
&IID_IBaseFilter, (void **)&renderer);
else
hr = CoCreateInstance(&CLSID_AudioRender, NULL, CLSCTX_INPROC_SERVER,
&IID_IBaseFilter, (void **)&renderer);
if (hr == VFW_E_NO_AUDIO_HARDWARE)
return VFW_E_CANNOT_CONNECT;
ok(hr == S_OK, "Got hr %#x.\n", hr);
graph = create_graph(); graph = create_graph();
hr = CoCreateInstance(&CLSID_VideoRenderer, NULL, CLSCTX_INPROC_SERVER, &IID_IVideoWindow, (void **)&window); IBaseFilter_EnumPins(renderer, &enumpins);
ok(hr == S_OK, "Failed to create VideoRenderer: %#x\n", hr); IEnumPins_Next(enumpins, 1, &pin_in, NULL);
IEnumPins_Release(enumpins);
hr = IFilterGraph2_AddSourceFilter(graph, filename, NULL, &source_filter); hr = IFilterGraph2_AddSourceFilter(graph, filename, NULL, &source_filter);
ok(hr == S_OK, "AddSourceFilter failed: %#x\n", hr); ok(hr == S_OK, "AddSourceFilter failed: %#x\n", hr);
hr = IVideoWindow_QueryInterface(window, &IID_IBaseFilter, (void **)&video_filter); hr = IFilterGraph2_AddFilter(graph, renderer, NULL);
ok(hr == S_OK, "QueryInterface(IBaseFilter) failed: %#x\n", hr);
hr = IFilterGraph2_AddFilter(graph, video_filter, NULL);
ok(hr == S_OK, "AddFilter failed: %#x\n", hr); ok(hr == S_OK, "AddFilter failed: %#x\n", hr);
hr = IBaseFilter_FindPin(source_filter, outputW, &pin_out); hr = IBaseFilter_FindPin(source_filter, outputW, &pin_out);
ok(hr == S_OK, "FindPin failed: %#x\n", hr); ok(hr == S_OK, "FindPin failed: %#x\n", hr);
hr = IBaseFilter_FindPin(video_filter, inW, &pin_in);
ok(hr == S_OK, "FindPin failed: %#x\n", hr);
hr = IFilterGraph2_Connect(graph, pin_out, pin_in); hr = IFilterGraph2_Connect(graph, pin_out, pin_in);
if (SUCCEEDED(hr)) if (SUCCEEDED(hr))
rungraph(graph); rungraph(graph, video);
IPin_Release(pin_in); IPin_Release(pin_in);
IPin_Release(pin_out); IPin_Release(pin_out);
IBaseFilter_Release(source_filter); IBaseFilter_Release(source_filter);
IBaseFilter_Release(video_filter); IBaseFilter_Release(renderer);
IVideoWindow_Release(window);
IFilterGraph2_Release(graph); IFilterGraph2_Release(graph);
return hr; return hr;
} }
static void test_render_run(const WCHAR *file) static void test_render_run(const WCHAR *file, BOOL audio, BOOL video)
{ {
IFilterGraph2 *graph; IFilterGraph2 *graph;
HANDLE h; HANDLE h;
...@@ -608,19 +615,25 @@ static void test_render_run(const WCHAR *file) ...@@ -608,19 +615,25 @@ static void test_render_run(const WCHAR *file)
refs = IFilterGraph2_Release(graph); refs = IFilterGraph2_Release(graph);
ok(!refs, "Graph has %u references\n", refs); ok(!refs, "Graph has %u references\n", refs);
hr = test_graph_builder_connect_file(filename); hr = test_graph_builder_connect_file(filename, audio, video);
ok(hr == VFW_E_CANNOT_CONNECT, "got %#x\n", hr); ok(hr == VFW_E_CANNOT_CONNECT, "got %#x\n", hr);
} }
else else
{ {
ok(hr == S_OK || hr == VFW_S_AUDIO_NOT_RENDERED, "RenderFile failed: %x\n", hr); if (audio)
rungraph(graph); ok(hr == S_OK || hr == VFW_S_AUDIO_NOT_RENDERED, "Got hr %#x.\n", hr);
else
ok(hr == S_OK, "Got hr %#x.\n", hr);
rungraph(graph, video);
refs = IFilterGraph2_Release(graph); refs = IFilterGraph2_Release(graph);
ok(!refs, "Graph has %u references\n", refs); ok(!refs, "Graph has %u references\n", refs);
hr = test_graph_builder_connect_file(filename); hr = test_graph_builder_connect_file(filename, audio, video);
ok(hr == S_OK || hr == VFW_S_PARTIAL_RENDER, "got %#x\n", hr); if (audio && video)
todo_wine ok(hr == VFW_S_PARTIAL_RENDER, "Got hr %#x.\n", hr);
else
ok(hr == S_OK, "Got hr %#x.\n", hr);
} }
/* check reference leaks */ /* check reference leaks */
...@@ -737,7 +750,7 @@ todo_wine ...@@ -737,7 +750,7 @@ todo_wine
ok(SUCCEEDED(hr), "RenderFile failed: %x\n", hr); ok(SUCCEEDED(hr), "RenderFile failed: %x\n", hr);
if (SUCCEEDED(hr)) if (SUCCEEDED(hr))
rungraph(graph); rungraph(graph, TRUE);
return 0; return 0;
} }
...@@ -3199,8 +3212,9 @@ START_TEST(filtergraph) ...@@ -3199,8 +3212,9 @@ START_TEST(filtergraph)
CoInitializeEx(NULL, COINIT_MULTITHREADED); CoInitializeEx(NULL, COINIT_MULTITHREADED);
test_interfaces(); test_interfaces();
test_render_run(avifile); test_render_run(avifile, FALSE, TRUE);
test_render_run(mpegfile); test_render_run(mpegfile, TRUE, TRUE);
test_render_run(mp3file, TRUE, FALSE);
test_enum_filters(); test_enum_filters();
test_graph_builder_render(); test_graph_builder_render();
test_graph_builder_connect(); test_graph_builder_connect();
......
...@@ -20,8 +20,14 @@ ...@@ -20,8 +20,14 @@
#include "windef.h" #include "windef.h"
/* ffmpeg -f lavfi -i smptebars -t 1 -r 1 -f avi -vcodec rawvideo -pix_fmt yuv420p -vf scale=32x24 test.avi */
/* @makedep: test.avi */ /* @makedep: test.avi */
test.avi RCDATA "test.avi" test.avi RCDATA "test.avi"
/* ffmpeg -f lavfi -i smptebars -f lavfi -i "sine=frequency=1000" -t 0.04 -r 25 -f mpeg -vcodec mpeg1video -vf scale=32x24 -acodec mp2 test.mpg */
/* @makedep: test.mpg */ /* @makedep: test.mpg */
test.mpg RCDATA "test.mpg" test.mpg RCDATA "test.mpg"
/* ffmpeg -f lavfi -i "sine=frequency=500" -t 0.5 -ar 48000 -b:a 32k -f mp3 -acodec mp3 test.mp3 */
/* @makedep: test.mp3 */
test.mp3 RCDATA "test.mp3"
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