Author: akhaldi
Date: Tue Oct 1 15:07:45 2013
New Revision: 60494
URL:
http://svn.reactos.org/svn/reactos?rev=60494&view=rev
Log:
[AMSTREAM_WINETEST]
* Sync with Wine 1.7.1.
CORE-7469
Modified:
trunk/rostests/winetests/amstream/CMakeLists.txt
trunk/rostests/winetests/amstream/amstream.c
trunk/rostests/winetests/amstream/testlist.c
Modified: trunk/rostests/winetests/amstream/CMakeLists.txt
URL:
http://svn.reactos.org/svn/reactos/trunk/rostests/winetests/amstream/CMakeL…
==============================================================================
--- trunk/rostests/winetests/amstream/CMakeLists.txt [iso-8859-1] (original)
+++ trunk/rostests/winetests/amstream/CMakeLists.txt [iso-8859-1] Tue Oct 1 15:07:45
2013
@@ -1,8 +1,6 @@
-add_definitions(-D_DLL -D__USE_CRTIMP)
add_executable(amstream_winetest amstream.c testlist.c)
-target_link_libraries(amstream_winetest wine uuid)
+target_link_libraries(amstream_winetest uuid)
set_module_type(amstream_winetest win32cui)
-add_importlibs(amstream_winetest ole32 user32 ddraw msvcrt kernel32 ntdll)
-add_dependencies(amstream_winetest dxsdk)
+add_importlibs(amstream_winetest ole32 user32 ddraw msvcrt kernel32)
add_cd_file(TARGET amstream_winetest DESTINATION reactos/bin FOR all)
Modified: trunk/rostests/winetests/amstream/amstream.c
URL:
http://svn.reactos.org/svn/reactos/trunk/rostests/winetests/amstream/amstre…
==============================================================================
--- trunk/rostests/winetests/amstream/amstream.c [iso-8859-1] (original)
+++ trunk/rostests/winetests/amstream/amstream.c [iso-8859-1] Tue Oct 1 15:07:45 2013
@@ -1,7 +1,7 @@
/*
* Unit tests for MultiMedia Stream functions
*
- * Copyright (C) 2009 Christian Costa
+ * Copyright (C) 2009, 2012 Christian Costa
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
@@ -18,14 +18,22 @@
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
*/
+#define WIN32_NO_STATUS
+#define _INC_WINDOWS
+#define COM_NO_WINDOWS_H
+
#define COBJMACROS
-#include "wine/test.h"
-#include "initguid.h"
-#include "amstream.h"
-
-#define FILE_LEN 9
-static const char fileA[FILE_LEN] = "test.avi";
+#include <wine/test.h>
+#include <wingdi.h>
+#include <winnls.h>
+#include <vfwmsgs.h>
+#include <objbase.h>
+#include <initguid.h>
+#include <amstream.h>
+#include <dxsdk/uuids.h>
+
+static const WCHAR filenameW[] =
{'t','e','s','t','.','a','v','i',0};
static IAMMultiMediaStream* pams;
static IDirectDraw7* pdd7;
@@ -88,21 +96,11 @@
static void test_openfile(void)
{
- HANDLE h;
HRESULT hr;
- WCHAR fileW[FILE_LEN];
IGraphBuilder* pgraph;
if (!create_ammultimediastream())
return;
-
- h = CreateFileA(fileA, 0, 0, NULL, OPEN_EXISTING, 0, NULL);
- if (h == INVALID_HANDLE_VALUE) {
- release_ammultimediastream();
- return;
- }
-
- MultiByteToWideChar(CP_ACP, 0, fileA, -1, fileW, FILE_LEN);
hr = IAMMultiMediaStream_GetFilterGraph(pams, &pgraph);
ok(hr==S_OK, "IAMMultiMediaStream_GetFilterGraph returned: %x\n", hr);
@@ -111,7 +109,7 @@
if (pgraph)
IGraphBuilder_Release(pgraph);
- hr = IAMMultiMediaStream_OpenFile(pams, fileW, 0);
+ hr = IAMMultiMediaStream_OpenFile(pams, filenameW, 0);
ok(hr==S_OK, "IAMMultiMediaStream_OpenFile returned: %x\n", hr);
hr = IAMMultiMediaStream_GetFilterGraph(pams, &pgraph);
@@ -124,18 +122,20 @@
release_ammultimediastream();
}
-static void renderfile(const char * fileA)
+static void test_renderfile(void)
{
HRESULT hr;
- WCHAR fileW[FILE_LEN];
IMediaStream *pvidstream = NULL;
IDirectDrawMediaStream *pddstream = NULL;
IDirectDrawStreamSample *pddsample = NULL;
+ if (!create_ammultimediastream())
+ return;
if (!create_directdraw())
+ {
+ release_ammultimediastream();
return;
-
- MultiByteToWideChar(CP_ACP, 0, fileA, -1, fileW, FILE_LEN);
+ }
hr = IAMMultiMediaStream_Initialize(pams, STREAMTYPE_READ, 0, NULL);
ok(hr==S_OK, "IAMMultiMediaStream_Initialize returned: %x\n", hr);
@@ -146,7 +146,7 @@
hr = IAMMultiMediaStream_AddMediaStream(pams, NULL, &MSPID_PrimaryAudio,
AMMSF_ADDDEFAULTRENDERER, NULL);
ok(hr==S_OK, "IAMMultiMediaStream_AddMediaStream returned: %x\n", hr);
- hr = IAMMultiMediaStream_OpenFile(pams, fileW, 0);
+ hr = IAMMultiMediaStream_OpenFile(pams, filenameW, 0);
ok(hr==S_OK, "IAMMultiMediaStream_OpenFile returned: %x\n", hr);
hr = IAMMultiMediaStream_GetMediaStream(pams, &MSPID_PrimaryVideo,
&pvidstream);
@@ -158,39 +158,305 @@
if (FAILED(hr)) goto error;
hr = IDirectDrawMediaStream_CreateSample(pddstream, NULL, NULL, 0, &pddsample);
- todo_wine ok(hr==S_OK, "IDirectDrawMediaStream_CreateSample returned:
%x\n", hr);
+ ok(hr == S_OK, "IDirectDrawMediaStream_CreateSample returned: %x\n", hr);
error:
if (pddsample)
- IDirectDrawMediaSample_Release(pddsample);
+ IDirectDrawStreamSample_Release(pddsample);
if (pddstream)
IDirectDrawMediaStream_Release(pddstream);
if (pvidstream)
IMediaStream_Release(pvidstream);
release_directdraw();
-}
-
-static void test_render(void)
-{
- HANDLE h;
+ release_ammultimediastream();
+}
+
+static void test_media_streams(void)
+{
+ HRESULT hr;
+ IMediaStream *video_stream = NULL;
+ IMediaStream *audio_stream = NULL;
+ IMediaStream *dummy_stream;
+ IMediaStreamFilter* media_stream_filter = NULL;
if (!create_ammultimediastream())
return;
-
- h = CreateFileA(fileA, 0, 0, NULL, OPEN_EXISTING, 0, NULL);
- if (h != INVALID_HANDLE_VALUE) {
- CloseHandle(h);
- renderfile(fileA);
- }
-
+ if (!create_directdraw())
+ {
+ release_ammultimediastream();
+ return;
+ }
+
+ hr = IAMMultiMediaStream_Initialize(pams, STREAMTYPE_READ, 0, NULL);
+ ok(hr == S_OK, "IAMMultiMediaStream_Initialize returned: %x\n", hr);
+
+ /* Retrieve media stream filter */
+ hr = IAMMultiMediaStream_GetFilter(pams, NULL);
+ ok(hr == E_POINTER, "IAMMultiMediaStream_GetFilter returned: %x\n", hr);
+ hr = IAMMultiMediaStream_GetFilter(pams, &media_stream_filter);
+ ok(hr == S_OK, "IAMMultiMediaStream_GetFilter returned: %x\n", hr);
+
+ /* Verify behaviour with invalid purpose id */
+ hr = IAMMultiMediaStream_GetMediaStream(pams, &IID_IUnknown, &dummy_stream);
+ ok(hr == MS_E_NOSTREAM, "IAMMultiMediaStream_GetMediaStream returned:
%x\n", hr);
+ hr = IAMMultiMediaStream_AddMediaStream(pams, NULL, &IID_IUnknown, 0, NULL);
+ ok(hr == MS_E_PURPOSEID, "IAMMultiMediaStream_AddMediaStream returned:
%x\n", hr);
+
+ /* Verify there is no video media stream */
+ hr = IAMMultiMediaStream_GetMediaStream(pams, &MSPID_PrimaryVideo,
&video_stream);
+ ok(hr == MS_E_NOSTREAM, "IAMMultiMediaStream_GetMediaStream returned:
%x\n", hr);
+
+ /* Verify there is no default renderer for video stream */
+ hr = IAMMultiMediaStream_AddMediaStream(pams, (IUnknown*)pdd7,
&MSPID_PrimaryVideo, AMMSF_ADDDEFAULTRENDERER, NULL);
+ ok(hr == MS_E_PURPOSEID, "IAMMultiMediaStream_AddMediaStream returned:
%x\n", hr);
+ hr = IAMMultiMediaStream_GetMediaStream(pams, &MSPID_PrimaryVideo,
&video_stream);
+ ok(hr == MS_E_NOSTREAM, "IAMMultiMediaStream_GetMediaStream returned:
%x\n", hr);
+ hr = IAMMultiMediaStream_AddMediaStream(pams, NULL, &MSPID_PrimaryVideo,
AMMSF_ADDDEFAULTRENDERER, NULL);
+ ok(hr == MS_E_PURPOSEID, "IAMMultiMediaStream_AddMediaStream returned:
%x\n", hr);
+ hr = IAMMultiMediaStream_GetMediaStream(pams, &MSPID_PrimaryVideo,
&video_stream);
+ ok(hr == MS_E_NOSTREAM, "IAMMultiMediaStream_GetMediaStream returned:
%x\n", hr);
+
+ /* Verify normal case for video stream */
+ hr = IAMMultiMediaStream_AddMediaStream(pams, NULL, &MSPID_PrimaryVideo, 0,
NULL);
+ ok(hr == S_OK, "IAMMultiMediaStream_AddMediaStream returned: %x\n", hr);
+ hr = IAMMultiMediaStream_GetMediaStream(pams, &MSPID_PrimaryVideo,
&video_stream);
+ ok(hr == S_OK, "IAMMultiMediaStream_GetMediaStream returned: %x\n", hr);
+
+ /* Verify the video stream has been added to the media stream filter */
+ if (media_stream_filter)
+ {
+ hr = IMediaStreamFilter_GetMediaStream(media_stream_filter,
&MSPID_PrimaryVideo, &dummy_stream);
+ ok(hr == S_OK, "IMediaStreamFilter_GetMediaStream returned: %x\n",
hr);
+ ok(dummy_stream == video_stream, "Got wrong returned pointer %p, expected
%p\n", dummy_stream, video_stream);
+ if (SUCCEEDED(hr))
+ IMediaStream_Release(dummy_stream);
+ }
+
+ /* Check interfaces and samples for video */
+ if (video_stream)
+ {
+ IAMMediaStream* am_media_stream;
+ IAudioMediaStream* audio_media_stream;
+ IDirectDrawMediaStream *ddraw_stream = NULL;
+ IDirectDrawStreamSample *ddraw_sample = NULL;
+
+ hr = IMediaStream_QueryInterface(video_stream, &IID_IAMMediaStream,
(LPVOID*)&am_media_stream);
+ ok(hr == S_OK, "IMediaStream_QueryInterface returned: %x\n", hr);
+ ok((void*)am_media_stream == (void*)video_stream, "Not same interface, got
%p expected %p\n", am_media_stream, video_stream);
+ if (hr == S_OK)
+ IAMMediaStream_Release(am_media_stream);
+
+ hr = IMediaStream_QueryInterface(video_stream, &IID_IAudioMediaStream,
(LPVOID*)&audio_media_stream);
+ ok(hr == E_NOINTERFACE, "IMediaStream_QueryInterface returned: %x\n",
hr);
+
+ hr = IMediaStream_QueryInterface(video_stream, &IID_IDirectDrawMediaStream,
(LPVOID*)&ddraw_stream);
+ ok(hr == S_OK, "IMediaStream_QueryInterface returned: %x\n", hr);
+
+ if (SUCCEEDED(hr))
+ {
+ DDSURFACEDESC current_format, desired_format;
+ IDirectDrawPalette *palette;
+ DWORD flags;
+
+ hr = IDirectDrawMediaStream_GetFormat(ddraw_stream, ¤t_format,
&palette, &desired_format, &flags);
+ ok(hr == MS_E_NOSTREAM, "IDirectDrawoMediaStream_GetFormat returned:
%x\n", hr);
+
+ hr = IDirectDrawMediaStream_CreateSample(ddraw_stream, NULL, NULL, 0,
&ddraw_sample);
+ ok(hr == S_OK, "IDirectDrawMediaStream_CreateSample returned:
%x\n", hr);
+ }
+
+ if (ddraw_sample)
+ IDirectDrawStreamSample_Release(ddraw_sample);
+ if (ddraw_stream)
+ IDirectDrawMediaStream_Release(ddraw_stream);
+ }
+
+ /* Verify there is no audio media stream */
+ hr = IAMMultiMediaStream_GetMediaStream(pams, &MSPID_PrimaryAudio,
&audio_stream);
+ ok(hr == MS_E_NOSTREAM, "IAMMultiMediaStream_GetMediaStream returned:
%x\n", hr);
+
+ /* Verify no stream is created when using the default renderer for audio stream */
+ hr = IAMMultiMediaStream_AddMediaStream(pams, NULL, &MSPID_PrimaryAudio,
AMMSF_ADDDEFAULTRENDERER, NULL);
+ ok((hr == S_OK) || (hr == VFW_E_NO_AUDIO_HARDWARE),
"IAMMultiMediaStream_AddMediaStream returned: %x\n", hr);
+ if (hr == S_OK)
+ {
+ IGraphBuilder* filtergraph = NULL;
+ IBaseFilter* filter = NULL;
+ const WCHAR name[] = {'0','0','0','1',0};
+ CLSID clsid;
+
+ hr = IAMMultiMediaStream_GetFilterGraph(pams, &filtergraph);
+ ok(hr == S_OK, "IAMMultiMediaStream_GetFilterGraph returned: %x\n",
hr);
+ if (hr == S_OK)
+ {
+ hr = IGraphBuilder_FindFilterByName(filtergraph, name, &filter);
+ ok(hr == S_OK, "IGraphBuilder_FindFilterByName returned: %x\n",
hr);
+ }
+ if (hr == S_OK)
+ {
+ hr = IBaseFilter_GetClassID(filter, &clsid);
+ ok(hr == S_OK, "IGraphBuilder_FindFilterByName returned: %x\n",
hr);
+ }
+ if (hr == S_OK)
+ ok(IsEqualGUID(&clsid, &CLSID_DSoundRender), "Got wrong
CLSID\n");
+ if (filter)
+ IBaseFilter_Release(filter);
+ if (filtergraph)
+ IGraphBuilder_Release(filtergraph);
+ }
+ hr = IAMMultiMediaStream_GetMediaStream(pams, &MSPID_PrimaryAudio,
&audio_stream);
+ ok(hr == MS_E_NOSTREAM, "IAMMultiMediaStream_GetMediaStream returned:
%x\n", hr);
+
+ /* Verify a stream is created when no default renderer is used */
+ hr = IAMMultiMediaStream_AddMediaStream(pams, NULL, &MSPID_PrimaryAudio, 0,
NULL);
+ ok(hr == S_OK, "IAMMultiMediaStream_AddMediaStream returned: %x\n", hr);
+ hr = IAMMultiMediaStream_GetMediaStream(pams, &MSPID_PrimaryAudio,
&audio_stream);
+ ok(hr == S_OK, "IAMMultiMediaStream_GetMediaStream returned: %x\n", hr);
+
+ /* verify the audio stream has been added to the media stream filter */
+ if (media_stream_filter)
+ {
+ hr = IMediaStreamFilter_GetMediaStream(media_stream_filter,
&MSPID_PrimaryAudio, &dummy_stream);
+ ok(hr == S_OK, "IAMMultiMediaStream_GetMediaStream returned: %x\n",
hr);
+ ok(dummy_stream == audio_stream, "Got wrong returned pointer %p, expected
%p\n", dummy_stream, audio_stream);
+ if (SUCCEEDED(hr))
+ IMediaStream_Release(dummy_stream);
+ }
+
+ /* Check interfaces and samples for audio */
+ if (audio_stream)
+ {
+ IAMMediaStream* am_media_stream;
+ IDirectDrawMediaStream* ddraw_stream = NULL;
+ IAudioMediaStream* audio_media_stream = NULL;
+ IAudioStreamSample *audio_sample = NULL;
+
+ hr = IMediaStream_QueryInterface(audio_stream, &IID_IAMMediaStream,
(LPVOID*)&am_media_stream);
+ ok(hr == S_OK, "IMediaStream_QueryInterface returned: %x\n", hr);
+ ok((void*)am_media_stream == (void*)audio_stream, "Not same interface, got
%p expected %p\n", am_media_stream, audio_stream);
+ if (hr == S_OK)
+ IAMMediaStream_Release(am_media_stream);
+
+ hr = IMediaStream_QueryInterface(audio_stream, &IID_IDirectDrawMediaStream,
(LPVOID*)&ddraw_stream);
+ ok(hr == E_NOINTERFACE, "IMediaStream_QueryInterface returned: %x\n",
hr);
+
+ hr = IMediaStream_QueryInterface(audio_stream, &IID_IAudioMediaStream,
(LPVOID*)&audio_media_stream);
+ ok(hr == S_OK, "IMediaStream_QueryInterface returned: %x\n", hr);
+
+ if (SUCCEEDED(hr))
+ {
+ IAudioData* audio_data = NULL;
+ WAVEFORMATEX format;
+
+ hr = CoCreateInstance(&CLSID_AMAudioData, NULL, CLSCTX_INPROC_SERVER,
&IID_IAudioData, (void **)&audio_data);
+ ok(hr == S_OK, "CoCreateInstance returned: %x\n", hr);
+
+ hr = IAudioMediaStream_GetFormat(audio_media_stream, NULL);
+ ok(hr == E_POINTER, "IAudioMediaStream_GetFormat returned: %x\n",
hr);
+ hr = IAudioMediaStream_GetFormat(audio_media_stream, &format);
+ ok(hr == MS_E_NOSTREAM, "IAudioMediaStream_GetFormat returned:
%x\n", hr);
+
+ hr = IAudioMediaStream_CreateSample(audio_media_stream, NULL, 0,
&audio_sample);
+ ok(hr == E_POINTER, "IAudioMediaStream_CreateSample returned:
%x\n", hr);
+ hr = IAudioMediaStream_CreateSample(audio_media_stream, audio_data, 0,
&audio_sample);
+ ok(hr == S_OK, "IAudioMediaStream_CreateSample returned: %x\n",
hr);
+
+ if (audio_data)
+ IAudioData_Release(audio_data);
+ if (audio_sample)
+ IAudioStreamSample_Release(audio_sample);
+ if (audio_media_stream)
+ IAudioMediaStream_Release(audio_media_stream);
+ }
+ }
+
+ if (media_stream_filter)
+ {
+ IEnumPins *enum_pins;
+
+ hr = IMediaStreamFilter_EnumPins(media_stream_filter, &enum_pins);
+ ok(hr == S_OK, "IBaseFilter_EnumPins returned: %x\n", hr);
+ if (hr == S_OK)
+ {
+ IPin* pins[3] = { NULL, NULL, NULL };
+ ULONG nb_pins;
+ ULONG expected_nb_pins = audio_stream ? 2 : 1;
+ int i;
+
+ hr = IEnumPins_Next(enum_pins, 3, pins, &nb_pins);
+ ok(SUCCEEDED(hr), "IEnumPins_Next returned: %x\n", hr);
+ ok(nb_pins == expected_nb_pins, "Number of pins is %u instead of
%u\n", nb_pins, expected_nb_pins);
+ for (i = 0; i < min(nb_pins, expected_nb_pins); i++)
+ {
+ IEnumMediaTypes* enum_media_types;
+ AM_MEDIA_TYPE* media_types[10];
+ ULONG nb_media_types;
+ IPin* pin;
+ PIN_INFO info;
+ WCHAR id[40];
+
+ /* Pin name is "I{guid MSPID_PrimaryVideo or
MSPID_PrimaryAudio}" */
+ id[0] = 'I';
+ StringFromGUID2(i ? &MSPID_PrimaryAudio : &MSPID_PrimaryVideo, id
+ 1, 40);
+
+ hr = IPin_ConnectedTo(pins[i], &pin);
+ ok(hr == VFW_E_NOT_CONNECTED, "IPin_ConnectedTo returned:
%x\n", hr);
+ hr = IPin_QueryPinInfo(pins[i], &info);
+ ok(hr == S_OK, "IPin_QueryPinInfo returned: %x\n", hr);
+ IBaseFilter_Release(info.pFilter);
+ ok(info.dir == PINDIR_INPUT, "Pin direction is %u instead of
%u\n", info.dir, PINDIR_INPUT);
+ ok(!lstrcmpW(info.achName, id), "Pin name is %s instead of
%s\n", wine_dbgstr_w(info.achName), wine_dbgstr_w(id));
+ hr = IPin_EnumMediaTypes(pins[i], &enum_media_types);
+ ok(hr == S_OK, "IPin_EnumMediaTypes returned: %x\n", hr);
+ hr = IEnumMediaTypes_Next(enum_media_types, sizeof(media_types) /
sizeof(AM_MEDIA_TYPE), media_types, &nb_media_types);
+ ok(SUCCEEDED(hr), "IEnumMediaTypes_Next returned: %x\n", hr);
+ ok(nb_media_types == 0, "nb_media_types should be 0 instead of
%u\n", nb_media_types);
+ IEnumMediaTypes_Release(enum_media_types);
+ IPin_Release(pins[i]);
+ }
+ IEnumPins_Release(enum_pins);
+ }
+ }
+
+ /* Test open file with no filename */
+ hr = IAMMultiMediaStream_OpenFile(pams, NULL, 0);
+ ok(hr == E_POINTER, "IAMMultiMediaStream_OpenFile returned %x instead of
%x\n", hr, E_POINTER);
+
+ if (video_stream)
+ IMediaStream_Release(video_stream);
+ if (audio_stream)
+ IMediaStream_Release(audio_stream);
+ if (media_stream_filter)
+ IMediaStreamFilter_Release(media_stream_filter);
+
+ release_directdraw();
release_ammultimediastream();
}
START_TEST(amstream)
{
+ HANDLE file;
+
CoInitializeEx(NULL, COINIT_MULTITHREADED);
- test_openfile();
- test_render();
+
+ if (!winetest_interactive)
+ {
+ win_skip("test_media_streams(), ROSTESTS-123\n");
+ }
+ else
+ {
+ test_media_streams();
+ }
+
+ file = CreateFileW(filenameW, 0, 0, NULL, OPEN_EXISTING, 0, NULL);
+ if (file != INVALID_HANDLE_VALUE)
+ {
+ CloseHandle(file);
+
+ test_openfile();
+ test_renderfile();
+ }
+
CoUninitialize();
}
Modified: trunk/rostests/winetests/amstream/testlist.c
URL:
http://svn.reactos.org/svn/reactos/trunk/rostests/winetests/amstream/testli…
==============================================================================
--- trunk/rostests/winetests/amstream/testlist.c [iso-8859-1] (original)
+++ trunk/rostests/winetests/amstream/testlist.c [iso-8859-1] Tue Oct 1 15:07:45 2013
@@ -1,10 +1,7 @@
/* Automatically generated file; DO NOT EDIT!! */
-#define WIN32_LEAN_AND_MEAN
-#include <windows.h>
-
#define STANDALONE
-#include "wine/test.h"
+#include <wine/test.h>
extern void func_amstream(void);