Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
eedde528
Commit
eedde528
authored
Sep 13, 2023
by
Rémi Bernon
Committed by
Alexandre Julliard
Sep 18, 2023
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
dmime/tests: Test that SendPMsg also converts reference time.
And avoid checking a possibly freed message.
parent
9a28dbfb
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
77 additions
and
32 deletions
+77
-32
dmime.c
dlls/dmime/tests/dmime.c
+77
-32
No files found.
dlls/dmime/tests/dmime.c
View file @
eedde528
...
...
@@ -1730,9 +1730,10 @@ static void test_performance_pmsg(void)
static
const
DWORD
delivery_flags
[]
=
{
DMUS_PMSGF_TOOL_IMMEDIATE
,
DMUS_PMSGF_TOOL_QUEUE
,
DMUS_PMSGF_TOOL_ATTIME
};
static
const
DWORD
message_types
[]
=
{
DMUS_PMSGT_MIDI
,
DMUS_PMSGT_USER
};
IDirectMusicPerformance
*
performance
;
IDirectMusicGraph
*
graph
;
IDirectMusicGraph
*
graph
,
*
performance_graph
;
IDirectMusicTool
*
tool
;
DMUS_PMSG
*
msg
,
*
clone
;
MUSIC_TIME
music_time
;
REFERENCE_TIME
time
;
HRESULT
hr
;
DWORD
ret
;
...
...
@@ -1744,6 +1745,8 @@ static void test_performance_pmsg(void)
hr
=
CoCreateInstance
(
&
CLSID_DirectMusicPerformance
,
NULL
,
CLSCTX_INPROC_SERVER
,
&
IID_IDirectMusicPerformance
,
(
void
**
)
&
performance
);
ok
(
hr
==
S_OK
,
"got %#lx
\n
"
,
hr
);
hr
=
IDirectMusicPerformance_QueryInterface
(
performance
,
&
IID_IDirectMusicGraph
,
(
void
**
)
&
performance_graph
);
ok
(
hr
==
S_OK
,
"got %#lx
\n
"
,
hr
);
hr
=
IDirectMusicPerformance_AllocPMsg
(
performance
,
0
,
NULL
);
...
...
@@ -1826,6 +1829,40 @@ static void test_performance_pmsg(void)
ok
(
hr
==
S_OK
,
"got %#lx
\n
"
,
hr
);
/* SendPMsg skips all the tools unless messages are stamped beforehand */
hr
=
IDirectMusicPerformance_AllocPMsg
(
performance
,
sizeof
(
DMUS_PMSG
),
&
msg
);
ok
(
hr
==
S_OK
,
"got %#lx
\n
"
,
hr
);
ok
(
msg
->
dwSize
==
sizeof
(
DMUS_PMSG
),
"got %ld
\n
"
,
msg
->
dwSize
);
msg
->
mtTime
=
0
;
msg
->
dwFlags
=
DMUS_PMSGF_MUSICTIME
;
msg
->
dwType
=
DMUS_PMSGT_USER
;
hr
=
IDirectMusicPerformance_SendPMsg
(
performance
,
msg
);
ok
(
hr
==
S_OK
,
"got %#lx
\n
"
,
hr
);
ret
=
test_tool_wait_message
(
tool
,
10
,
&
msg
);
ok
(
ret
==
WAIT_TIMEOUT
,
"got %#lx
\n
"
,
ret
);
ok
(
!
msg
,
"got %p
\n
"
,
msg
);
/* SendPMsg converts music time to reference time if it is missing */
hr
=
IDirectMusicPerformance_AllocPMsg
(
performance
,
sizeof
(
DMUS_PMSG
),
&
msg
);
ok
(
hr
==
S_OK
,
"got %#lx
\n
"
,
hr
);
ok
(
msg
->
dwSize
==
sizeof
(
DMUS_PMSG
),
"got %ld
\n
"
,
msg
->
dwSize
);
msg
->
mtTime
=
500
;
msg
->
dwFlags
=
DMUS_PMSGF_MUSICTIME
;
msg
->
dwType
=
DMUS_PMSGT_USER
;
hr
=
IDirectMusicGraph_StampPMsg
(
performance_graph
,
msg
);
ok
(
hr
==
S_OK
,
"got %#lx
\n
"
,
hr
);
hr
=
IDirectMusicPerformance_SendPMsg
(
performance
,
msg
);
ok
(
hr
==
S_OK
,
"got %#lx
\n
"
,
hr
);
ret
=
test_tool_wait_message
(
tool
,
50
,
&
msg
);
todo_wine
ok
(
!
ret
,
"got %#lx
\n
"
,
ret
);
todo_wine
ok
(
msg
!=
NULL
,
"got %p
\n
"
,
msg
);
if
(
!
msg
)
goto
skip_rtime
;
time
=
0xdeadbeef
;
hr
=
IDirectMusicPerformance_MusicToReferenceTime
(
performance
,
msg
->
mtTime
,
&
time
);
ok
(
hr
==
S_OK
,
"got %#lx
\n
"
,
hr
);
...
...
@@ -1833,32 +1870,26 @@ static void test_performance_pmsg(void)
todo_wine
ok
(
msg
->
rtTime
==
time
,
"got %I64d
\n
"
,
msg
->
rtTime
);
ok
(
msg
->
mtTime
==
500
,
"got %ld
\n
"
,
msg
->
mtTime
);
todo_wine
ok
(
msg
->
dwFlags
&
DMUS_PMSGF_REFTIME
,
"got %#lx
\n
"
,
msg
->
dwFlags
);
todo_wine
ok
(
msg
->
dwFlags
&
DMUS_PMSGF_MUSICTIME
,
"got %#lx
\n
"
,
msg
->
dwFlags
);
todo_wine
ok
(
msg
->
dwFlags
&
(
DMUS_PMSGF_TOOL_QUEUE
|
DMUS_PMSGF_TOOL_IMMEDIATE
),
"got %#lx
\n
"
,
msg
->
dwFlags
);
ok
(
!
msg
->
dwPChannel
,
"got %ld
\n
"
,
msg
->
dwPChannel
);
ok
(
!
msg
->
dwVirtualTrackID
,
"got %ld
\n
"
,
msg
->
dwVirtualTrackID
);
ok
(
!
msg
->
pT
ool
,
"got %p
\n
"
,
msg
->
pTool
);
ok
(
!
msg
->
pG
raph
,
"got %p
\n
"
,
msg
->
pGraph
);
ok
(
!
msg
->
dwType
,
"got %#lx
\n
"
,
msg
->
dwType
);
ok
(
msg
->
pTool
==
t
ool
,
"got %p
\n
"
,
msg
->
pTool
);
ok
(
msg
->
pGraph
==
performance_g
raph
,
"got %p
\n
"
,
msg
->
pGraph
);
ok
(
msg
->
dwType
==
DMUS_PMSGT_USER
,
"got %#lx
\n
"
,
msg
->
dwType
);
ok
(
!
msg
->
dwVoiceID
,
"got %ld
\n
"
,
msg
->
dwVoiceID
);
ok
(
!
msg
->
dwGroupID
,
"got %ld
\n
"
,
msg
->
dwGroupID
);
ok
(
!
msg
->
punkUser
,
"got %p
\n
"
,
msg
->
punkUser
);
/* SendPMsg skips all the tools unless messages are stamped beforehand */
hr
=
IDirectMusicPerformance_AllocPMsg
(
performance
,
sizeof
(
DMUS_PMSG
),
&
msg
);
ok
(
hr
==
S_OK
,
"got %#lx
\n
"
,
hr
);
ok
(
msg
->
dwSize
==
sizeof
(
DMUS_PMSG
),
"got %ld
\n
"
,
msg
->
dwSize
);
msg
->
rtTime
=
time
;
msg
->
dwFlags
=
DMUS_PMSGF_REFTIME
;
msg
->
dwType
=
DMUS_PMSGT_USER
;
hr
=
IDirectMusicPerformance_SendPMsg
(
performance
,
msg
);
hr
=
IDirectMusicPerformance_FreePMsg
(
performance
,
msg
);
ok
(
hr
==
S_OK
,
"got %#lx
\n
"
,
hr
);
ret
=
test_tool_wait_message
(
tool
,
10
,
&
msg
);
ok
(
ret
==
WAIT_TIMEOUT
,
"got %#lx
\n
"
,
ret
);
ok
(
!
msg
,
"got %p
\n
"
,
msg
);
skip_rtime:
/* SendPMsg converts reference time to music time if it is missing */
hr
=
IDirectMusicPerformance_GetTime
(
performance
,
&
time
,
&
music_time
);
ok
(
hr
==
S_OK
,
"got %#lx
\n
"
,
hr
);
hr
=
IDirectMusicPerformance_AllocPMsg
(
performance
,
sizeof
(
DMUS_PMSG
),
&
msg
);
ok
(
hr
==
S_OK
,
"got %#lx
\n
"
,
hr
);
...
...
@@ -1866,24 +1897,39 @@ static void test_performance_pmsg(void)
msg
->
rtTime
=
time
;
msg
->
dwFlags
=
DMUS_PMSGF_REFTIME
;
msg
->
dwType
=
DMUS_PMSGT_USER
;
hr
=
IDirectMusicPerformance_QueryInterface
(
performance
,
&
IID_IDirectMusicGraph
,
(
void
**
)
&
graph
);
ok
(
hr
==
S_OK
,
"got %#lx
\n
"
,
hr
);
hr
=
IDirectMusicGraph_StampPMsg
(
graph
,
msg
);
hr
=
IDirectMusicGraph_StampPMsg
(
performance_graph
,
msg
);
ok
(
hr
==
S_OK
,
"got %#lx
\n
"
,
hr
);
IDirectMusicGraph_Release
(
graph
);
hr
=
IDirectMusicPerformance_SendPMsg
(
performance
,
msg
);
ok
(
hr
==
S_OK
,
"got %#lx
\n
"
,
hr
);
ret
=
test_tool_wait_message
(
tool
,
50
,
&
msg
);
todo_wine
ok
(
!
ret
,
"got %#lx
\n
"
,
ret
);
todo_wine
ok
(
msg
!=
NULL
,
"got %p
\n
"
,
msg
);
if
(
!
msg
)
hr
=
S_OK
;
else
hr
=
IDirectMusicPerformance_FreePMsg
(
performance
,
msg
);
if
(
!
msg
)
goto
skip_mtime
;
music_time
=
0xdeadbeef
;
hr
=
IDirectMusicPerformance_ReferenceToMusicTime
(
performance
,
msg
->
rtTime
,
&
music_time
);
ok
(
hr
==
S_OK
,
"got %#lx
\n
"
,
hr
);
ok
(
msg
->
dwSize
==
sizeof
(
DMUS_PMSG
),
"got %ld
\n
"
,
msg
->
dwSize
);
todo_wine
ok
(
msg
->
rtTime
==
time
,
"got %I64d
\n
"
,
msg
->
rtTime
);
todo_wine
ok
(
msg
->
mtTime
==
music_time
,
"got %ld
\n
"
,
msg
->
mtTime
);
todo_wine
ok
(
msg
->
dwFlags
&
DMUS_PMSGF_REFTIME
,
"got %#lx
\n
"
,
msg
->
dwFlags
);
todo_wine
ok
(
msg
->
dwFlags
&
DMUS_PMSGF_MUSICTIME
,
"got %#lx
\n
"
,
msg
->
dwFlags
);
todo_wine
ok
(
msg
->
dwFlags
&
(
DMUS_PMSGF_TOOL_QUEUE
|
DMUS_PMSGF_TOOL_IMMEDIATE
),
"got %#lx
\n
"
,
msg
->
dwFlags
);
ok
(
!
msg
->
dwPChannel
,
"got %ld
\n
"
,
msg
->
dwPChannel
);
ok
(
!
msg
->
dwVirtualTrackID
,
"got %ld
\n
"
,
msg
->
dwVirtualTrackID
);
ok
(
msg
->
pTool
==
tool
,
"got %p
\n
"
,
msg
->
pTool
);
ok
(
msg
->
pGraph
==
performance_graph
,
"got %p
\n
"
,
msg
->
pGraph
);
ok
(
msg
->
dwType
==
DMUS_PMSGT_USER
,
"got %#lx
\n
"
,
msg
->
dwType
);
ok
(
!
msg
->
dwVoiceID
,
"got %ld
\n
"
,
msg
->
dwVoiceID
);
ok
(
!
msg
->
dwGroupID
,
"got %ld
\n
"
,
msg
->
dwGroupID
);
ok
(
!
msg
->
punkUser
,
"got %p
\n
"
,
msg
->
punkUser
);
hr
=
IDirectMusicPerformance_FreePMsg
(
performance
,
msg
);
ok
(
hr
==
S_OK
,
"got %#lx
\n
"
,
hr
);
skip_mtime:
for
(
i
=
0
;
i
<
ARRAY_SIZE
(
delivery_flags
);
i
++
)
{
DWORD
duration
=
0
;
...
...
@@ -1896,12 +1942,8 @@ static void test_performance_pmsg(void)
msg
->
rtTime
=
time
+
150
*
10000
;
msg
->
dwFlags
=
DMUS_PMSGF_REFTIME
;
msg
->
dwType
=
DMUS_PMSGT_USER
;
hr
=
IDirectMusicPerformance_QueryInterface
(
performance
,
&
IID_IDirectMusicGraph
,
(
void
**
)
&
graph
);
hr
=
IDirectMusicGraph_StampPMsg
(
performance_graph
,
msg
);
ok
(
hr
==
S_OK
,
"got %#lx
\n
"
,
hr
);
hr
=
IDirectMusicGraph_StampPMsg
(
graph
,
msg
);
ok
(
hr
==
S_OK
,
"got %#lx
\n
"
,
hr
);
IDirectMusicGraph_Release
(
graph
);
msg
->
dwFlags
&=
~
(
DMUS_PMSGF_TOOL_IMMEDIATE
|
DMUS_PMSGF_TOOL_QUEUE
|
DMUS_PMSGF_TOOL_ATTIME
);
msg
->
dwFlags
|=
delivery_flags
[
i
];
...
...
@@ -1921,8 +1963,8 @@ static void test_performance_pmsg(void)
switch
(
delivery_flags
[
i
])
{
case
DMUS_PMSGF_TOOL_IMMEDIATE
:
todo_wine
ok
(
duration
<=
50
,
"got %lu
\n
"
,
duration
);
break
;
case
DMUS_PMSGF_TOOL_QUEUE
:
todo_wine
ok
(
duration
>=
50
&&
duration
<=
1
00
,
"got %lu
\n
"
,
duration
);
break
;
case
DMUS_PMSGF_TOOL_ATTIME
:
todo_wine
ok
(
duration
>=
1
50
&&
duration
<=
500
,
"got %lu
\n
"
,
duration
);
break
;
case
DMUS_PMSGF_TOOL_QUEUE
:
todo_wine
ok
(
duration
>=
50
&&
duration
<=
1
25
,
"got %lu
\n
"
,
duration
);
break
;
case
DMUS_PMSGF_TOOL_ATTIME
:
todo_wine
ok
(
duration
>=
1
25
&&
duration
<=
500
,
"got %lu
\n
"
,
duration
);
break
;
}
}
...
...
@@ -1931,7 +1973,10 @@ static void test_performance_pmsg(void)
ok
(
hr
==
S_OK
,
"got %#lx
\n
"
,
hr
);
IDirectMusicGraph_Release
(
performance_graph
);
IDirectMusicPerformance_Release
(
performance
);
IDirectMusicTool_Release
(
tool
);
}
START_TEST
(
dmime
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment