[PATCH v6 4/7] wmvcore/tests: Add some IWMOutputMediaProps_SetMediaType tests.
Rémi Bernon
wine at gitlab.winehq.org
Tue Jul 5 06:03:07 CDT 2022
From: Rémi Bernon <rbernon at codeweavers.com>
Signed-off-by: Rémi Bernon <rbernon at codeweavers.com>
---
dlls/wmvcore/tests/wmvcore.c | 143 +++++++++++++++++++++++++++++++++++
1 file changed, 143 insertions(+)
diff --git a/dlls/wmvcore/tests/wmvcore.c b/dlls/wmvcore/tests/wmvcore.c
index f639184de90..bbac572acb5 100644
--- a/dlls/wmvcore/tests/wmvcore.c
+++ b/dlls/wmvcore/tests/wmvcore.c
@@ -48,6 +48,61 @@ static BOOL compare_media_types(const WM_MEDIA_TYPE *a, const WM_MEDIA_TYPE *b)
&& !memcmp(a->pbFormat, b->pbFormat, a->cbFormat);
}
+static void init_audio_type(WM_MEDIA_TYPE *mt, const GUID *subtype, UINT bits, UINT channels, UINT rate)
+{
+ WAVEFORMATEX *format = (WAVEFORMATEX *)(mt + 1);
+
+ format->wFormatTag = subtype->Data1;
+ format->nChannels = channels;
+ format->nSamplesPerSec = rate;
+ format->wBitsPerSample = bits;
+ format->nBlockAlign = format->nChannels * format->wBitsPerSample;
+ format->nAvgBytesPerSec = format->nSamplesPerSec * format->nBlockAlign / 8;
+ format->cbSize = sizeof(*format);
+
+ mt->majortype = MEDIATYPE_Audio;
+ mt->subtype = *subtype;
+ mt->bFixedSizeSamples = TRUE;
+ mt->bTemporalCompression = FALSE;
+ mt->lSampleSize = format->nAvgBytesPerSec;
+ mt->formattype = FORMAT_WaveFormatEx;
+ mt->pUnk = NULL;
+ mt->cbFormat = sizeof(*format);
+ mt->pbFormat = (BYTE *)format;
+}
+
+static void init_video_type(WM_MEDIA_TYPE *mt, const GUID *subtype, UINT depth, const RECT *rect)
+{
+ VIDEOINFOHEADER *video_info = (VIDEOINFOHEADER *)(mt + 1);
+
+ video_info->rcSource = *rect;
+ video_info->rcTarget = *rect;
+ video_info->dwBitRate = 0;
+ video_info->dwBitErrorRate = 0;
+ video_info->AvgTimePerFrame = 0;
+ video_info->bmiHeader.biSize = sizeof(video_info->bmiHeader);
+ video_info->bmiHeader.biWidth = rect->right;
+ video_info->bmiHeader.biHeight = rect->bottom;
+ video_info->bmiHeader.biPlanes = 1;
+ video_info->bmiHeader.biBitCount = depth;
+ video_info->bmiHeader.biCompression = subtype->Data1;
+ video_info->bmiHeader.biSizeImage = rect->right * rect->bottom * 4;
+ video_info->bmiHeader.biXPelsPerMeter = 0;
+ video_info->bmiHeader.biYPelsPerMeter = 0;
+ video_info->bmiHeader.biClrUsed = 0;
+ video_info->bmiHeader.biClrImportant = 0;
+
+ mt->majortype = MEDIATYPE_Video;
+ mt->subtype = *subtype;
+ mt->bFixedSizeSamples = TRUE;
+ mt->bTemporalCompression = FALSE;
+ mt->lSampleSize = video_info->bmiHeader.biSizeImage;
+ mt->formattype = FORMAT_VideoInfo;
+ mt->pUnk = NULL;
+ mt->cbFormat = sizeof(*video_info);
+ mt->pbFormat = (BYTE *)video_info;
+}
+
static WCHAR *load_resource(const WCHAR *name)
{
static WCHAR pathW[MAX_PATH];
@@ -1239,6 +1294,44 @@ static void test_sync_reader_types(void)
ok(IsEqualGUID(&majortype2, &majortype), "Expected major type %s, got %s.\n",
debugstr_guid(&majortype), debugstr_guid(&majortype2));
+ hr = IWMOutputMediaProps_SetMediaType(output_props, NULL);
+ todo_wine
+ ok(hr == E_POINTER, "Got hr %#lx.\n", hr);
+
+ memset(mt2_buffer, 0, sizeof(mt2_buffer));
+ hr = IWMOutputMediaProps_SetMediaType(output_props, mt2);
+ todo_wine
+ ok(hr == E_FAIL, "Got hr %#lx.\n", hr);
+
+ if (IsEqualGUID(&majortype, &MEDIATYPE_Audio))
+ {
+ WAVEFORMATEX *format = (WAVEFORMATEX *)mt->pbFormat;
+ init_audio_type(mt2, &MEDIASUBTYPE_IEEE_FLOAT, 32, format->nChannels, format->nSamplesPerSec);
+ hr = IWMOutputMediaProps_SetMediaType(output_props, mt2);
+ todo_wine
+ ok(hr == S_OK, "Got hr %#lx.\n", hr);
+ hr = IWMSyncReader_SetOutputProps(reader, output_number, output_props);
+ todo_wine
+ ok(hr == NS_E_AUDIO_CODEC_NOT_INSTALLED, "Got hr %#lx.\n", hr);
+ }
+ else
+ {
+ VIDEOINFO *info = (VIDEOINFO *)mt->pbFormat;
+ init_video_type(mt2, &MEDIASUBTYPE_AYUV, 32, &info->rcTarget);
+ hr = IWMOutputMediaProps_SetMediaType(output_props, mt2);
+ todo_wine
+ ok(hr == S_OK, "Got hr %#lx.\n", hr);
+ hr = IWMSyncReader_SetOutputProps(reader, output_number, output_props);
+ todo_wine
+ ok(hr == ASF_E_BADMEDIATYPE, "Got hr %#lx.\n", hr);
+ }
+
+ hr = IWMOutputMediaProps_SetMediaType(output_props, mt);
+ todo_wine
+ ok(hr == S_OK, "Got hr %#lx.\n", hr);
+ hr = IWMSyncReader_SetOutputProps(reader, output_number, output_props);
+ ok(hr == S_OK, "Got hr %#lx.\n", hr);
+
ref = IWMOutputMediaProps_Release(output_props);
ok(!ref, "Got outstanding refcount %ld.\n", ref);
@@ -1293,9 +1386,15 @@ static void test_sync_reader_types(void)
ok(IsEqualGUID(&mt->majortype, &majortype), "Got major type %s.\n", debugstr_guid(&mt->majortype));
if (IsEqualGUID(&mt->majortype, &MEDIATYPE_Audio))
+ {
+ ok(IsEqualGUID(&mt->subtype, &MEDIASUBTYPE_PCM), "Got subtype %s.\n", debugstr_guid(&mt->subtype));
check_audio_type(mt);
+ }
else
+ {
+ ok(!IsEqualGUID(&mt->subtype, &MEDIASUBTYPE_AYUV), "Got subtype %s.\n", debugstr_guid(&mt->subtype));
check_video_type(mt);
+ }
memset(&majortype2, 0xcc, sizeof(majortype2));
hr = IWMOutputMediaProps_GetType(output_props, &majortype2);
@@ -2362,6 +2461,44 @@ static void test_async_reader_types(void)
ok(IsEqualGUID(&majortype2, &majortype), "Expected major type %s, got %s.\n",
debugstr_guid(&majortype), debugstr_guid(&majortype2));
+ hr = IWMOutputMediaProps_SetMediaType(output_props, NULL);
+ todo_wine
+ ok(hr == E_POINTER, "Got hr %#lx.\n", hr);
+
+ memset(mt2_buffer, 0, sizeof(mt2_buffer));
+ hr = IWMOutputMediaProps_SetMediaType(output_props, mt2);
+ todo_wine
+ ok(hr == E_FAIL, "Got hr %#lx.\n", hr);
+
+ if (IsEqualGUID(&majortype, &MEDIATYPE_Audio))
+ {
+ WAVEFORMATEX *format = (WAVEFORMATEX *)mt->pbFormat;
+ init_audio_type(mt2, &MEDIASUBTYPE_IEEE_FLOAT, 32, format->nChannels, format->nSamplesPerSec);
+ hr = IWMOutputMediaProps_SetMediaType(output_props, mt2);
+ todo_wine
+ ok(hr == S_OK, "Got hr %#lx.\n", hr);
+ hr = IWMReader_SetOutputProps(reader, output_number, output_props);
+ todo_wine
+ ok(hr == NS_E_AUDIO_CODEC_NOT_INSTALLED, "Got hr %#lx.\n", hr);
+ }
+ else
+ {
+ VIDEOINFO *info = (VIDEOINFO *)mt->pbFormat;
+ init_video_type(mt2, &MEDIASUBTYPE_AYUV, 32, &info->rcTarget);
+ hr = IWMOutputMediaProps_SetMediaType(output_props, mt2);
+ todo_wine
+ ok(hr == S_OK, "Got hr %#lx.\n", hr);
+ hr = IWMReader_SetOutputProps(reader, output_number, output_props);
+ todo_wine
+ ok(hr == ASF_E_BADMEDIATYPE, "Got hr %#lx.\n", hr);
+ }
+
+ hr = IWMOutputMediaProps_SetMediaType(output_props, mt);
+ todo_wine
+ ok(hr == S_OK, "Got hr %#lx.\n", hr);
+ hr = IWMReader_SetOutputProps(reader, output_number, output_props);
+ ok(hr == S_OK, "Got hr %#lx.\n", hr);
+
ref = IWMOutputMediaProps_Release(output_props);
ok(!ref, "Got outstanding refcount %ld.\n", ref);
@@ -2438,9 +2575,15 @@ static void test_async_reader_types(void)
ok(IsEqualGUID(&mt->majortype, &majortype), "Got major type %s.\n", debugstr_guid(&mt->majortype));
if (IsEqualGUID(&mt->majortype, &MEDIATYPE_Audio))
+ {
+ ok(IsEqualGUID(&mt->subtype, &MEDIASUBTYPE_PCM), "Got subtype %s.\n", debugstr_guid(&mt->subtype));
check_audio_type(mt);
+ }
else
+ {
+ ok(!IsEqualGUID(&mt->subtype, &MEDIASUBTYPE_AYUV), "Got subtype %s.\n", debugstr_guid(&mt->subtype));
check_video_type(mt);
+ }
memset(&majortype2, 0xcc, sizeof(majortype2));
hr = IWMOutputMediaProps_GetType(output_props, &majortype2);
--
GitLab
https://gitlab.winehq.org/wine/wine/-/merge_requests/140
More information about the wine-devel
mailing list