use crate::csaf::types::csaf_document_category::CsafDocumentCategory;
use crate::csaf_traits::{CsafTrait, DocumentTrait, VulnerabilityTrait};
use crate::validation::ValidationError;
use crate::validations::utils::document_category_test_config::DocumentCategoryTestConfig;
pub fn test_6_1_27_08_vulnerability_id(doc: &impl CsafTrait) -> Result<(), Vec<ValidationError>> {
let doc_category = doc.get_document().get_category();
if !PROFILE_TEST_CONFIG.matches_category(&doc_category) {
return Ok(()); }
let mut errors: Option<Vec<ValidationError>> = None;
for (v_i, vulnerability) in doc.get_vulnerabilities().iter().enumerate() {
if vulnerability.get_cve().is_none() && vulnerability.get_ids().is_none() {
errors
.get_or_insert_default()
.push(test_6_1_27_08_err_generator(&doc_category, &v_i));
}
}
errors.map_or(Ok(()), Err)
}
const PROFILE_TEST_CONFIG: DocumentCategoryTestConfig =
DocumentCategoryTestConfig::new().shared(&[CsafDocumentCategory::CsafVex]);
fn test_6_1_27_08_err_generator(document_category: &CsafDocumentCategory, vuln_path_index: &usize) -> ValidationError {
ValidationError {
message: format!(
"Document with category '{document_category}' must provide at least either cve or ids in each vulnerability"
),
instance_path: format!("/vulnerabilities/{vuln_path_index}/product_status"),
}
}
crate::test_validation::impl_validator!(ValidatorForTest6_1_27_8, test_6_1_27_08_vulnerability_id);
#[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_27_08() {
let case_vex_without_cve_or_id = Err(vec![test_6_1_27_08_err_generator(&CsafDocumentCategory::CsafVex, &0)]);
TESTS_2_0
.test_6_1_27_8
.expect(case_vex_without_cve_or_id.clone(), Ok(()));
TESTS_2_1.test_6_1_27_8.expect(case_vex_without_cve_or_id, Ok(()));
}
}