feat(network): Added support for fetching Sonarr queued events

This commit is contained in:
2024-11-19 12:01:07 -07:00
parent 9ceb55a314
commit 6b64b5ecc4
15 changed files with 160 additions and 53 deletions
@@ -8,10 +8,11 @@ mod tests {
use crate::event::Key; use crate::event::Key;
use crate::handlers::radarr_handlers::system::system_details_handler::SystemDetailsHandler; use crate::handlers::radarr_handlers::system::system_details_handler::SystemDetailsHandler;
use crate::handlers::KeyEventHandler; use crate::handlers::KeyEventHandler;
use crate::models::radarr_models::{QueueEvent, Task}; use crate::models::radarr_models::Task;
use crate::models::servarr_data::radarr::radarr_data::{ use crate::models::servarr_data::radarr::radarr_data::{
ActiveRadarrBlock, SYSTEM_DETAILS_BLOCKS, ActiveRadarrBlock, SYSTEM_DETAILS_BLOCKS,
}; };
use crate::models::servarr_models::QueueEvent;
use crate::models::{HorizontallyScrollableText, ScrollableText}; use crate::models::{HorizontallyScrollableText, ScrollableText};
mod test_handle_scroll_up_and_down { mod test_handle_scroll_up_and_down {
@@ -9,10 +9,11 @@ mod tests {
use crate::event::Key; use crate::event::Key;
use crate::handlers::radarr_handlers::system::SystemHandler; use crate::handlers::radarr_handlers::system::SystemHandler;
use crate::handlers::KeyEventHandler; use crate::handlers::KeyEventHandler;
use crate::models::radarr_models::{QueueEvent, Task}; use crate::models::radarr_models::Task;
use crate::models::servarr_data::radarr::radarr_data::{ use crate::models::servarr_data::radarr::radarr_data::{
ActiveRadarrBlock, SYSTEM_DETAILS_BLOCKS, ActiveRadarrBlock, SYSTEM_DETAILS_BLOCKS,
}; };
use crate::models::servarr_models::QueueEvent;
use crate::test_handler_delegation; use crate::test_handler_delegation;
mod test_handle_left_right_action { mod test_handle_left_right_action {
+1 -14
View File
@@ -9,7 +9,7 @@ use strum_macros::EnumIter;
use crate::{models::HorizontallyScrollableText, serde_enum_from}; use crate::{models::HorizontallyScrollableText, serde_enum_from};
use super::servarr_models::{HostConfig, Indexer, SecurityConfig}; use super::servarr_models::{HostConfig, Indexer, QueueEvent, SecurityConfig};
use super::Serdeable; use super::Serdeable;
#[cfg(test)] #[cfg(test)]
@@ -462,19 +462,6 @@ pub struct QualityWrapper {
pub quality: Quality, pub quality: Quality,
} }
#[derive(Default, Serialize, Deserialize, Debug, Clone, PartialEq, Eq)]
#[serde(rename_all = "camelCase")]
pub struct QueueEvent {
pub trigger: String,
pub name: String,
pub command_name: String,
pub status: String,
pub queued: DateTime<Utc>,
pub started: Option<DateTime<Utc>>,
pub ended: Option<DateTime<Utc>>,
pub duration: Option<String>,
}
#[derive(Derivative, Serialize, Deserialize, Debug, Clone, PartialEq, Eq)] #[derive(Derivative, Serialize, Deserialize, Debug, Clone, PartialEq, Eq)]
#[derivative(Default)] #[derivative(Default)]
pub struct Rating { pub struct Rating {
+2 -2
View File
@@ -8,9 +8,9 @@ mod tests {
AddMovieSearchResult, BlocklistItem, BlocklistResponse, Collection, Credit, DiskSpace, AddMovieSearchResult, BlocklistItem, BlocklistResponse, Collection, Credit, DiskSpace,
DownloadRecord, DownloadsResponse, Indexer, IndexerSettings, IndexerTestResult, Log, DownloadRecord, DownloadsResponse, Indexer, IndexerSettings, IndexerTestResult, Log,
LogResponse, MinimumAvailability, Monitor, Movie, MovieHistoryItem, QualityProfile, LogResponse, MinimumAvailability, Monitor, Movie, MovieHistoryItem, QualityProfile,
QueueEvent, RadarrSerdeable, Release, RootFolder, SystemStatus, Tag, Task, TaskName, Update, RadarrSerdeable, Release, RootFolder, SystemStatus, Tag, Task, TaskName, Update,
}, },
servarr_models::{HostConfig, SecurityConfig}, servarr_models::{HostConfig, QueueEvent, SecurityConfig},
Serdeable, Serdeable,
}; };
@@ -7,13 +7,13 @@ use crate::app::radarr::radarr_context_clues::{
}; };
use crate::models::radarr_models::{ use crate::models::radarr_models::{
AddMovieSearchResult, BlocklistItem, Collection, CollectionMovie, DiskSpace, DownloadRecord, AddMovieSearchResult, BlocklistItem, Collection, CollectionMovie, DiskSpace, DownloadRecord,
IndexerSettings, Movie, QueueEvent, RootFolder, Task, IndexerSettings, Movie, RootFolder, Task,
}; };
use crate::models::servarr_data::radarr::modals::{ use crate::models::servarr_data::radarr::modals::{
AddMovieModal, EditCollectionModal, EditIndexerModal, EditMovieModal, IndexerTestResultModalItem, AddMovieModal, EditCollectionModal, EditIndexerModal, EditMovieModal, IndexerTestResultModalItem,
MovieDetailsModal, MovieDetailsModal,
}; };
use crate::models::servarr_models::Indexer; use crate::models::servarr_models::{Indexer, QueueEvent};
use crate::models::stateful_list::StatefulList; use crate::models::stateful_list::StatefulList;
use crate::models::stateful_table::StatefulTable; use crate::models::stateful_table::StatefulTable;
use crate::models::{ use crate::models::{
+17 -15
View File
@@ -3,7 +3,7 @@ use chrono::{DateTime, Utc};
use strum::EnumIter; use strum::EnumIter;
use crate::models::{ use crate::models::{
servarr_models::Indexer, servarr_models::{Indexer, QueueEvent},
sonarr_models::{BlocklistItem, DownloadRecord, Episode, IndexerSettings, Series}, sonarr_models::{BlocklistItem, DownloadRecord, Episode, IndexerSettings, Series},
stateful_list::StatefulList, stateful_list::StatefulList,
stateful_table::StatefulTable, stateful_table::StatefulTable,
@@ -18,35 +18,37 @@ use super::modals::EpisodeDetailsModal;
mod sonarr_data_tests; mod sonarr_data_tests;
pub struct SonarrData { pub struct SonarrData {
pub version: String,
pub start_time: DateTime<Utc>,
pub series: StatefulTable<Series>,
pub blocklist: StatefulTable<BlocklistItem>, pub blocklist: StatefulTable<BlocklistItem>,
pub logs: StatefulList<HorizontallyScrollableText>,
pub episodes_tree: StatefulTree<Episode>,
pub episodes_table: StatefulTable<Episode>,
pub downloads: StatefulTable<DownloadRecord>, pub downloads: StatefulTable<DownloadRecord>,
pub episode_details_modal: Option<EpisodeDetailsModal>, pub episode_details_modal: Option<EpisodeDetailsModal>,
pub quality_profile_map: BiMap<i64, String>, pub episodes_table: StatefulTable<Episode>,
pub episodes_tree: StatefulTree<Episode>,
pub indexers: StatefulTable<Indexer>, pub indexers: StatefulTable<Indexer>,
pub indexer_settings: Option<IndexerSettings>, pub indexer_settings: Option<IndexerSettings>,
pub logs: StatefulList<HorizontallyScrollableText>,
pub quality_profile_map: BiMap<i64, String>,
pub queued_events: StatefulTable<QueueEvent>,
pub series: StatefulTable<Series>,
pub start_time: DateTime<Utc>,
pub version: String,
} }
impl Default for SonarrData { impl Default for SonarrData {
fn default() -> SonarrData { fn default() -> SonarrData {
SonarrData { SonarrData {
version: String::new(),
start_time: DateTime::default(),
series: StatefulTable::default(),
blocklist: StatefulTable::default(), blocklist: StatefulTable::default(),
logs: StatefulList::default(),
episodes_tree: StatefulTree::default(),
episodes_table: StatefulTable::default(),
downloads: StatefulTable::default(), downloads: StatefulTable::default(),
episode_details_modal: None, episode_details_modal: None,
quality_profile_map: BiMap::new(), episodes_table: StatefulTable::default(),
episodes_tree: StatefulTree::default(),
indexers: StatefulTable::default(), indexers: StatefulTable::default(),
indexer_settings: None, indexer_settings: None,
logs: StatefulList::default(),
quality_profile_map: BiMap::new(),
queued_events: StatefulTable::default(),
series: StatefulTable::default(),
start_time: DateTime::default(),
version: String::new(),
} }
} }
} }
@@ -34,18 +34,19 @@ mod tests {
fn test_sonarr_data_defaults() { fn test_sonarr_data_defaults() {
let sonarr_data = SonarrData::default(); let sonarr_data = SonarrData::default();
assert!(sonarr_data.version.is_empty());
assert_eq!(sonarr_data.start_time, <DateTime<Utc>>::default());
assert!(sonarr_data.series.is_empty());
assert!(sonarr_data.blocklist.is_empty()); assert!(sonarr_data.blocklist.is_empty());
assert!(sonarr_data.logs.is_empty());
assert!(sonarr_data.episodes_tree.is_empty());
assert!(sonarr_data.episodes_table.is_empty());
assert!(sonarr_data.downloads.is_empty()); assert!(sonarr_data.downloads.is_empty());
assert!(sonarr_data.episode_details_modal.is_none()); assert!(sonarr_data.episode_details_modal.is_none());
assert!(sonarr_data.quality_profile_map.is_empty()); assert!(sonarr_data.episodes_table.is_empty());
assert!(sonarr_data.episodes_tree.is_empty());
assert!(sonarr_data.indexers.is_empty()); assert!(sonarr_data.indexers.is_empty());
assert!(sonarr_data.indexer_settings.is_none()); assert!(sonarr_data.indexer_settings.is_none());
assert!(sonarr_data.logs.is_empty());
assert!(sonarr_data.quality_profile_map.is_empty());
assert!(sonarr_data.queued_events.is_empty());
assert!(sonarr_data.series.is_empty());
assert_eq!(sonarr_data.start_time, <DateTime<Utc>>::default());
assert!(sonarr_data.version.is_empty());
} }
} }
} }
+14
View File
@@ -1,5 +1,6 @@
use std::fmt::{Display, Formatter, Result}; use std::fmt::{Display, Formatter, Result};
use chrono::{DateTime, Utc};
use clap::ValueEnum; use clap::ValueEnum;
use serde::{Deserialize, Serialize}; use serde::{Deserialize, Serialize};
use serde_json::{Number, Value}; use serde_json::{Number, Value};
@@ -113,6 +114,19 @@ pub struct IndexerField {
pub value: Option<Value>, pub value: Option<Value>,
} }
#[derive(Default, Serialize, Deserialize, Debug, Clone, PartialEq, Eq)]
#[serde(rename_all = "camelCase")]
pub struct QueueEvent {
pub trigger: String,
pub name: String,
pub command_name: String,
pub status: String,
pub queued: DateTime<Utc>,
pub started: Option<DateTime<Utc>>,
pub ended: Option<DateTime<Utc>>,
pub duration: Option<String>,
}
#[derive(Default, Serialize, Deserialize, Clone, Debug, PartialEq, Eq)] #[derive(Default, Serialize, Deserialize, Clone, Debug, PartialEq, Eq)]
#[serde(rename_all = "camelCase")] #[serde(rename_all = "camelCase")]
pub struct SecurityConfig { pub struct SecurityConfig {
+3 -1
View File
@@ -10,7 +10,7 @@ use strum::EnumIter;
use crate::serde_enum_from; use crate::serde_enum_from;
use super::{ use super::{
servarr_models::{HostConfig, Indexer, SecurityConfig}, servarr_models::{HostConfig, Indexer, QueueEvent, SecurityConfig},
HorizontallyScrollableText, Serdeable, HorizontallyScrollableText, Serdeable,
}; };
@@ -352,6 +352,7 @@ pub enum SonarrSerdeable {
IndexerSettings(IndexerSettings), IndexerSettings(IndexerSettings),
Indexers(Vec<Indexer>), Indexers(Vec<Indexer>),
QualityProfiles(Vec<QualityProfile>), QualityProfiles(Vec<QualityProfile>),
QueueEvents(Vec<QueueEvent>),
SecurityConfig(SecurityConfig), SecurityConfig(SecurityConfig),
SeriesVec(Vec<Series>), SeriesVec(Vec<Series>),
SystemStatus(SystemStatus), SystemStatus(SystemStatus),
@@ -381,6 +382,7 @@ serde_enum_from!(
IndexerSettings(IndexerSettings), IndexerSettings(IndexerSettings),
Indexers(Vec<Indexer>), Indexers(Vec<Indexer>),
QualityProfiles(Vec<QualityProfile>), QualityProfiles(Vec<QualityProfile>),
QueueEvents(Vec<QueueEvent>),
SecurityConfig(SecurityConfig), SecurityConfig(SecurityConfig),
SeriesVec(Vec<Series>), SeriesVec(Vec<Series>),
SystemStatus(SystemStatus), SystemStatus(SystemStatus),
+13 -1
View File
@@ -4,7 +4,7 @@ mod tests {
use serde_json::json; use serde_json::json;
use crate::models::{ use crate::models::{
servarr_models::{HostConfig, Indexer, SecurityConfig}, servarr_models::{HostConfig, Indexer, QueueEvent, SecurityConfig},
sonarr_models::{ sonarr_models::{
BlocklistItem, BlocklistResponse, DownloadRecord, DownloadsResponse, Episode, BlocklistItem, BlocklistResponse, DownloadRecord, DownloadsResponse, Episode,
IndexerSettings, Log, LogResponse, QualityProfile, Series, SeriesStatus, SeriesType, IndexerSettings, Log, LogResponse, QualityProfile, Series, SeriesStatus, SeriesType,
@@ -231,6 +231,18 @@ mod tests {
); );
} }
#[test]
fn test_sonarr_serdeable_from_queue_events() {
let queue_events = vec![QueueEvent {
trigger: "test".to_owned(),
..QueueEvent::default()
}];
let sonarr_serdeable: SonarrSerdeable = queue_events.clone().into();
assert_eq!(sonarr_serdeable, SonarrSerdeable::QueueEvents(queue_events));
}
#[test] #[test]
fn test_sonarr_serdeable_from_security_config() { fn test_sonarr_serdeable_from_security_config() {
let security_config = SecurityConfig { let security_config = SecurityConfig {
+8 -5
View File
@@ -11,15 +11,15 @@ use crate::models::radarr_models::{
CollectionMovie, CommandBody, Credit, CreditType, DeleteMovieParams, DiskSpace, DownloadRecord, CollectionMovie, CommandBody, Credit, CreditType, DeleteMovieParams, DiskSpace, DownloadRecord,
DownloadsResponse, EditCollectionParams, EditIndexerParams, EditMovieParams, IndexerSettings, DownloadsResponse, EditCollectionParams, EditIndexerParams, EditMovieParams, IndexerSettings,
IndexerTestResult, LogResponse, Movie, MovieCommandBody, MovieHistoryItem, QualityProfile, IndexerTestResult, LogResponse, Movie, MovieCommandBody, MovieHistoryItem, QualityProfile,
QueueEvent, RadarrSerdeable, Release, ReleaseDownloadBody, RootFolder, SystemStatus, Tag, Task, RadarrSerdeable, Release, ReleaseDownloadBody, RootFolder, SystemStatus, Tag, Task, TaskName,
TaskName, Update, Update,
}; };
use crate::models::servarr_data::radarr::modals::{ use crate::models::servarr_data::radarr::modals::{
AddMovieModal, EditCollectionModal, EditIndexerModal, EditMovieModal, IndexerTestResultModalItem, AddMovieModal, EditCollectionModal, EditIndexerModal, EditMovieModal, IndexerTestResultModalItem,
MovieDetailsModal, MovieDetailsModal,
}; };
use crate::models::servarr_data::radarr::radarr_data::ActiveRadarrBlock; use crate::models::servarr_data::radarr::radarr_data::ActiveRadarrBlock;
use crate::models::servarr_models::{HostConfig, Indexer, SecurityConfig}; use crate::models::servarr_models::{HostConfig, Indexer, QueueEvent, SecurityConfig};
use crate::models::stateful_table::StatefulTable; use crate::models::stateful_table::StatefulTable;
use crate::models::{HorizontallyScrollableText, Route, Scrollable, ScrollableText}; use crate::models::{HorizontallyScrollableText, Route, Scrollable, ScrollableText};
use crate::network::{Network, NetworkEvent, RequestMethod}; use crate::network::{Network, NetworkEvent, RequestMethod};
@@ -219,7 +219,10 @@ impl<'a, 'b> Network<'a, 'b> {
.get_radarr_quality_profiles() .get_radarr_quality_profiles()
.await .await
.map(RadarrSerdeable::from), .map(RadarrSerdeable::from),
RadarrEvent::GetQueuedEvents => self.get_queued_events().await.map(RadarrSerdeable::from), RadarrEvent::GetQueuedEvents => self
.get_queued_radarr_events()
.await
.map(RadarrSerdeable::from),
RadarrEvent::GetReleases(movie_id) => { RadarrEvent::GetReleases(movie_id) => {
self.get_releases(movie_id).await.map(RadarrSerdeable::from) self.get_releases(movie_id).await.map(RadarrSerdeable::from)
} }
@@ -1728,7 +1731,7 @@ impl<'a, 'b> Network<'a, 'b> {
.await .await
} }
async fn get_queued_events(&mut self) -> Result<Vec<QueueEvent>> { async fn get_queued_radarr_events(&mut self) -> Result<Vec<QueueEvent>> {
info!("Fetching Radarr queued events"); info!("Fetching Radarr queued events");
let event = RadarrEvent::GetQueuedEvents; let event = RadarrEvent::GetQueuedEvents;
+1 -1
View File
@@ -2399,7 +2399,7 @@ mod test {
} }
#[tokio::test] #[tokio::test]
async fn test_handle_get_queued_events_event() { async fn test_handle_get_queued_radarr_events_event() {
let queued_events_json = json!([{ let queued_events_json = json!([{
"name": "RefreshMonitoredDownloads", "name": "RefreshMonitoredDownloads",
"commandName": "Refresh Monitored Downloads", "commandName": "Refresh Monitored Downloads",
+26 -1
View File
@@ -9,7 +9,7 @@ use serde_json::{json, Value};
use crate::{ use crate::{
models::{ models::{
servarr_data::sonarr::{modals::EpisodeDetailsModal, sonarr_data::ActiveSonarrBlock}, servarr_data::sonarr::{modals::EpisodeDetailsModal, sonarr_data::ActiveSonarrBlock},
servarr_models::{HostConfig, Indexer, SecurityConfig}, servarr_models::{HostConfig, Indexer, QueueEvent, SecurityConfig},
sonarr_models::{ sonarr_models::{
BlocklistResponse, DownloadRecord, DownloadsResponse, Episode, IndexerSettings, LogResponse, BlocklistResponse, DownloadRecord, DownloadsResponse, Episode, IndexerSettings, LogResponse,
QualityProfile, Series, SonarrSerdeable, SystemStatus, QualityProfile, Series, SonarrSerdeable, SystemStatus,
@@ -38,6 +38,7 @@ pub enum SonarrEvent {
GetEpisodes(Option<i64>), GetEpisodes(Option<i64>),
GetLogs(Option<u64>), GetLogs(Option<u64>),
GetQualityProfiles, GetQualityProfiles,
GetQueuedEvents,
GetSecurityConfig, GetSecurityConfig,
GetStatus, GetStatus,
HealthCheck, HealthCheck,
@@ -57,6 +58,7 @@ impl NetworkResource for SonarrEvent {
SonarrEvent::GetIndexers => "/indexer", SonarrEvent::GetIndexers => "/indexer",
SonarrEvent::GetLogs(_) => "/log", SonarrEvent::GetLogs(_) => "/log",
SonarrEvent::GetQualityProfiles => "/qualityprofile", SonarrEvent::GetQualityProfiles => "/qualityprofile",
SonarrEvent::GetQueuedEvents => "/command",
SonarrEvent::GetStatus => "/system/status", SonarrEvent::GetStatus => "/system/status",
SonarrEvent::HealthCheck => "/health", SonarrEvent::HealthCheck => "/health",
SonarrEvent::ListSeries => "/series", SonarrEvent::ListSeries => "/series",
@@ -107,6 +109,10 @@ impl<'a, 'b> Network<'a, 'b> {
.get_sonarr_quality_profiles() .get_sonarr_quality_profiles()
.await .await
.map(SonarrSerdeable::from), .map(SonarrSerdeable::from),
SonarrEvent::GetQueuedEvents => self
.get_queued_sonarr_events()
.await
.map(SonarrSerdeable::from),
SonarrEvent::GetLogs(events) => self SonarrEvent::GetLogs(events) => self
.get_sonarr_logs(events) .get_sonarr_logs(events)
.await .await
@@ -523,6 +529,25 @@ impl<'a, 'b> Network<'a, 'b> {
.await .await
} }
async fn get_queued_sonarr_events(&mut self) -> Result<Vec<QueueEvent>> {
info!("Fetching Sonarr queued events");
let event = SonarrEvent::GetQueuedEvents;
let request_props = self
.request_props_from(event, RequestMethod::Get, None::<()>, None, None)
.await;
self
.handle_request::<(), Vec<QueueEvent>>(request_props, |queued_events_vec, mut app| {
app
.data
.sonarr_data
.queued_events
.set_items(queued_events_vec);
})
.await
}
async fn get_sonarr_security_config(&mut self) -> Result<SecurityConfig> { async fn get_sonarr_security_config(&mut self) -> Result<SecurityConfig> {
info!("Fetching Sonarr security config"); info!("Fetching Sonarr security config");
let event = SonarrEvent::GetSecurityConfig; let event = SonarrEvent::GetSecurityConfig;
+59 -1
View File
@@ -22,7 +22,9 @@ mod test {
use crate::app::App; use crate::app::App;
use crate::models::servarr_data::sonarr::sonarr_data::ActiveSonarrBlock; use crate::models::servarr_data::sonarr::sonarr_data::ActiveSonarrBlock;
use crate::models::servarr_models::{HostConfig, Indexer, IndexerField, SecurityConfig}; use crate::models::servarr_models::{
HostConfig, Indexer, IndexerField, QueueEvent, SecurityConfig,
};
use crate::models::sonarr_models::{ use crate::models::sonarr_models::{
BlocklistItem, DownloadRecord, DownloadsResponse, Episode, EpisodeFile, Language, LogResponse, BlocklistItem, DownloadRecord, DownloadsResponse, Episode, EpisodeFile, Language, LogResponse,
MediaInfo, QualityProfile, MediaInfo, QualityProfile,
@@ -145,6 +147,11 @@ mod test {
assert_str_eq!(event.resource(), "/config/host"); assert_str_eq!(event.resource(), "/config/host");
} }
#[rstest]
fn test_resource_command(#[values(SonarrEvent::GetQueuedEvents)] event: SonarrEvent) {
assert_str_eq!(event.resource(), "/command");
}
#[rstest] #[rstest]
fn test_resource_indexer(#[values(SonarrEvent::GetIndexers)] event: SonarrEvent) { fn test_resource_indexer(#[values(SonarrEvent::GetIndexers)] event: SonarrEvent) {
assert_str_eq!(event.resource(), "/indexer"); assert_str_eq!(event.resource(), "/indexer");
@@ -1130,6 +1137,57 @@ mod test {
} }
} }
#[tokio::test]
async fn test_handle_get_queued_sonarr_events_event() {
let queued_events_json = json!([{
"name": "RefreshMonitoredDownloads",
"commandName": "Refresh Monitored Downloads",
"status": "completed",
"queued": "2023-05-20T21:29:16Z",
"started": "2023-05-20T21:29:16Z",
"ended": "2023-05-20T21:29:16Z",
"duration": "00:00:00.5111547",
"trigger": "scheduled",
}]);
let response: Vec<QueueEvent> = serde_json::from_value(queued_events_json.clone()).unwrap();
let timestamp = DateTime::from(DateTime::parse_from_rfc3339("2023-05-20T21:29:16Z").unwrap());
let expected_event = QueueEvent {
name: "RefreshMonitoredDownloads".to_owned(),
command_name: "Refresh Monitored Downloads".to_owned(),
status: "completed".to_owned(),
queued: timestamp,
started: Some(timestamp),
ended: Some(timestamp),
duration: Some("00:00:00.5111547".to_owned()),
trigger: "scheduled".to_owned(),
};
let (async_server, app_arc, _server) = mock_servarr_api(
RequestMethod::Get,
None,
Some(queued_events_json),
None,
SonarrEvent::GetQueuedEvents,
None,
None,
)
.await;
let mut network = Network::new(&app_arc, CancellationToken::new(), Client::new());
if let SonarrSerdeable::QueueEvents(events) = network
.handle_sonarr_event(SonarrEvent::GetQueuedEvents)
.await
.unwrap()
{
async_server.assert_async().await;
assert_eq!(
app_arc.lock().await.data.sonarr_data.queued_events.items,
vec![expected_event]
);
assert_eq!(events, response);
}
}
#[rstest] #[rstest]
#[tokio::test] #[tokio::test]
async fn test_handle_get_series_event(#[values(true, false)] use_custom_sorting: bool) { async fn test_handle_get_series_event(#[values(true, false)] use_custom_sorting: bool) {
+2 -1
View File
@@ -12,8 +12,9 @@ use ratatui::{
}; };
use crate::app::App; use crate::app::App;
use crate::models::radarr_models::{QueueEvent, Task}; use crate::models::radarr_models::Task;
use crate::models::servarr_data::radarr::radarr_data::ActiveRadarrBlock; use crate::models::servarr_data::radarr::radarr_data::ActiveRadarrBlock;
use crate::models::servarr_models::QueueEvent;
use crate::ui::radarr_ui::radarr_ui_utils::{convert_to_minutes_hours_days, style_log_list_item}; use crate::ui::radarr_ui::radarr_ui_utils::{convert_to_minutes_hours_days, style_log_list_item};
use crate::ui::radarr_ui::system::system_details_ui::SystemDetailsUi; use crate::ui::radarr_ui::system::system_details_ui::SystemDetailsUi;
use crate::ui::styles::ManagarrStyle; use crate::ui::styles::ManagarrStyle;