From d82a7f7674cbf828d5c28a777c847edc15b92f28 Mon Sep 17 00:00:00 2001 From: Alex Clarke Date: Tue, 19 Nov 2024 17:01:48 -0700 Subject: [PATCH] feat(cli): Added CLI support for fetching series details in Sonarr --- src/cli/sonarr/get_command_handler.rs | 12 +++++ src/cli/sonarr/get_command_handler_tests.rs | 52 +++++++++++++++++++++ 2 files changed, 64 insertions(+) diff --git a/src/cli/sonarr/get_command_handler.rs b/src/cli/sonarr/get_command_handler.rs index 8d29cbc..7af1ee6 100644 --- a/src/cli/sonarr/get_command_handler.rs +++ b/src/cli/sonarr/get_command_handler.rs @@ -34,6 +34,15 @@ pub enum SonarrGetCommand { HostConfig, #[command(about = "Fetch the security config for your Sonarr instance")] SecurityConfig, + #[command(about = "Get detailed information for the series with the given ID")] + SeriesDetails { + #[arg( + long, + help = "The Sonarr ID of the series whose details you wish to fetch", + required = true + )] + series_id: i64, + }, #[command(about = "Get the system status")] SystemStatus, } @@ -77,6 +86,9 @@ impl<'a, 'b> CliCommandHandler<'a, 'b, SonarrGetCommand> for SonarrGetCommandHan SonarrGetCommand::SecurityConfig => { execute_network_event!(self, SonarrEvent::GetSecurityConfig); } + SonarrGetCommand::SeriesDetails { series_id } => { + execute_network_event!(self, SonarrEvent::GetSeriesDetails(Some(series_id))); + } SonarrGetCommand::SystemStatus => { execute_network_event!(self, SonarrEvent::GetStatus); } diff --git a/src/cli/sonarr/get_command_handler_tests.rs b/src/cli/sonarr/get_command_handler_tests.rs index 8905048..714cc67 100644 --- a/src/cli/sonarr/get_command_handler_tests.rs +++ b/src/cli/sonarr/get_command_handler_tests.rs @@ -78,6 +78,32 @@ mod tests { assert!(result.is_ok()); } + + #[test] + fn test_series_details_requires_series_id() { + let result = + Cli::command().try_get_matches_from(["managarr", "sonarr", "get", "series-details"]); + + assert!(result.is_err()); + assert_eq!( + result.unwrap_err().kind(), + ErrorKind::MissingRequiredArgument + ); + } + + #[test] + fn test_series_details_requirements_satisfied() { + let result = Cli::command().try_get_matches_from([ + "managarr", + "sonarr", + "get", + "series-details", + "--series-id", + "1", + ]); + + assert!(result.is_ok()); + } } mod handler { @@ -197,6 +223,32 @@ mod tests { assert!(result.is_ok()); } + #[tokio::test] + async fn test_handle_get_series_details_command() { + let expected_series_id = 1; + let mut mock_network = MockNetworkTrait::new(); + mock_network + .expect_handle_network_event() + .with(eq::( + SonarrEvent::GetSeriesDetails(Some(expected_series_id)).into(), + )) + .times(1) + .returning(|_| { + Ok(Serdeable::Sonarr(SonarrSerdeable::Value( + json!({"testResponse": "response"}), + ))) + }); + let app_arc = Arc::new(Mutex::new(App::default())); + let get_series_details_command = SonarrGetCommand::SeriesDetails { series_id: 1 }; + + let result = + SonarrGetCommandHandler::with(&app_arc, get_series_details_command, &mut mock_network) + .handle() + .await; + + assert!(result.is_ok()); + } + #[tokio::test] async fn test_handle_get_system_status_command() { let mut mock_network = MockNetworkTrait::new();