feat: CLI support for deleting a tag in Lidarr

This commit is contained in:
2026-01-07 12:50:23 -07:00
parent a18b047f4f
commit a8609e08c5
5 changed files with 124 additions and 15 deletions
@@ -25,6 +25,18 @@ mod tests {
assert_str_eq!(event.resource(), "/artist");
}
#[rstest]
fn test_resource_tag(
#[values(
LidarrEvent::AddTag(String::new()),
LidarrEvent::DeleteTag(0),
LidarrEvent::GetTags
)]
event: LidarrEvent,
) {
assert_str_eq!(event.resource(), "/tag");
}
#[rstest]
fn test_resource_config(
#[values(LidarrEvent::GetHostConfig, LidarrEvent::GetSecurityConfig)] event: LidarrEvent,
@@ -208,6 +220,21 @@ mod tests {
);
}
#[tokio::test]
async fn test_handle_delete_lidarr_tag_event() {
let (mock, app, _server) = MockServarrApi::delete()
.path("/1")
.build_for(LidarrEvent::DeleteTag(1))
.await;
app.lock().await.server_tabs.set_index(2);
let mut network = test_network(&app);
let result = network.handle_lidarr_event(LidarrEvent::DeleteTag(1)).await;
mock.assert_async().await;
assert!(result.is_ok());
}
#[tokio::test]
async fn test_extract_and_add_lidarr_tag_ids_vec() {
let app_arc = Arc::new(Mutex::new(App::test_default()));
+25 -1
View File
@@ -25,6 +25,7 @@ pub mod lidarr_network_test_utils;
pub enum LidarrEvent {
AddTag(String),
DeleteArtist(DeleteArtistParams),
DeleteTag(i64),
EditArtist(EditArtistParams),
GetArtistDetails(i64),
GetDiskSpace,
@@ -45,7 +46,7 @@ pub enum LidarrEvent {
impl NetworkResource for LidarrEvent {
fn resource(&self) -> &'static str {
match &self {
LidarrEvent::AddTag(_) | LidarrEvent::GetTags => "/tag",
LidarrEvent::AddTag(_) | LidarrEvent::DeleteTag(_) | LidarrEvent::GetTags => "/tag",
LidarrEvent::DeleteArtist(_)
| LidarrEvent::EditArtist(_)
| LidarrEvent::GetArtistDetails(_)
@@ -80,6 +81,10 @@ impl Network<'_, '_> {
LidarrEvent::DeleteArtist(params) => {
self.delete_artist(params).await.map(LidarrSerdeable::from)
}
LidarrEvent::DeleteTag(tag_id) => self
.delete_lidarr_tag(tag_id)
.await
.map(LidarrSerdeable::from),
LidarrEvent::GetArtistDetails(artist_id) => self
.get_artist_details(artist_id)
.await
@@ -213,6 +218,25 @@ impl Network<'_, '_> {
.await
}
async fn delete_lidarr_tag(&mut self, id: i64) -> Result<()> {
info!("Deleting Lidarr tag with ID: {id}");
let event = LidarrEvent::DeleteTag(id);
let request_props = self
.request_props_from(
event,
RequestMethod::Delete,
None::<()>,
Some(format!("/{id}")),
None,
)
.await;
self
.handle_request::<(), ()>(request_props, |_, _| ())
.await
}
pub(in crate::network::lidarr_network) async fn extract_and_add_lidarr_tag_ids_vec(
&mut self,
edit_tags: &str,