feat(network): Support for fetching all Sonarr root folders

This commit is contained in:
2024-11-21 16:37:23 -07:00
parent f4c647342b
commit 16538a3158
18 changed files with 138 additions and 45 deletions
@@ -8,10 +8,9 @@ mod tests {
use crate::event::Key; use crate::event::Key;
use crate::handlers::radarr_handlers::library::add_movie_handler::AddMovieHandler; use crate::handlers::radarr_handlers::library::add_movie_handler::AddMovieHandler;
use crate::handlers::KeyEventHandler; use crate::handlers::KeyEventHandler;
use crate::models::radarr_models::{ use crate::models::radarr_models::{AddMovieSearchResult, MinimumAvailability, Monitor};
AddMovieSearchResult, MinimumAvailability, Monitor, RootFolder,
};
use crate::models::servarr_data::radarr::radarr_data::{ActiveRadarrBlock, ADD_MOVIE_BLOCKS}; use crate::models::servarr_data::radarr::radarr_data::{ActiveRadarrBlock, ADD_MOVIE_BLOCKS};
use crate::models::servarr_models::RootFolder;
use crate::models::HorizontallyScrollableText; use crate::models::HorizontallyScrollableText;
mod test_handle_scroll_up_and_down { mod test_handle_scroll_up_and_down {
@@ -8,14 +8,14 @@ mod tests {
use crate::event::Key; use crate::event::Key;
use crate::handlers::radarr_handlers::root_folders::RootFoldersHandler; use crate::handlers::radarr_handlers::root_folders::RootFoldersHandler;
use crate::handlers::KeyEventHandler; use crate::handlers::KeyEventHandler;
use crate::models::radarr_models::RootFolder;
use crate::models::servarr_data::radarr::radarr_data::{ActiveRadarrBlock, ROOT_FOLDERS_BLOCKS}; use crate::models::servarr_data::radarr::radarr_data::{ActiveRadarrBlock, ROOT_FOLDERS_BLOCKS};
use crate::models::servarr_models::RootFolder;
use crate::models::HorizontallyScrollableText; use crate::models::HorizontallyScrollableText;
mod test_handle_scroll_up_and_down { mod test_handle_scroll_up_and_down {
use rstest::rstest; use rstest::rstest;
use crate::models::radarr_models::RootFolder; use crate::models::servarr_models::RootFolder;
use crate::{simple_stateful_iterable_vec, test_iterable_scroll}; use crate::{simple_stateful_iterable_vec, test_iterable_scroll};
use super::*; use super::*;
@@ -63,7 +63,7 @@ mod tests {
use pretty_assertions::assert_eq; use pretty_assertions::assert_eq;
use crate::models::radarr_models::RootFolder; use crate::models::servarr_models::RootFolder;
use crate::{extended_stateful_iterable_vec, test_iterable_home_and_end}; use crate::{extended_stateful_iterable_vec, test_iterable_home_and_end};
use super::*; use super::*;
+1 -19
View File
@@ -11,7 +11,7 @@ use crate::{models::HorizontallyScrollableText, serde_enum_from};
use super::servarr_models::{ use super::servarr_models::{
HostConfig, Indexer, Language, LogResponse, QualityProfile, QualityWrapper, QueueEvent, Release, HostConfig, Indexer, Language, LogResponse, QualityProfile, QualityWrapper, QueueEvent, Release,
SecurityConfig, RootFolder, SecurityConfig,
}; };
use super::{EnumDisplayStyle, Serdeable}; use super::{EnumDisplayStyle, Serdeable};
@@ -440,18 +440,6 @@ pub struct ReleaseDownloadBody {
pub movie_id: i64, pub movie_id: i64,
} }
#[derive(Default, Serialize, Deserialize, Debug, Clone, Eq, PartialEq)]
#[serde(rename_all = "camelCase")]
pub struct RootFolder {
#[serde(deserialize_with = "super::from_i64")]
pub id: i64,
pub path: String,
pub accessible: bool,
#[serde(deserialize_with = "super::from_i64")]
pub free_space: i64,
pub unmapped_folders: Option<Vec<UnmappedFolder>>,
}
#[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 SystemStatus { pub struct SystemStatus {
@@ -504,12 +492,6 @@ impl Display for TaskName {
} }
} }
#[derive(Serialize, Deserialize, Default, Debug, Clone, Eq, PartialEq)]
pub struct UnmappedFolder {
pub name: String,
pub path: String,
}
#[derive(Default, Serialize, Deserialize, Debug, Clone, PartialEq, Eq)] #[derive(Default, Serialize, Deserialize, Debug, Clone, PartialEq, Eq)]
#[serde(rename_all = "camelCase")] #[serde(rename_all = "camelCase")]
pub struct Update { pub struct Update {
+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, DownloadRecord, DownloadsResponse, Indexer, IndexerSettings, IndexerTestResult,
MinimumAvailability, Monitor, Movie, MovieHistoryItem, QualityProfile, RadarrSerdeable, MinimumAvailability, Monitor, Movie, MovieHistoryItem, QualityProfile, RadarrSerdeable,
Release, RootFolder, SystemStatus, Tag, Task, TaskName, Update, Release, SystemStatus, Tag, Task, TaskName, Update,
}, },
servarr_models::{HostConfig, Log, LogResponse, QueueEvent, SecurityConfig}, servarr_models::{HostConfig, Log, LogResponse, QueueEvent, RootFolder, SecurityConfig},
EnumDisplayStyle, Serdeable, EnumDisplayStyle, Serdeable,
}; };
+2 -2
View File
@@ -1,10 +1,10 @@
use strum::IntoEnumIterator; use strum::IntoEnumIterator;
use crate::models::radarr_models::{ use crate::models::radarr_models::{
Collection, Credit, MinimumAvailability, Monitor, Movie, MovieHistoryItem, RootFolder, Collection, Credit, MinimumAvailability, Monitor, Movie, MovieHistoryItem,
}; };
use crate::models::servarr_data::radarr::radarr_data::RadarrData; use crate::models::servarr_data::radarr::radarr_data::RadarrData;
use crate::models::servarr_models::{Indexer, Release}; use crate::models::servarr_models::{Indexer, Release, RootFolder};
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::{HorizontallyScrollableText, ScrollableText}; use crate::models::{HorizontallyScrollableText, ScrollableText};
@@ -1,12 +1,12 @@
#[cfg(test)] #[cfg(test)]
mod test { mod test {
use crate::models::radarr_models::{Collection, MinimumAvailability, Monitor, Movie, RootFolder}; use crate::models::radarr_models::{Collection, MinimumAvailability, Monitor, Movie};
use crate::models::servarr_data::radarr::modals::{ use crate::models::servarr_data::radarr::modals::{
AddMovieModal, EditCollectionModal, EditIndexerModal, EditMovieModal, AddMovieModal, EditCollectionModal, EditIndexerModal, EditMovieModal,
}; };
use crate::models::servarr_data::radarr::radarr_data::radarr_test_utils::utils::create_test_radarr_data; use crate::models::servarr_data::radarr::radarr_data::radarr_test_utils::utils::create_test_radarr_data;
use crate::models::servarr_data::radarr::radarr_data::RadarrData; use crate::models::servarr_data::radarr::radarr_data::RadarrData;
use crate::models::servarr_models::{Indexer, IndexerField}; use crate::models::servarr_models::{Indexer, IndexerField, RootFolder};
use crate::models::stateful_table::StatefulTable; use crate::models::stateful_table::StatefulTable;
use bimap::BiMap; use bimap::BiMap;
use pretty_assertions::{assert_eq, assert_str_eq}; use pretty_assertions::{assert_eq, assert_str_eq};
@@ -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, RootFolder, Task, IndexerSettings, Movie, 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, QueueEvent}; use crate::models::servarr_models::{Indexer, QueueEvent, RootFolder};
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::{
@@ -3,7 +3,7 @@ use chrono::{DateTime, Utc};
use strum::EnumIter; use strum::EnumIter;
use crate::models::{ use crate::models::{
servarr_models::{Indexer, QueueEvent}, servarr_models::{Indexer, QueueEvent, RootFolder},
sonarr_models::{ sonarr_models::{
BlocklistItem, DownloadRecord, IndexerSettings, Season, Series, SonarrHistoryItem, BlocklistItem, DownloadRecord, IndexerSettings, Season, Series, SonarrHistoryItem,
}, },
@@ -27,6 +27,7 @@ pub struct SonarrData {
pub logs: StatefulList<HorizontallyScrollableText>, pub logs: StatefulList<HorizontallyScrollableText>,
pub quality_profile_map: BiMap<i64, String>, pub quality_profile_map: BiMap<i64, String>,
pub queued_events: StatefulTable<QueueEvent>, pub queued_events: StatefulTable<QueueEvent>,
pub root_folders: StatefulTable<RootFolder>,
pub seasons: StatefulTable<Season>, pub seasons: StatefulTable<Season>,
pub season_details_modal: Option<SeasonDetailsModal>, pub season_details_modal: Option<SeasonDetailsModal>,
pub series: StatefulTable<Series>, pub series: StatefulTable<Series>,
@@ -46,6 +47,7 @@ impl Default for SonarrData {
logs: StatefulList::default(), logs: StatefulList::default(),
quality_profile_map: BiMap::new(), quality_profile_map: BiMap::new(),
queued_events: StatefulTable::default(), queued_events: StatefulTable::default(),
root_folders: StatefulTable::default(),
seasons: StatefulTable::default(), seasons: StatefulTable::default(),
season_details_modal: None, season_details_modal: None,
series: StatefulTable::default(), series: StatefulTable::default(),
@@ -42,6 +42,7 @@ mod tests {
assert!(sonarr_data.logs.is_empty()); assert!(sonarr_data.logs.is_empty());
assert!(sonarr_data.quality_profile_map.is_empty()); assert!(sonarr_data.quality_profile_map.is_empty());
assert!(sonarr_data.queued_events.is_empty()); assert!(sonarr_data.queued_events.is_empty());
assert!(sonarr_data.root_folders.is_empty());
assert!(sonarr_data.seasons.is_empty()); assert!(sonarr_data.seasons.is_empty());
assert!(sonarr_data.season_details_modal.is_none()); assert!(sonarr_data.season_details_modal.is_none());
assert!(sonarr_data.series.is_empty()); assert!(sonarr_data.series.is_empty());
+18
View File
@@ -197,6 +197,18 @@ pub struct Release {
pub quality: QualityWrapper, pub quality: QualityWrapper,
} }
#[derive(Default, Serialize, Deserialize, Debug, Clone, Eq, PartialEq)]
#[serde(rename_all = "camelCase")]
pub struct RootFolder {
#[serde(deserialize_with = "super::from_i64")]
pub id: i64,
pub path: String,
pub accessible: bool,
#[serde(deserialize_with = "super::from_i64")]
pub free_space: i64,
pub unmapped_folders: Option<Vec<UnmappedFolder>>,
}
#[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 {
@@ -210,3 +222,9 @@ pub struct SecurityConfig {
pub api_key: String, pub api_key: String,
pub certificate_validation: CertificateValidation, pub certificate_validation: CertificateValidation,
} }
#[derive(Serialize, Deserialize, Default, Debug, Clone, Eq, PartialEq)]
pub struct UnmappedFolder {
pub name: String,
pub path: String,
}
+3 -1
View File
@@ -12,7 +12,7 @@ use crate::serde_enum_from;
use super::{ use super::{
servarr_models::{ servarr_models::{
HostConfig, Indexer, Language, LogResponse, QualityProfile, QualityWrapper, QueueEvent, HostConfig, Indexer, Language, LogResponse, QualityProfile, QualityWrapper, QueueEvent,
Release, SecurityConfig, Release, RootFolder, SecurityConfig,
}, },
EnumDisplayStyle, HorizontallyScrollableText, Serdeable, EnumDisplayStyle, HorizontallyScrollableText, Serdeable,
}; };
@@ -402,6 +402,7 @@ pub enum SonarrSerdeable {
QualityProfiles(Vec<QualityProfile>), QualityProfiles(Vec<QualityProfile>),
QueueEvents(Vec<QueueEvent>), QueueEvents(Vec<QueueEvent>),
Releases(Vec<Release>), Releases(Vec<Release>),
RootFolders(Vec<RootFolder>),
SecurityConfig(SecurityConfig), SecurityConfig(SecurityConfig),
SeriesVec(Vec<Series>), SeriesVec(Vec<Series>),
Series(Series), Series(Series),
@@ -436,6 +437,7 @@ serde_enum_from!(
QualityProfiles(Vec<QualityProfile>), QualityProfiles(Vec<QualityProfile>),
QueueEvents(Vec<QueueEvent>), QueueEvents(Vec<QueueEvent>),
Releases(Vec<Release>), Releases(Vec<Release>),
RootFolders(Vec<RootFolder>),
SecurityConfig(SecurityConfig), SecurityConfig(SecurityConfig),
SeriesVec(Vec<Series>), SeriesVec(Vec<Series>),
Series(Series), Series(Series),
+14 -1
View File
@@ -5,7 +5,8 @@ mod tests {
use crate::models::{ use crate::models::{
servarr_models::{ servarr_models::{
HostConfig, Indexer, Log, LogResponse, QualityProfile, QueueEvent, Release, SecurityConfig, HostConfig, Indexer, Log, LogResponse, QualityProfile, QueueEvent, Release, RootFolder,
SecurityConfig,
}, },
sonarr_models::{ sonarr_models::{
BlocklistItem, BlocklistResponse, DownloadRecord, DownloadsResponse, Episode, BlocklistItem, BlocklistResponse, DownloadRecord, DownloadsResponse, Episode,
@@ -343,6 +344,18 @@ mod tests {
assert_eq!(sonarr_serdeable, SonarrSerdeable::Releases(releases)); assert_eq!(sonarr_serdeable, SonarrSerdeable::Releases(releases));
} }
#[test]
fn test_sonarr_serdeable_from_root_folders() {
let root_folders = vec![RootFolder {
id: 1,
..RootFolder::default()
}];
let sonarr_serdeable: SonarrSerdeable = root_folders.clone().into();
assert_eq!(sonarr_serdeable, SonarrSerdeable::RootFolders(root_folders));
}
#[test] #[test]
fn test_sonarr_serdeable_from_security_config() { fn test_sonarr_serdeable_from_security_config() {
let security_config = SecurityConfig { let security_config = SecurityConfig {
+7 -4
View File
@@ -11,7 +11,7 @@ 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, Movie, MovieCommandBody, MovieHistoryItem, RadarrSerdeable, IndexerTestResult, Movie, MovieCommandBody, MovieHistoryItem, RadarrSerdeable,
ReleaseDownloadBody, RootFolder, SystemStatus, Tag, Task, TaskName, Update, ReleaseDownloadBody, SystemStatus, Tag, Task, TaskName, 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,
@@ -19,7 +19,7 @@ use crate::models::servarr_data::radarr::modals::{
}; };
use crate::models::servarr_data::radarr::radarr_data::ActiveRadarrBlock; use crate::models::servarr_data::radarr::radarr_data::ActiveRadarrBlock;
use crate::models::servarr_models::{ use crate::models::servarr_models::{
HostConfig, Indexer, LogResponse, QualityProfile, QueueEvent, Release, SecurityConfig, HostConfig, Indexer, LogResponse, QualityProfile, QueueEvent, Release, RootFolder, 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};
@@ -228,7 +228,10 @@ impl<'a, 'b> Network<'a, 'b> {
.get_movie_releases(movie_id) .get_movie_releases(movie_id)
.await .await
.map(RadarrSerdeable::from), .map(RadarrSerdeable::from),
RadarrEvent::GetRootFolders => self.get_root_folders().await.map(RadarrSerdeable::from), RadarrEvent::GetRootFolders => self
.get_radarr_root_folders()
.await
.map(RadarrSerdeable::from),
RadarrEvent::GetSecurityConfig => self RadarrEvent::GetSecurityConfig => self
.get_radarr_security_config() .get_radarr_security_config()
.await .await
@@ -1785,7 +1788,7 @@ impl<'a, 'b> Network<'a, 'b> {
.await .await
} }
async fn get_root_folders(&mut self) -> Result<Vec<RootFolder>> { async fn get_radarr_root_folders(&mut self) -> Result<Vec<RootFolder>> {
info!("Fetching Radarr root folders"); info!("Fetching Radarr root folders");
let event = RadarrEvent::GetRootFolders; let event = RadarrEvent::GetRootFolders;
+1 -1
View File
@@ -2872,7 +2872,7 @@ mod test {
} }
#[tokio::test] #[tokio::test]
async fn test_handle_get_root_folders_event() { async fn test_handle_get_radarr_root_folders_event() {
let root_folder_json = json!([{ let root_folder_json = json!([{
"id": 1, "id": 1,
"path": "/nfs", "path": "/nfs",
+23 -1
View File
@@ -10,7 +10,8 @@ use crate::{
sonarr_data::ActiveSonarrBlock, sonarr_data::ActiveSonarrBlock,
}, },
servarr_models::{ servarr_models::{
HostConfig, Indexer, LogResponse, QualityProfile, QueueEvent, Release, SecurityConfig, HostConfig, Indexer, LogResponse, QualityProfile, QueueEvent, Release, RootFolder,
SecurityConfig,
}, },
sonarr_models::{ sonarr_models::{
BlocklistResponse, DownloadRecord, DownloadsResponse, Episode, IndexerSettings, Series, BlocklistResponse, DownloadRecord, DownloadsResponse, Episode, IndexerSettings, Series,
@@ -46,6 +47,7 @@ pub enum SonarrEvent {
GetLogs(Option<u64>), GetLogs(Option<u64>),
GetQualityProfiles, GetQualityProfiles,
GetQueuedEvents, GetQueuedEvents,
GetRootFolders,
GetEpisodeReleases(Option<i64>), GetEpisodeReleases(Option<i64>),
GetSeasonReleases(Option<(i64, i64)>), GetSeasonReleases(Option<(i64, i64)>),
GetSecurityConfig, GetSecurityConfig,
@@ -71,6 +73,7 @@ impl NetworkResource for SonarrEvent {
SonarrEvent::GetLogs(_) => "/log", SonarrEvent::GetLogs(_) => "/log",
SonarrEvent::GetQualityProfiles => "/qualityprofile", SonarrEvent::GetQualityProfiles => "/qualityprofile",
SonarrEvent::GetQueuedEvents => "/command", SonarrEvent::GetQueuedEvents => "/command",
SonarrEvent::GetRootFolders => "/rootfolder",
SonarrEvent::GetSeasonReleases(_) | SonarrEvent::GetEpisodeReleases(_) => "/release", SonarrEvent::GetSeasonReleases(_) | SonarrEvent::GetEpisodeReleases(_) => "/release",
SonarrEvent::GetSeriesHistory(_) => "/history/series", SonarrEvent::GetSeriesHistory(_) => "/history/series",
SonarrEvent::GetStatus => "/system/status", SonarrEvent::GetStatus => "/system/status",
@@ -147,6 +150,10 @@ impl<'a, 'b> Network<'a, 'b> {
.get_queued_sonarr_events() .get_queued_sonarr_events()
.await .await
.map(SonarrSerdeable::from), .map(SonarrSerdeable::from),
SonarrEvent::GetRootFolders => self
.get_sonarr_root_folders()
.await
.map(SonarrSerdeable::from),
SonarrEvent::GetEpisodeReleases(params) => self SonarrEvent::GetEpisodeReleases(params) => self
.get_episode_releases(params) .get_episode_releases(params)
.await .await
@@ -746,6 +753,21 @@ impl<'a, 'b> Network<'a, 'b> {
.await .await
} }
async fn get_sonarr_root_folders(&mut self) -> Result<Vec<RootFolder>> {
info!("Fetching Sonarr root folders");
let event = SonarrEvent::GetRootFolders;
let request_props = self
.request_props_from(event, RequestMethod::Get, None::<()>, None, None)
.await;
self
.handle_request::<(), Vec<RootFolder>>(request_props, |root_folders, mut app| {
app.data.sonarr_data.root_folders.set_items(root_folders);
})
.await
}
async fn get_episode_releases(&mut self, episode_id: Option<i64>) -> Result<Vec<Release>> { async fn get_episode_releases(&mut self, episode_id: Option<i64>) -> Result<Vec<Release>> {
let event = SonarrEvent::GetEpisodeReleases(None); let event = SonarrEvent::GetEpisodeReleases(None);
let id = self.extract_episode_id(episode_id).await; let id = self.extract_episode_id(episode_id).await;
+51 -1
View File
@@ -18,7 +18,7 @@ mod test {
use crate::models::servarr_data::sonarr::sonarr_data::ActiveSonarrBlock; use crate::models::servarr_data::sonarr::sonarr_data::ActiveSonarrBlock;
use crate::models::servarr_models::{ use crate::models::servarr_models::{
HostConfig, Indexer, IndexerField, Language, LogResponse, Quality, QualityProfile, HostConfig, Indexer, IndexerField, Language, LogResponse, Quality, QualityProfile,
QualityWrapper, QueueEvent, Release, SecurityConfig, QualityWrapper, QueueEvent, Release, RootFolder, SecurityConfig,
}; };
use crate::models::sonarr_models::SystemStatus; use crate::models::sonarr_models::SystemStatus;
use crate::models::sonarr_models::{ use crate::models::sonarr_models::{
@@ -172,6 +172,11 @@ mod test {
assert_str_eq!(event.resource(), "/queue"); assert_str_eq!(event.resource(), "/queue");
} }
#[rstest]
fn test_resource_root_folder(#[values(SonarrEvent::GetRootFolders)] event: SonarrEvent) {
assert_str_eq!(event.resource(), "/rootfolder");
}
#[rstest] #[rstest]
fn test_resource_release( fn test_resource_release(
#[values( #[values(
@@ -2148,6 +2153,41 @@ mod test {
} }
} }
#[tokio::test]
async fn test_handle_get_sonarr_root_folders_event() {
let root_folder_json = json!([{
"id": 1,
"path": "/nfs",
"accessible": true,
"freeSpace": 219902325555200u64,
}]);
let response: Vec<RootFolder> = serde_json::from_value(root_folder_json.clone()).unwrap();
let (async_server, app_arc, _server) = mock_servarr_api(
RequestMethod::Get,
None,
Some(root_folder_json),
None,
SonarrEvent::GetRootFolders,
None,
None,
)
.await;
let mut network = Network::new(&app_arc, CancellationToken::new(), Client::new());
if let SonarrSerdeable::RootFolders(root_folders) = network
.handle_sonarr_event(SonarrEvent::GetRootFolders)
.await
.unwrap()
{
async_server.assert_async().await;
assert_eq!(
app_arc.lock().await.data.sonarr_data.root_folders.items,
vec![root_folder()]
);
assert_eq!(root_folders, response);
}
}
#[tokio::test] #[tokio::test]
async fn test_handle_get_episode_releases_event() { async fn test_handle_get_episode_releases_event() {
let release_json = json!([{ let release_json = json!([{
@@ -3839,4 +3879,14 @@ mod test {
quality: quality_wrapper(), quality: quality_wrapper(),
} }
} }
fn root_folder() -> RootFolder {
RootFolder {
id: 1,
path: "/nfs".to_owned(),
accessible: true,
free_space: 219902325555200,
unmapped_folders: None,
}
}
} }
+2 -1
View File
@@ -9,8 +9,9 @@ use ratatui::Frame;
use crate::app::App; use crate::app::App;
use crate::logos::RADARR_LOGO; use crate::logos::RADARR_LOGO;
use crate::models::radarr_models::{DiskSpace, DownloadRecord, Movie, RootFolder}; use crate::models::radarr_models::{DiskSpace, DownloadRecord, Movie};
use crate::models::servarr_data::radarr::radarr_data::RadarrData; use crate::models::servarr_data::radarr::radarr_data::RadarrData;
use crate::models::servarr_models::RootFolder;
use crate::models::Route; use crate::models::Route;
use crate::ui::draw_tabs; use crate::ui::draw_tabs;
use crate::ui::radarr_ui::blocklist::BlocklistUi; use crate::ui::radarr_ui::blocklist::BlocklistUi;
+1 -1
View File
@@ -3,8 +3,8 @@ use ratatui::widgets::{Cell, Row};
use ratatui::Frame; use ratatui::Frame;
use crate::app::App; use crate::app::App;
use crate::models::radarr_models::RootFolder;
use crate::models::servarr_data::radarr::radarr_data::{ActiveRadarrBlock, ROOT_FOLDERS_BLOCKS}; use crate::models::servarr_data::radarr::radarr_data::{ActiveRadarrBlock, ROOT_FOLDERS_BLOCKS};
use crate::models::servarr_models::RootFolder;
use crate::models::Route; use crate::models::Route;
use crate::ui::styles::ManagarrStyle; use crate::ui::styles::ManagarrStyle;
use crate::ui::utils::layout_block_top_border; use crate::ui::utils::layout_block_top_border;