use crate::csaf::types::language::CsafLanguage;
use crate::csaf_traits::{CsafTrait, DocumentTrait};
use crate::validation::{IntoValidationError, ValidationError};
pub fn test_6_1_12_language(doc: &impl CsafTrait) -> Result<(), Vec<ValidationError>> {
let document = doc.get_document();
if document.get_lang().is_none() && document.get_source_lang().is_none() {
return Ok(()); }
let mut errors: Option<Vec<ValidationError>> = None;
validate_language(document.get_lang(), "/document/lang", &mut errors);
validate_language(document.get_source_lang(), "/document/source_lang", &mut errors);
errors.map_or(Ok(()), Err)
}
fn validate_language(lang: Option<CsafLanguage>, json_path: &str, errors: &mut Option<Vec<ValidationError>>) {
if let Some(CsafLanguage::Invalid(_, err)) = lang {
errors
.get_or_insert_default()
.push(err.into_validation_error(json_path));
}
}
crate::test_validation::impl_validator!(ValidatorForTest6_1_12, test_6_1_12_language);
#[cfg(test)]
mod tests {
use super::*;
use crate::csaf::types::language::CsafLanguage::Invalid;
use crate::csaf2_0::testcases::TESTS_2_0;
use crate::csaf2_1::testcases::TESTS_2_1;
#[test]
fn test_test_6_1_12() {
let Invalid(_, ez_error) = CsafLanguage::from(&"EZ".to_string()) else {
unreachable!()
};
let Invalid(_, zzz_error) = CsafLanguage::from(&"ZZZ".to_string()) else {
unreachable!()
};
let case_01_lang_invalid = Err(vec![ez_error.clone().into_validation_error("/document/lang")]);
let case_s01_source_lang_invalid = Err(vec![ez_error.clone().into_validation_error("/document/source_lang")]);
let case_s02_both_langs_invalid = Err(vec![
ez_error.into_validation_error("/document/lang"),
zzz_error.into_validation_error("/document/source_lang"),
]);
TESTS_2_0.test_6_1_12.expect(
case_01_lang_invalid.clone(),
case_s01_source_lang_invalid.clone(),
case_s02_both_langs_invalid.clone(),
Ok(()),
Ok(()),
Ok(()),
);
TESTS_2_1.test_6_1_12.expect(
case_01_lang_invalid,
case_s01_source_lang_invalid,
case_s02_both_langs_invalid,
Ok(()),
Ok(()),
Ok(()),
);
}
}