fix: improve usage of indicatif for tracking progress #101
| @ -5,6 +5,9 @@ version.workspace = true | |||||||
| readme.workspace = true | readme.workspace = true | ||||||
| license.workspace = true | license.workspace = true | ||||||
| 
 | 
 | ||||||
|  | [features] | ||||||
|  | testing = [] | ||||||
|  | 
 | ||||||
| [dependencies] | [dependencies] | ||||||
| rand = "0.9" | rand = "0.9" | ||||||
| hex = "0.4" | hex = "0.4" | ||||||
|  | |||||||
| @ -39,11 +39,16 @@ static HARMONY_EVENT_BUS: Lazy<broadcast::Sender<HarmonyEvent>> = Lazy::new(|| { | |||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| pub fn instrument(event: HarmonyEvent) -> Result<(), &'static str> { | pub fn instrument(event: HarmonyEvent) -> Result<(), &'static str> { | ||||||
|  |     if cfg!(any(test, feature = "testing")) { | ||||||
|  |         let _ = event; // Suppress the "unused variable" warning for `event`
 | ||||||
|  |         Ok(()) | ||||||
|  |     } else { | ||||||
|         match HARMONY_EVENT_BUS.send(event) { |         match HARMONY_EVENT_BUS.send(event) { | ||||||
|             Ok(_) => Ok(()), |             Ok(_) => Ok(()), | ||||||
|             Err(_) => Err("send error: no subscribers"), |             Err(_) => Err("send error: no subscribers"), | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| pub async fn subscribe<F, Fut>(name: &str, mut handler: F) | pub async fn subscribe<F, Fut>(name: &str, mut handler: F) | ||||||
| where | where | ||||||
|  | |||||||
| @ -29,7 +29,7 @@ impl Default for K3DInstallationScore { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl<T: Topology> Score<T> for K3DInstallationScore { | impl<T: Topology> Score<T> for K3DInstallationScore { | ||||||
|     fn create_interpret(&self) -> Box<dyn crate::interpret::Interpret<T>> { |     fn create_interpret(&self) -> Box<dyn Interpret<T>> { | ||||||
|         Box::new(K3dInstallationInterpret { |         Box::new(K3dInstallationInterpret { | ||||||
|             score: self.clone(), |             score: self.clone(), | ||||||
|         }) |         }) | ||||||
|  | |||||||
| @ -5,6 +5,10 @@ version.workspace = true | |||||||
| readme.workspace = true | readme.workspace = true | ||||||
| license.workspace = true | license.workspace = true | ||||||
| 
 | 
 | ||||||
|  | [features] | ||||||
|  | default = ["tui"] | ||||||
|  | tui = ["dep:harmony_tui"] | ||||||
|  | 
 | ||||||
| [dependencies] | [dependencies] | ||||||
| assert_cmd = "2.0.17" | assert_cmd = "2.0.17" | ||||||
| clap = { version = "4.5.35", features = ["derive"] } | clap = { version = "4.5.35", features = ["derive"] } | ||||||
| @ -19,7 +23,5 @@ lazy_static = "1.5.0" | |||||||
| log.workspace = true | log.workspace = true | ||||||
| indicatif-log-bridge = "0.2.3" | indicatif-log-bridge = "0.2.3" | ||||||
| 
 | 
 | ||||||
| 
 | [dev-dependencies] | ||||||
| [features] | harmony = { path = "../harmony", features = ["testing"] } | ||||||
| default = ["tui"] |  | ||||||
| tui = ["dep:harmony_tui"] |  | ||||||
|  | |||||||
| @ -165,7 +165,7 @@ async fn init<T: Topology + Send + Sync + 'static>( | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #[cfg(test)] | #[cfg(test)] | ||||||
| mod test { | mod tests { | ||||||
|     use harmony::{ |     use harmony::{ | ||||||
|         inventory::Inventory, |         inventory::Inventory, | ||||||
|         maestro::Maestro, |         maestro::Maestro, | ||||||
|  | |||||||
| @ -23,12 +23,21 @@ static HARMONY_COMPOSER_EVENT_BUS: Lazy<broadcast::Sender<HarmonyComposerEvent>> | |||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
| pub fn instrument(event: HarmonyComposerEvent) -> Result<(), &'static str> { | pub fn instrument(event: HarmonyComposerEvent) -> Result<(), &'static str> { | ||||||
|  |     #[cfg(not(test))] | ||||||
|  |     { | ||||||
|         match HARMONY_COMPOSER_EVENT_BUS.send(event) { |         match HARMONY_COMPOSER_EVENT_BUS.send(event) { | ||||||
|             Ok(_) => Ok(()), |             Ok(_) => Ok(()), | ||||||
|             Err(_) => Err("send error: no subscribers"), |             Err(_) => Err("send error: no subscribers"), | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     #[cfg(test)] | ||||||
|  |     { | ||||||
|  |         let _ = event; // Suppress the "unused variable" warning for `event`
 | ||||||
|  |         Ok(()) | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| pub async fn subscribe<F, Fut>(name: &str, mut handler: F) | pub async fn subscribe<F, Fut>(name: &str, mut handler: F) | ||||||
| where | where | ||||||
|     F: FnMut(HarmonyComposerEvent) -> Fut + Send + 'static, |     F: FnMut(HarmonyComposerEvent) -> Fut + Send + 'static, | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user