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
cc091670
Commit
cc091670
authored
Oct 11, 2022
by
Zebediah Figura
Committed by
Alexandre Julliard
Oct 12, 2022
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
qcap/tests: Test that the video capture filter sets timestamps.
OpenSeeFace depends on this.
parent
333a8715
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
26 additions
and
2 deletions
+26
-2
videocapture.c
dlls/qcap/tests/videocapture.c
+26
-2
No files found.
dlls/qcap/tests/videocapture.c
View file @
cc091670
...
@@ -353,6 +353,7 @@ struct testfilter
...
@@ -353,6 +353,7 @@ struct testfilter
{
{
struct
strmbase_filter
filter
;
struct
strmbase_filter
filter
;
struct
strmbase_sink
sink
;
struct
strmbase_sink
sink
;
HANDLE
got_sample
;
};
};
static
inline
struct
testfilter
*
impl_from_strmbase_filter
(
struct
strmbase_filter
*
iface
)
static
inline
struct
testfilter
*
impl_from_strmbase_filter
(
struct
strmbase_filter
*
iface
)
...
@@ -371,6 +372,8 @@ static struct strmbase_pin *testfilter_get_pin(struct strmbase_filter *iface, un
...
@@ -371,6 +372,8 @@ static struct strmbase_pin *testfilter_get_pin(struct strmbase_filter *iface, un
static
void
testfilter_destroy
(
struct
strmbase_filter
*
iface
)
static
void
testfilter_destroy
(
struct
strmbase_filter
*
iface
)
{
{
struct
testfilter
*
filter
=
impl_from_strmbase_filter
(
iface
);
struct
testfilter
*
filter
=
impl_from_strmbase_filter
(
iface
);
CloseHandle
(
filter
->
got_sample
);
strmbase_sink_cleanup
(
&
filter
->
sink
);
strmbase_sink_cleanup
(
&
filter
->
sink
);
strmbase_filter_cleanup
(
&
filter
->
filter
);
strmbase_filter_cleanup
(
&
filter
->
filter
);
}
}
...
@@ -396,6 +399,17 @@ static HRESULT testsink_query_interface(struct strmbase_pin *iface, REFIID iid,
...
@@ -396,6 +399,17 @@ static HRESULT testsink_query_interface(struct strmbase_pin *iface, REFIID iid,
static
HRESULT
WINAPI
testsink_Receive
(
struct
strmbase_sink
*
iface
,
IMediaSample
*
sample
)
static
HRESULT
WINAPI
testsink_Receive
(
struct
strmbase_sink
*
iface
,
IMediaSample
*
sample
)
{
{
struct
testfilter
*
filter
=
impl_from_strmbase_filter
(
iface
->
pin
.
filter
);
REFERENCE_TIME
start
,
end
;
HRESULT
hr
;
if
(
winetest_debug
>
1
)
trace
(
"Receive()
\n
"
);
hr
=
IMediaSample_GetTime
(
sample
,
&
start
,
&
end
);
todo_wine
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
SetEvent
(
filter
->
got_sample
);
return
S_OK
;
return
S_OK
;
}
}
...
@@ -411,13 +425,16 @@ static void testfilter_init(struct testfilter *filter)
...
@@ -411,13 +425,16 @@ static void testfilter_init(struct testfilter *filter)
memset
(
filter
,
0
,
sizeof
(
*
filter
));
memset
(
filter
,
0
,
sizeof
(
*
filter
));
strmbase_filter_init
(
&
filter
->
filter
,
NULL
,
&
clsid
,
&
testfilter_ops
);
strmbase_filter_init
(
&
filter
->
filter
,
NULL
,
&
clsid
,
&
testfilter_ops
);
strmbase_sink_init
(
&
filter
->
sink
,
&
filter
->
filter
,
L"sink"
,
&
testsink_ops
,
NULL
);
strmbase_sink_init
(
&
filter
->
sink
,
&
filter
->
filter
,
L"sink"
,
&
testsink_ops
,
NULL
);
filter
->
got_sample
=
CreateEventW
(
NULL
,
FALSE
,
FALSE
,
NULL
);
}
}
static
void
test_filter_state
(
IMediaControl
*
control
,
IMemAllocator
*
allocato
r
)
static
void
test_filter_state
(
IMediaControl
*
control
,
struct
testfilter
*
filte
r
)
{
{
IMemAllocator
*
allocator
=
filter
->
sink
.
pAllocator
;
IMediaSample
*
sample
;
IMediaSample
*
sample
;
OAFilterState
state
;
OAFilterState
state
;
HRESULT
hr
;
HRESULT
hr
;
DWORD
ret
;
hr
=
IMediaControl_GetState
(
control
,
0
,
&
state
);
hr
=
IMediaControl_GetState
(
control
,
0
,
&
state
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
...
@@ -440,6 +457,13 @@ static void test_filter_state(IMediaControl *control, IMemAllocator *allocator)
...
@@ -440,6 +457,13 @@ static void test_filter_state(IMediaControl *control, IMemAllocator *allocator)
hr
=
IMediaControl_Run
(
control
);
hr
=
IMediaControl_Run
(
control
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
/* starting up the webcam can be a little slow */
ret
=
WaitForSingleObject
(
filter
->
got_sample
,
5000
);
ok
(
!
ret
,
"Got %lu.
\n
"
,
ret
);
ret
=
WaitForSingleObject
(
filter
->
got_sample
,
1000
);
ok
(
!
ret
,
"Got %lu.
\n
"
,
ret
);
hr
=
IMediaControl_GetState
(
control
,
0
,
&
state
);
hr
=
IMediaControl_GetState
(
control
,
0
,
&
state
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
ok
(
state
==
State_Running
,
"Got state %lu.
\n
"
,
state
);
ok
(
state
==
State_Running
,
"Got state %lu.
\n
"
,
state
);
...
@@ -547,7 +571,7 @@ static void test_connect_pin(IBaseFilter *filter, IPin *source)
...
@@ -547,7 +571,7 @@ static void test_connect_pin(IBaseFilter *filter, IPin *source)
ok
(
!!
testsink
.
sink
.
pAllocator
,
"Expected to be assigned an allocator.
\n
"
);
ok
(
!!
testsink
.
sink
.
pAllocator
,
"Expected to be assigned an allocator.
\n
"
);
test_filter_state
(
control
,
testsink
.
sink
.
pAllocator
);
test_filter_state
(
control
,
&
testsink
);
hr
=
IPin_ConnectedTo
(
source
,
&
peer
);
hr
=
IPin_ConnectedTo
(
source
,
&
peer
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"Got hr %#lx.
\n
"
,
hr
);
...
...
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