use crate::checker::Checker;
use crate::diagnostic::{Diagnostic, Severity};
use crate::po::entry::Entry;
use crate::rules::rule::RuleChecker;
pub struct EncodingRule;
impl RuleChecker for EncodingRule {
fn name(&self) -> &'static str {
"encoding"
}
fn is_default(&self) -> bool {
true
}
fn is_check(&self) -> bool {
true
}
fn severity(&self) -> Severity {
Severity::Info
}
fn check_entry(&self, checker: &Checker, entry: &Entry) -> Vec<Diagnostic> {
if entry.encoding_error {
vec![
self.new_diag(
checker,
format!(
"invalid characters for encoding {}",
checker.encoding_name()
),
)
.with_entry(entry),
]
} else {
vec![]
}
}
}
#[cfg(test)]
mod tests {
use super::*;
use crate::{diagnostic::Diagnostic, rules::rule::Rules};
fn check_encoding(content: &str) -> Vec<Diagnostic> {
let mut checker = Checker::new(content.as_bytes());
let rules = Rules::new(vec![Box::new(EncodingRule {})]);
checker.do_all_checks(&rules);
checker.diagnostics
}
#[test]
fn test_encoding_ok() {
let diags = check_encoding(
r#"
msgid "tested"
msgstr "testé"
"#,
);
assert!(diags.is_empty());
}
#[test]
fn test_encoding_error_noqa() {
let mut checker =
Checker::new(b"#, noqa:encoding\nmsgid \"tested\"\nmsgstr \"test\xe9\"\n");
let rules = Rules::new(vec![Box::new(EncodingRule {})]);
checker.do_all_checks(&rules);
let diags = checker.diagnostics;
assert!(diags.is_empty());
}
#[test]
fn test_encoding_error() {
let mut checker = Checker::new(b"msgid \"tested\"\nmsgstr \"test\xe9\"\n");
let rules = Rules::new(vec![Box::new(EncodingRule {})]);
checker.do_all_checks(&rules);
let diags = checker.diagnostics;
assert_eq!(diags.len(), 1);
let diag = &diags[0];
assert_eq!(diag.severity, Severity::Info);
assert_eq!(diag.message, "invalid characters for encoding UTF-8");
}
}