Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
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-winehq
Commits
150463b3
Commit
150463b3
authored
Nov 27, 2023
by
Anton Baskanov
Committed by
Alexandre Julliard
Nov 27, 2023
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
amstream/tests: Test IEnumPins with two streams.
parent
54aef599
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
49 additions
and
16 deletions
+49
-16
amstream.c
dlls/amstream/tests/amstream.c
+49
-16
No files found.
dlls/amstream/tests/amstream.c
View file @
150463b3
...
@@ -1839,10 +1839,10 @@ static void test_media_streams(void)
...
@@ -1839,10 +1839,10 @@ static void test_media_streams(void)
static
void
test_enum_pins
(
void
)
static
void
test_enum_pins
(
void
)
{
{
IAMMultiMediaStream
*
mmstream
=
create_ammultimediastream
();
IAMMultiMediaStream
*
mmstream
=
create_ammultimediastream
();
IMediaStream
*
stream0
,
*
stream1
;
IPin
*
pins
[
3
],
*
pin0
,
*
pin1
;
IMediaStreamFilter
*
filter
;
IMediaStreamFilter
*
filter
;
IEnumPins
*
enum1
,
*
enum2
;
IEnumPins
*
enum1
,
*
enum2
;
IMediaStream
*
stream
;
IPin
*
pins
[
3
],
*
pin
;
ULONG
ref
,
count
;
ULONG
ref
,
count
;
HRESULT
hr
;
HRESULT
hr
;
...
@@ -1877,9 +1877,13 @@ static void test_enum_pins(void)
...
@@ -1877,9 +1877,13 @@ static void test_enum_pins(void)
hr
=
IEnumPins_Skip
(
enum1
,
1
);
hr
=
IEnumPins_Skip
(
enum1
,
1
);
ok
(
hr
==
S_FALSE
,
"Got hr %#lx.
\n
"
,
hr
);
ok
(
hr
==
S_FALSE
,
"Got hr %#lx.
\n
"
,
hr
);
hr
=
IAMMultiMediaStream_AddMediaStream
(
mmstream
,
NULL
,
&
MSPID_PrimaryVideo
,
0
,
&
stream
);
hr
=
IAMMultiMediaStream_AddMediaStream
(
mmstream
,
NULL
,
&
MSPID_PrimaryVideo
,
0
,
&
stream
0
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
hr
=
IMediaStream_QueryInterface
(
stream
,
&
IID_IPin
,
(
void
**
)
&
pin
);
hr
=
IAMMultiMediaStream_AddMediaStream
(
mmstream
,
NULL
,
&
MSPID_PrimaryAudio
,
0
,
&
stream1
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
hr
=
IMediaStream_QueryInterface
(
stream0
,
&
IID_IPin
,
(
void
**
)
&
pin0
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
hr
=
IMediaStream_QueryInterface
(
stream1
,
&
IID_IPin
,
(
void
**
)
&
pin1
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
/* Reset() isn't enough; we have to call EnumPins() again to see the updated
/* Reset() isn't enough; we have to call EnumPins() again to see the updated
...
@@ -1899,21 +1903,34 @@ static void test_enum_pins(void)
...
@@ -1899,21 +1903,34 @@ static void test_enum_pins(void)
ok
(
ref
==
4
,
"Got unexpected refcount %ld.
\n
"
,
ref
);
ok
(
ref
==
4
,
"Got unexpected refcount %ld.
\n
"
,
ref
);
ref
=
get_refcount
(
enum1
);
ref
=
get_refcount
(
enum1
);
ok
(
ref
==
1
,
"Got unexpected refcount %ld.
\n
"
,
ref
);
ok
(
ref
==
1
,
"Got unexpected refcount %ld.
\n
"
,
ref
);
ref
=
get_refcount
(
pin
);
ref
=
get_refcount
(
pin0
);
ok
(
ref
==
4
,
"Got unexpected refcount %ld.
\n
"
,
ref
);
ref
=
get_refcount
(
pin1
);
ok
(
ref
==
4
,
"Got unexpected refcount %ld.
\n
"
,
ref
);
ok
(
ref
==
4
,
"Got unexpected refcount %ld.
\n
"
,
ref
);
hr
=
IEnumPins_Next
(
enum1
,
1
,
pins
,
NULL
);
hr
=
IEnumPins_Next
(
enum1
,
1
,
pins
,
NULL
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
ok
(
pins
[
0
]
==
pin
,
"Expected pin %p, got %p.
\n
"
,
pin
,
pins
[
0
]);
ok
(
pins
[
0
]
==
pin
0
,
"Expected pin %p, got %p.
\n
"
,
pin0
,
pins
[
0
]);
ref
=
get_refcount
(
filter
);
ref
=
get_refcount
(
filter
);
ok
(
ref
==
4
,
"Got unexpected refcount %ld.
\n
"
,
ref
);
ok
(
ref
==
4
,
"Got unexpected refcount %ld.
\n
"
,
ref
);
ref
=
get_refcount
(
enum1
);
ref
=
get_refcount
(
enum1
);
ok
(
ref
==
1
,
"Got unexpected refcount %ld.
\n
"
,
ref
);
ok
(
ref
==
1
,
"Got unexpected refcount %ld.
\n
"
,
ref
);
ref
=
get_refcount
(
pin
);
ref
=
get_refcount
(
pin
0
);
ok
(
ref
==
5
,
"Got unexpected refcount %ld.
\n
"
,
ref
);
ok
(
ref
==
5
,
"Got unexpected refcount %ld.
\n
"
,
ref
);
IPin_Release
(
pins
[
0
]);
IPin_Release
(
pins
[
0
]);
hr
=
IEnumPins_Next
(
enum1
,
1
,
pins
,
NULL
);
hr
=
IEnumPins_Next
(
enum1
,
1
,
pins
,
NULL
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
todo_wine
ok
(
pins
[
0
]
==
pin1
,
"Expected pin %p, got %p.
\n
"
,
pin1
,
pins
[
0
]);
ref
=
get_refcount
(
filter
);
ok
(
ref
==
4
,
"Got unexpected refcount %ld.
\n
"
,
ref
);
ref
=
get_refcount
(
enum1
);
ok
(
ref
==
1
,
"Got unexpected refcount %ld.
\n
"
,
ref
);
ref
=
get_refcount
(
pin1
);
todo_wine
ok
(
ref
==
5
,
"Got unexpected refcount %ld.
\n
"
,
ref
);
IPin_Release
(
pins
[
0
]);
hr
=
IEnumPins_Next
(
enum1
,
1
,
pins
,
NULL
);
ok
(
hr
==
S_FALSE
,
"Got hr %#lx.
\n
"
,
hr
);
ok
(
hr
==
S_FALSE
,
"Got hr %#lx.
\n
"
,
hr
);
hr
=
IEnumPins_Reset
(
enum1
);
hr
=
IEnumPins_Reset
(
enum1
);
...
@@ -1922,20 +1939,28 @@ static void test_enum_pins(void)
...
@@ -1922,20 +1939,28 @@ static void test_enum_pins(void)
hr
=
IEnumPins_Next
(
enum1
,
1
,
pins
,
&
count
);
hr
=
IEnumPins_Next
(
enum1
,
1
,
pins
,
&
count
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
ok
(
count
==
1
,
"Got count %lu.
\n
"
,
count
);
ok
(
count
==
1
,
"Got count %lu.
\n
"
,
count
);
ok
(
pins
[
0
]
==
pin
,
"Expected pin %p, got %p.
\n
"
,
pin
,
pins
[
0
]);
ok
(
pins
[
0
]
==
pin0
,
"Expected pin %p, got %p.
\n
"
,
pin0
,
pins
[
0
]);
IPin_Release
(
pins
[
0
]);
hr
=
IEnumPins_Next
(
enum1
,
1
,
pins
,
&
count
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
ok
(
count
==
1
,
"Got count %lu.
\n
"
,
count
);
todo_wine
ok
(
pins
[
0
]
==
pin1
,
"Expected pin %p, got %p.
\n
"
,
pin1
,
pins
[
0
]);
IPin_Release
(
pins
[
0
]);
IPin_Release
(
pins
[
0
]);
hr
=
IEnumPins_Reset
(
enum1
);
hr
=
IEnumPins_Reset
(
enum1
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
hr
=
IEnumPins_Next
(
enum1
,
2
,
pins
,
NULL
);
hr
=
IEnumPins_Next
(
enum1
,
3
,
pins
,
NULL
);
ok
(
hr
==
E_POINTER
,
"Got hr %#lx.
\n
"
,
hr
);
ok
(
hr
==
E_POINTER
,
"Got hr %#lx.
\n
"
,
hr
);
hr
=
IEnumPins_Next
(
enum1
,
2
,
pins
,
&
count
);
hr
=
IEnumPins_Next
(
enum1
,
3
,
pins
,
&
count
);
ok
(
hr
==
S_FALSE
,
"Got hr %#lx.
\n
"
,
hr
);
ok
(
hr
==
S_FALSE
,
"Got hr %#lx.
\n
"
,
hr
);
ok
(
count
==
1
,
"Got count %lu.
\n
"
,
count
);
ok
(
count
==
2
,
"Got count %lu.
\n
"
,
count
);
ok
(
pins
[
0
]
==
pin
,
"Expected pin %p, got %p.
\n
"
,
pin
,
pins
[
0
]);
ok
(
pins
[
0
]
==
pin0
,
"Expected pin %p, got %p.
\n
"
,
pin0
,
pins
[
0
]);
ok
(
pins
[
1
]
==
pin1
,
"Expected pin %p, got %p.
\n
"
,
pin1
,
pins
[
1
]);
IPin_Release
(
pins
[
0
]);
IPin_Release
(
pins
[
0
]);
IPin_Release
(
pins
[
1
]);
hr
=
IEnumPins_Reset
(
enum1
);
hr
=
IEnumPins_Reset
(
enum1
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
...
@@ -1946,7 +1971,7 @@ static void test_enum_pins(void)
...
@@ -1946,7 +1971,7 @@ static void test_enum_pins(void)
hr
=
IEnumPins_Skip
(
enum1
,
0
);
hr
=
IEnumPins_Skip
(
enum1
,
0
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
hr
=
IEnumPins_Skip
(
enum1
,
1
);
hr
=
IEnumPins_Skip
(
enum1
,
2
);
ok
(
hr
==
S_FALSE
,
"Got hr %#lx.
\n
"
,
hr
);
ok
(
hr
==
S_FALSE
,
"Got hr %#lx.
\n
"
,
hr
);
hr
=
IEnumPins_Next
(
enum1
,
1
,
pins
,
NULL
);
hr
=
IEnumPins_Next
(
enum1
,
1
,
pins
,
NULL
);
...
@@ -1954,7 +1979,12 @@ static void test_enum_pins(void)
...
@@ -1954,7 +1979,12 @@ static void test_enum_pins(void)
hr
=
IEnumPins_Next
(
enum2
,
1
,
pins
,
NULL
);
hr
=
IEnumPins_Next
(
enum2
,
1
,
pins
,
NULL
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
ok
(
pins
[
0
]
==
pin
,
"Expected pin %p, got %p.
\n
"
,
pin
,
pins
[
0
]);
ok
(
pins
[
0
]
==
pin0
,
"Expected pin %p, got %p.
\n
"
,
pin0
,
pins
[
0
]);
IPin_Release
(
pins
[
0
]);
hr
=
IEnumPins_Next
(
enum2
,
1
,
pins
,
NULL
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
todo_wine
ok
(
pins
[
0
]
==
pin1
,
"Expected pin %p, got %p.
\n
"
,
pin1
,
pins
[
0
]);
IPin_Release
(
pins
[
0
]);
IPin_Release
(
pins
[
0
]);
IEnumPins_Release
(
enum2
);
IEnumPins_Release
(
enum2
);
...
@@ -1963,8 +1993,11 @@ static void test_enum_pins(void)
...
@@ -1963,8 +1993,11 @@ static void test_enum_pins(void)
IMediaStreamFilter_Release
(
filter
);
IMediaStreamFilter_Release
(
filter
);
ref
=
IAMMultiMediaStream_Release
(
mmstream
);
ref
=
IAMMultiMediaStream_Release
(
mmstream
);
ok
(
!
ref
,
"Got outstanding refcount %ld.
\n
"
,
ref
);
ok
(
!
ref
,
"Got outstanding refcount %ld.
\n
"
,
ref
);
IMediaStream_Release
(
stream
);
IMediaStream_Release
(
stream1
);
ref
=
IPin_Release
(
pin
);
IMediaStream_Release
(
stream0
);
ref
=
IPin_Release
(
pin1
);
ok
(
!
ref
,
"Got outstanding refcount %ld.
\n
"
,
ref
);
ref
=
IPin_Release
(
pin0
);
ok
(
!
ref
,
"Got outstanding refcount %ld.
\n
"
,
ref
);
ok
(
!
ref
,
"Got outstanding refcount %ld.
\n
"
,
ref
);
}
}
...
...
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