[PATCH v2 5/5] dsdmo/tests: Add some tests for media types.
Zebediah Figura
z.figura12 at gmail.com
Thu Jul 23 11:47:03 CDT 2020
Signed-off-by: Zebediah Figura <z.figura12 at gmail.com>
---
dlls/dsdmo/tests/dsdmo.c | 136 +++++++++++++++++++++++++++++++++++++++
1 file changed, 136 insertions(+)
diff --git a/dlls/dsdmo/tests/dsdmo.c b/dlls/dsdmo/tests/dsdmo.c
index 298ebadcf9..b8f0932790 100644
--- a/dlls/dsdmo/tests/dsdmo.c
+++ b/dlls/dsdmo/tests/dsdmo.c
@@ -162,6 +162,141 @@ static void test_interfaces(const GUID *clsid, const GUID *iid)
ok(!ref, "Got outstanding refcount %d.\n", ref);
}
+static void build_pcm_format(WAVEFORMATEX *format, WORD tag, WORD depth, DWORD sample_rate, WORD channels)
+{
+ format->wFormatTag = tag;
+ format->wBitsPerSample = depth;
+ format->nChannels = channels;
+ format->nSamplesPerSec = sample_rate;
+ format->nBlockAlign = channels * depth / 8;
+ format->nAvgBytesPerSec = sample_rate * channels * depth / 8;
+ format->cbSize = 0;
+}
+
+static void test_media_types(const GUID *clsid)
+{
+ WAVEFORMATEX wfx;
+ DMO_MEDIA_TYPE mt =
+ {
+ .majortype = MEDIATYPE_Audio,
+ .subtype = MEDIASUBTYPE_PCM,
+ .formattype = FORMAT_WaveFormatEx,
+ .cbFormat = sizeof(wfx),
+ .pbFormat = (BYTE *)&wfx,
+ };
+ IMediaObject *dmo;
+ unsigned int i, j;
+ WORD channels;
+ HRESULT hr;
+ ULONG ref;
+
+ static const DWORD sample_rates[] = {8000, 11025, 22050, 44100, 48000, 96000};
+ static const struct
+ {
+ WORD format;
+ WORD depth;
+ }
+ depths[] =
+ {
+ {WAVE_FORMAT_PCM, 8},
+ {WAVE_FORMAT_PCM, 16},
+ {WAVE_FORMAT_IEEE_FLOAT, 32},
+ };
+
+ hr = CoCreateInstance(clsid, NULL, CLSCTX_INPROC_SERVER, &IID_IMediaObject, (void **)&dmo);
+ todo_wine ok(hr == S_OK, "Got hr %#x.\n", hr);
+ if (hr != S_OK)
+ return;
+
+ build_pcm_format(&wfx, WAVE_FORMAT_PCM, 16, 44100, 2);
+
+ mt.majortype = MEDIATYPE_Video;
+ hr = IMediaObject_SetInputType(dmo, 0, &mt, 0);
+ todo_wine ok(hr == DMO_E_TYPE_NOT_ACCEPTED, "Got hr %#x.\n", hr);
+ mt.majortype = GUID_NULL;
+ hr = IMediaObject_SetInputType(dmo, 0, &mt, 0);
+ todo_wine ok(hr == DMO_E_TYPE_NOT_ACCEPTED, "Got hr %#x.\n", hr);
+ mt.majortype = MEDIATYPE_Audio;
+
+ mt.subtype = MEDIASUBTYPE_RGB8;
+ hr = IMediaObject_SetInputType(dmo, 0, &mt, 0);
+ todo_wine ok(hr == DMO_E_TYPE_NOT_ACCEPTED, "Got hr %#x.\n", hr);
+ mt.subtype = GUID_NULL;
+ hr = IMediaObject_SetInputType(dmo, 0, &mt, 0);
+ todo_wine ok(hr == DMO_E_TYPE_NOT_ACCEPTED, "Got hr %#x.\n", hr);
+ mt.subtype = MEDIASUBTYPE_IEEE_FLOAT;
+ hr = IMediaObject_SetInputType(dmo, 0, &mt, 0);
+ todo_wine ok(hr == S_OK, "Got hr %#x.\n", hr);
+ mt.subtype = MEDIASUBTYPE_PCM;
+
+ mt.formattype = FORMAT_VideoInfo;
+ hr = IMediaObject_SetInputType(dmo, 0, &mt, 0);
+ todo_wine ok(hr == DMO_E_TYPE_NOT_ACCEPTED, "Got hr %#x.\n", hr);
+ mt.formattype = FORMAT_None;
+ hr = IMediaObject_SetInputType(dmo, 0, &mt, 0);
+ todo_wine ok(hr == DMO_E_TYPE_NOT_ACCEPTED, "Got hr %#x.\n", hr);
+ mt.formattype = GUID_NULL;
+ hr = IMediaObject_SetInputType(dmo, 0, &mt, 0);
+ todo_wine ok(hr == DMO_E_TYPE_NOT_ACCEPTED, "Got hr %#x.\n", hr);
+ mt.formattype = FORMAT_WaveFormatEx;
+
+ for (i = 0; i < ARRAY_SIZE(sample_rates); ++i)
+ {
+ for (j = 0; j < ARRAY_SIZE(depths); ++j)
+ {
+ /* Waves reverberation is documented as not supporting 8-bit PCM. */
+ if (IsEqualGUID(clsid, &GUID_DSFX_WAVES_REVERB) && depths[j].depth == 8)
+ continue;
+
+ for (channels = 1; channels <= 2; ++channels)
+ {
+ build_pcm_format(&wfx, depths[j].format, depths[j].depth, sample_rates[i], channels);
+
+ hr = IMediaObject_SetInputType(dmo, 0, &mt, 0);
+ todo_wine ok(hr == S_OK, "Got hr %#x for %u Hz, %u channels, format %#x, depth %u.\n",
+ hr, sample_rates[i], channels, depths[j].format, depths[j].depth);
+
+ /* The output type must match the input type. */
+
+ build_pcm_format(&wfx, depths[j].format, depths[j].depth, sample_rates[i], 3 - channels);
+ hr = IMediaObject_SetOutputType(dmo, 0, &mt, 0);
+ todo_wine ok(hr == DMO_E_TYPE_NOT_ACCEPTED, "Got hr %#x for %u Hz, %u channels, format %#x, depth %u.\n",
+ hr, sample_rates[i], channels, depths[j].format, depths[j].depth);
+
+ build_pcm_format(&wfx, depths[j].format, depths[j].depth, 2 * sample_rates[i], channels);
+ hr = IMediaObject_SetOutputType(dmo, 0, &mt, 0);
+ todo_wine ok(hr == DMO_E_TYPE_NOT_ACCEPTED, "Got hr %#x for %u Hz, %u channels, format %#x, depth %u.\n",
+ hr, sample_rates[i], channels, depths[j].format, depths[j].depth);
+
+ build_pcm_format(&wfx, depths[j].format, 24 - depths[j].depth, sample_rates[i], channels);
+ hr = IMediaObject_SetOutputType(dmo, 0, &mt, 0);
+ todo_wine ok(hr == DMO_E_TYPE_NOT_ACCEPTED, "Got hr %#x for %u Hz, %u channels, format %#x, depth %u.\n",
+ hr, sample_rates[i], channels, depths[j].format, depths[j].depth);
+
+ build_pcm_format(&wfx, depths[j].format, depths[j].depth, sample_rates[i], channels);
+ hr = IMediaObject_SetOutputType(dmo, 0, &mt, 0);
+ todo_wine ok(hr == S_OK, "Got hr %#x for %u Hz, %u channels, format %#x, depth %u.\n",
+ hr, sample_rates[i], channels, depths[j].format, depths[j].depth);
+
+ hr = IMediaObject_SetInputType(dmo, 0, NULL, DMO_SET_TYPEF_CLEAR);
+ todo_wine ok(hr == S_OK, "Got hr %#x for %u Hz, %u channels, format %#x, depth %u.\n",
+ hr, sample_rates[i], channels, depths[j].format, depths[j].depth);
+
+ hr = IMediaObject_SetOutputType(dmo, 0, NULL, DMO_SET_TYPEF_CLEAR);
+ todo_wine ok(hr == S_OK, "Got hr %#x for %u Hz, %u channels, format %#x, depth %u.\n",
+ hr, sample_rates[i], channels, depths[j].format, depths[j].depth);
+
+ hr = IMediaObject_SetInputType(dmo, 0, NULL, DMO_SET_TYPEF_CLEAR);
+ todo_wine ok(hr == S_OK, "Got hr %#x for %u Hz, %u channels, format %#x, depth %u.\n",
+ hr, sample_rates[i], channels, depths[j].format, depths[j].depth);
+ }
+ }
+ }
+
+ ref = IMediaObject_Release(dmo);
+ ok(!ref, "Got outstanding refcount %d.\n", ref);
+}
+
static void test_chorus_parameters(void)
{
IDirectSoundFXChorus *chorus;
@@ -394,6 +529,7 @@ START_TEST(dsdmo)
{
test_aggregation(tests[i].clsid);
test_interfaces(tests[i].clsid, tests[i].iid);
+ test_media_types(tests[i].clsid);
}
test_chorus_parameters();
--
2.27.0
More information about the wine-devel
mailing list