[PATCH v4] dmime/tests: Add a notification_type test

Michael Stefaniuc mstefani at winehq.org
Thu Oct 3 15:29:12 CDT 2019


Signed-off-by: Michael Stefaniuc <mstefani at winehq.org>

On 10/3/19 10:42 AM, Alistair Leslie-Hughes wrote:
> Signed-off-by: Alistair Leslie-Hughes <leslie_alistair at hotmail.com>
> ---
> Reset timeout to 500.
> Fixed failures of testbox.
> It wasn't a timeout issue after all, its possible to get a DMUS_NOTIFICATION_SEGALMOSTEND
> message, which needs to be treated the same as DMUS_NOTIFICATION_SEGEND.
> 
>  dlls/dmime/tests/performance.c | 117 +++++++++++++++++++++++++++++++++
>  1 file changed, 117 insertions(+)
> 
> diff --git a/dlls/dmime/tests/performance.c b/dlls/dmime/tests/performance.c
> index c2ca4cdf28..4433846f9b 100644
> --- a/dlls/dmime/tests/performance.c
> +++ b/dlls/dmime/tests/performance.c
> @@ -366,6 +366,122 @@ static void test_COM(void)
>      ok (refcount == 0, "refcount == %u, expected 0\n", refcount);
>  }
>  
> +static void test_notification_type(void)
> +{
> +    static unsigned char rifffile[8+4+8+16+8+256] = "RIFF\x24\x01\x00\x00WAVE" /* header: 4 ("WAVE") + (8 + 16) (format segment) + (8 + 256) (data segment) = 0x124 */
> +        "fmt \x10\x00\x00\x00\x01\x00\x20\x00\xAC\x44\x00\x00\x10\xB1\x02\x00\x04\x00\x10\x00" /* format segment: PCM, 2 chan, 44100 Hz, 16 bits */
> +        "data\x00\x01\x00\x00"; /* 256 byte data segment (silence) */
> +
> +    IDirectMusicPerformance8 *perf;
> +    IDirectMusic *music = NULL;
> +    IDirectMusicSegment8 *prime_segment8;
> +    IDirectMusicSegment8 *segment8 = NULL;
> +    IDirectMusicLoader8 *loader;
> +    IDirectMusicAudioPath8 *path;
> +    IDirectMusicSegmentState *state;
> +    IDirectSound *dsound = NULL;
> +    HRESULT hr;
> +    DWORD result;
> +    HANDLE messages;
> +    DMUS_NOTIFICATION_PMSG *msg;
> +    BOOL found_end = FALSE;
> +    DMUS_OBJECTDESC desc = {0};
> +
> +    hr = CoCreateInstance(&CLSID_DirectMusicPerformance, NULL,
> +            CLSCTX_INPROC_SERVER, &IID_IDirectMusicPerformance8, (void**)&perf);
> +    ok(hr == S_OK, "CoCreateInstance failed: %08x\n", hr);
> +
> +    hr = IDirectMusicPerformance8_InitAudio(perf, &music, &dsound, NULL, DMUS_APATH_DYNAMIC_STEREO, 64, DMUS_AUDIOF_ALL, NULL);
> +    ok(music != NULL, "Didn't get IDirectMusic pointer\n");
> +    ok(dsound != NULL, "Didn't get IDirectSound pointer\n");
> +
> +    hr = CoCreateInstance(&CLSID_DirectMusicLoader, NULL, CLSCTX_INPROC_SERVER,  &IID_IDirectMusicLoader8, (void**)&loader);
> +    ok(hr == S_OK, "CoCreateInstance failed: %08x\n", hr);
> +
> +    messages = CreateEventA( NULL, FALSE, FALSE, NULL );
> +
> +    hr = IDirectMusicPerformance8_AddNotificationType(perf, &GUID_NOTIFICATION_SEGMENT);
> +    ok(hr == S_OK, "Failed: %08x\n", hr);
> +
> +    hr = IDirectMusicPerformance8_SetNotificationHandle(perf, messages, 0);
> +    ok(hr == S_OK, "Failed: %08x\n", hr);
> +
> +    hr = IDirectMusicPerformance8_GetDefaultAudioPath(perf, &path);
> +    ok(hr == S_OK, "Failed: %08x\n", hr);
> +    ok(path != NULL, "Didn't get IDirectMusicAudioPath pointer\n");
> +
> +    desc.dwSize = sizeof(DMUS_OBJECTDESC);
> +    desc.dwValidData = DMUS_OBJ_CLASS | DMUS_OBJ_MEMORY;
> +    desc.guidClass = CLSID_DirectMusicSegment;
> +    desc.pbMemData = rifffile;
> +    desc.llMemLength = sizeof(rifffile);
> +    hr = IDirectMusicLoader8_GetObject(loader, &desc, &IID_IDirectMusicSegment8, (void**)&prime_segment8);
> +    ok(hr == S_OK, "Failed: %08x\n", hr);
> +    ok(prime_segment8 != NULL, "Didn't get IDirectMusicSegment pointer\n");
> +
> +    hr = IDirectMusicSegment8_Download(prime_segment8, (IUnknown*)path);
> +    ok(hr == S_OK, "Download failed: %08x\n", hr);
> +
> +    hr = IDirectMusicPerformance8_PlaySegmentEx(perf, (IUnknown*)prime_segment8,
> +            NULL, NULL, DMUS_SEGF_SECONDARY, 0, &state, NULL, (IUnknown*)path);
> +    ok(hr == S_OK, "PlaySegmentEx failed: %08x\n", hr);
> +    ok(state != NULL, "Didn't get IDirectMusicSegmentState pointer\n");
> +
> +    while (!found_end) {
> +        result = WaitForSingleObject(messages, 500);
> +        todo_wine ok(result == WAIT_OBJECT_0, "Failed: %d\n", result);
> +        if (result != WAIT_OBJECT_0)
> +            break;
> +
> +        msg = NULL;
> +        hr = IDirectMusicPerformance8_GetNotificationPMsg(perf, &msg);
> +        ok(hr == S_OK, "Failed: %08x\n", hr);
> +        ok(msg != NULL, "Unexpected NULL pointer\n");
> +        if (FAILED(hr) || !msg)
> +            break;
> +
> +        trace("Notification: %d\n", msg->dwNotificationOption);
> +
> +        if (msg->dwNotificationOption == DMUS_NOTIFICATION_SEGEND ||
> +            msg->dwNotificationOption == DMUS_NOTIFICATION_SEGALMOSTEND) {
> +            ok(msg->punkUser != NULL, "Unexpected NULL pointer\n");
> +            if (msg->punkUser) {
> +                IDirectMusicSegmentState8 *segmentstate;
> +                IDirectMusicSegment       *segment;
> +
> +                hr = IUnknown_QueryInterface(msg->punkUser, &IID_IDirectMusicSegmentState8, (void**)&segmentstate);
> +                ok(hr == S_OK, "Failed: %08x\n", hr);
> +
> +                hr = IDirectMusicSegmentState8_GetSegment(segmentstate, &segment);
> +                ok(hr == S_OK, "Failed: %08x\n", hr);
> +
> +                hr = IDirectMusicSegment_QueryInterface(segment, &IID_IDirectMusicSegment8, (void**)&segment8);
> +                ok(hr == S_OK, "Failed: %08x\n", hr);
> +
> +                found_end = TRUE;
> +
> +                IDirectMusicSegment_Release(segment);
> +                IDirectMusicSegmentState8_Release(segmentstate);
> +            }
> +        }
> +
> +        IDirectMusicPerformance8_FreePMsg(perf, (DMUS_PMSG*)msg);
> +    }
> +    todo_wine ok(prime_segment8 == segment8, "Wrong end segment\n");
> +    todo_wine ok(found_end, "Didn't recieve DMUS_NOTIFICATION_SEGEND message\n");
> +
> +    CloseHandle(messages);
> +
> +    if(segment8)
> +        IDirectMusicSegment8_Release(segment8);
> +    IDirectSound_Release(dsound);
> +    IDirectMusicSegmentState_Release(state);
> +    IDirectMusicAudioPath_Release(path);
> +    IDirectMusicLoader8_Release(loader);
> +    IDirectMusic_Release(music);
> +    IDirectMusicPerformance8_Release(perf);
> +}
> +
>  START_TEST( performance )
>  {
>      HRESULT hr;
> @@ -384,6 +500,7 @@ START_TEST( performance )
>  
>      test_COM();
>      test_createport();
> +    test_notification_type();
>  
>      CoUninitialize();
>  }
> 




More information about the wine-devel mailing list