Add comments for integration_tests::event_property_parser
This commit is contained in:
parent
93366593c7
commit
bb050d7a6d
@ -19,6 +19,11 @@ enum PropertyCheckingThreadError {
|
|||||||
MpvError(#[from] MpvError),
|
MpvError(#[from] MpvError),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// This function will create an ongoing tokio task that collects [`Event::PropertyChange`] events,
|
||||||
|
/// and parses them into [`mpvipc::Property`]s. It will then run the property through the provided
|
||||||
|
/// closure, and return an error if the closure returns false.
|
||||||
|
///
|
||||||
|
/// The returned cancellation token can be used to stop the task.
|
||||||
fn create_interruptable_event_property_checking_thread<T>(
|
fn create_interruptable_event_property_checking_thread<T>(
|
||||||
mut events: impl Stream<Item = Result<Event, MpvError>> + Unpin + Send + 'static,
|
mut events: impl Stream<Item = Result<Event, MpvError>> + Unpin + Send + 'static,
|
||||||
on_property: T,
|
on_property: T,
|
||||||
@ -61,6 +66,9 @@ where
|
|||||||
(handle, cancellation_token)
|
(handle, cancellation_token)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// This helper function will gracefully shut down both the event checking thread and the mpv process.
|
||||||
|
/// It will also return an error if the event checking thread happened to panic, or if it times out
|
||||||
|
/// The timeout is hardcoded to 500ms.
|
||||||
async fn graceful_shutdown(
|
async fn graceful_shutdown(
|
||||||
cancellation_token: tokio_util::sync::CancellationToken,
|
cancellation_token: tokio_util::sync::CancellationToken,
|
||||||
handle: tokio::task::JoinHandle<Result<(), PropertyCheckingThreadError>>,
|
handle: tokio::task::JoinHandle<Result<(), PropertyCheckingThreadError>>,
|
||||||
@ -103,6 +111,7 @@ async fn graceful_shutdown(
|
|||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Test correct parsing of different values of the "pause" property
|
||||||
#[test(tokio::test)]
|
#[test(tokio::test)]
|
||||||
#[cfg(target_family = "unix")]
|
#[cfg(target_family = "unix")]
|
||||||
async fn test_highlevel_event_pause() -> Result<(), MpvError> {
|
async fn test_highlevel_event_pause() -> Result<(), MpvError> {
|
||||||
@ -131,6 +140,7 @@ async fn test_highlevel_event_pause() -> Result<(), MpvError> {
|
|||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Test correct parsing of different values of the "volume" property
|
||||||
#[test(tokio::test)]
|
#[test(tokio::test)]
|
||||||
#[cfg(target_family = "unix")]
|
#[cfg(target_family = "unix")]
|
||||||
async fn test_highlevel_event_volume() -> Result<(), MpvError> {
|
async fn test_highlevel_event_volume() -> Result<(), MpvError> {
|
||||||
@ -160,6 +170,7 @@ async fn test_highlevel_event_volume() -> Result<(), MpvError> {
|
|||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Test correct parsing of different values of the "mute" property
|
||||||
#[test(tokio::test)]
|
#[test(tokio::test)]
|
||||||
#[cfg(target_family = "unix")]
|
#[cfg(target_family = "unix")]
|
||||||
async fn test_highlevel_event_mute() -> Result<(), MpvError> {
|
async fn test_highlevel_event_mute() -> Result<(), MpvError> {
|
||||||
@ -187,6 +198,7 @@ async fn test_highlevel_event_mute() -> Result<(), MpvError> {
|
|||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Test correct parsing of different values of the "duration" property
|
||||||
#[test(tokio::test)]
|
#[test(tokio::test)]
|
||||||
#[cfg(target_family = "unix")]
|
#[cfg(target_family = "unix")]
|
||||||
async fn test_highlevel_event_duration() -> Result<(), MpvError> {
|
async fn test_highlevel_event_duration() -> Result<(), MpvError> {
|
||||||
|
Loading…
Reference in New Issue
Block a user