use crate::csaf_traits::{CsafTrait, VulnerabilityTrait, WithOptionalGroupIds, WithOptionalProductIds};
use crate::validation::ValidationError;
fn create_flag_without_product_reference_error(vulnerability_index: usize, flag_index: usize) -> ValidationError {
ValidationError {
message: "A flag must have at least of the elements group_ids or product_ids".to_string(),
instance_path: format!("/vulnerabilities/{vulnerability_index}/flags/{flag_index}"),
}
}
pub fn test_6_1_32_flag_without_product_reference(doc: &impl CsafTrait) -> Result<(), Vec<ValidationError>> {
let vulnerabilities = doc.get_vulnerabilities();
if vulnerabilities.is_empty() {
return Ok(());
}
let mut errors: Option<Vec<ValidationError>> = None;
for (vuln_i, vulnerability) in vulnerabilities.iter().enumerate() {
if let Some(flags) = vulnerability.get_flags() {
for (flag_i, flag) in flags.iter().enumerate() {
if flag.get_product_ids().is_none() && flag.get_group_ids().is_none() {
errors
.get_or_insert_default()
.push(create_flag_without_product_reference_error(vuln_i, flag_i));
}
}
}
}
errors.map_or(Ok(()), Err)
}
crate::test_validation::impl_validator!(ValidatorForTest6_1_32, test_6_1_32_flag_without_product_reference);
#[cfg(test)]
mod tests {
use super::*;
use crate::csaf2_0::testcases::TESTS_2_0;
use crate::csaf2_1::testcases::TESTS_2_1;
#[test]
fn test_test_6_1_32() {
let case_01 = Err(vec![create_flag_without_product_reference_error(0, 0)]);
let case_s01 = Err(vec![
create_flag_without_product_reference_error(0, 0),
create_flag_without_product_reference_error(1, 1),
create_flag_without_product_reference_error(2, 1),
]);
TESTS_2_0
.test_6_1_32
.expect(case_01.clone(), case_s01.clone(), Ok(()), Ok(()), Ok(()), Ok(()));
TESTS_2_1
.test_6_1_32
.expect(case_01, case_s01, Ok(()), Ok(()), Ok(()), Ok(()));
}
}