Removed normalized ProbabilityFile tests

These tests no longer make sense, as multiple different items can now
drop in one roll and the probabilities can't be normalized.

These tests did not fail previously because they only checked one
specific loot table, which hasn't been touched until now.
This commit is contained in:
crabman 2024-03-18 11:49:59 +00:00
parent 78cd928069
commit 016fb0bc9b
No known key found for this signature in database

View File

@ -250,9 +250,12 @@ lazy_static! {
} }
#[derive(Clone)] #[derive(Clone)]
/// A collection of items with probabilty (normalized to one), created /// A collection of items with probabilty, created
/// hierarchically from `LootSpec`s /// hierarchically from `LootSpec`s
/// (probability, item id, average amount) /// (probability, item id, average amount)
///
/// This collection is NOT normalized (the sum of probabilities may not equal to
/// one, as maltiple items can drop in one roll)
pub struct ProbabilityFile { pub struct ProbabilityFile {
pub content: Vec<(f32, ItemDefinitionIdOwned, f32)>, pub content: Vec<(f32, ItemDefinitionIdOwned, f32)>,
} }
@ -1148,11 +1151,7 @@ pub fn expand_loot_table(loot_table: &str) -> Vec<(f32, ItemDefinitionIdOwned, f
// cd common && cargo test trade_pricing -- --nocapture // cd common && cargo test trade_pricing -- --nocapture
#[cfg(test)] #[cfg(test)]
mod tests { mod tests {
use crate::{ use crate::{comp::inventory::trade_pricing::TradePricing, trade::Good};
comp::inventory::trade_pricing::{ProbabilityFile, TradePricing},
lottery::LootSpec,
trade::Good,
};
use tracing::{info, Level}; use tracing::{info, Level};
use tracing_subscriber::{filter::EnvFilter, FmtSubscriber}; use tracing_subscriber::{filter::EnvFilter, FmtSubscriber};
@ -1192,43 +1191,4 @@ mod tests {
info!("Random item {:?}*{}", i.0, i.1); info!("Random item {:?}*{}", i.0, i.1);
} }
} }
fn normalized(probability: &ProbabilityFile) -> bool {
let sum = probability.content.iter().map(|(p, _, _)| p).sum::<f32>();
(dbg!(sum) - 1.0).abs() < 1e-3
}
#[test]
fn test_normalizing_table1() {
let item = |asset: &str| LootSpec::Item(asset.to_owned());
let loot_table = vec![(1.0, item("wow")), (1.0, item("nice"))];
let probability: ProbabilityFile = loot_table.into();
assert!(normalized(&probability));
}
#[test]
fn test_normalizing_table2() {
let table = |asset: &str| LootSpec::LootTable(asset.to_owned());
let loot_table = vec![(
1.0,
table("common.loot_tables.creature.quad_medium.catoblepas"),
)];
let probability: ProbabilityFile = loot_table.into();
assert!(normalized(&probability));
}
#[test]
fn test_normalizing_table3() {
let table = |asset: &str| LootSpec::LootTable(asset.to_owned());
let loot_table = vec![
(
1.0,
table("common.loot_tables.creature.quad_medium.catoblepas"),
),
(1.0, table("common.loot_tables.creature.quad_medium.gentle")),
];
let probability: ProbabilityFile = loot_table.into();
assert!(normalized(&probability));
}
} }