Use insta for testing.

This commit is contained in:
2019-02-06 09:24:42 +01:00
parent 5a1d428c22
commit 8b1cc276d6
10 changed files with 714 additions and 702 deletions

View File

@@ -48,7 +48,7 @@ impl Probe for Eniro {
format!("https://gulasidorna.eniro.se/hitta:{}", number)
}
fn search(&mut self, ctx: &mut Context, number: &str) -> Result<(), ()> {
fn search(&mut self, ctx: &mut Context, number: &str) -> Result<Entry, ()> {
let body = if let Some(cache) = ctx.cache_get("eniro", &number) {
String::from_utf8(cache.data).unwrap()
} else {
@@ -60,21 +60,13 @@ impl Probe for Eniro {
body
};
match from_html(&body) {
Ok(entry) => {
println!("eniro.se:");
print!("{}", entry);
Ok(())
}
Err(_) => Err(()),
}
from_html(&body)
}
}
#[cfg(test)]
mod tests {
use pretty_assertions::assert_eq;
use insta::assert_yaml_snapshot_matches;
use super::*;
@@ -82,93 +74,76 @@ mod tests {
fn test_0104754350() {
let document = include_str!("../../fixtures/eniro/0104754350.html");
let expected = Entry {
messages: vec![
"Företaget bedriver telefonförsäljning eller marknadsundersökningar"
.to_string(),
],
history: vec![],
comments: vec![],
};
assert_eq!(from_html(&document), Ok(expected));
assert_yaml_snapshot_matches!(from_html(&document), @r###"Ok:
messages:
- Företaget bedriver telefonförsäljning eller marknadsundersökningar
history: []
comments: []"###);
}
#[test]
fn test_0313908905() {
let document = include_str!("../../fixtures/eniro/0313908905.html");
let expected = Entry {
messages: vec![],
history: vec!["3464 denna vecka och 6637 totalt.".to_string()],
comments: vec![],
};
assert_eq!(from_html(&document), Ok(expected));
assert_yaml_snapshot_matches!(from_html(&document), @r###"Ok:
messages: []
history:
- 3464 denna vecka och 6637 totalt.
comments: []"###);
}
#[test]
fn test_0702269893() {
let document = include_str!("../../fixtures/eniro/0702269893.html");
let expected = Entry {
messages: vec!["Anonym Kund För Refill".to_string()],
history: vec![],
comments: vec![],
};
assert_eq!(from_html(&document), Ok(expected));
assert_yaml_snapshot_matches!(from_html(&document), @r###"Ok:
messages:
- Anonym Kund För Refill
history: []
comments: []"###);
}
#[test]
fn test_0726443387() {
let document = include_str!("../../fixtures/eniro/0726443387.html");
let expected = Entry {
messages: vec![],
history: vec!["16 denna vecka och 98 totalt.".to_string()],
comments: vec![],
};
assert_eq!(from_html(&document), Ok(expected));
assert_yaml_snapshot_matches!(from_html(&document), @r###"Ok:
messages: []
history:
- 16 denna vecka och 98 totalt.
comments: []"###);
}
#[test]
fn test_0751793426() {
let document = include_str!("../../fixtures/eniro/0751793426.html");
let expected = Entry {
messages: vec![],
history: vec!["20 denna vecka och 602 totalt.".to_string()],
comments: vec![],
};
assert_eq!(from_html(&document), Ok(expected));
assert_yaml_snapshot_matches!(from_html(&document), @r###"Ok:
messages: []
history:
- 20 denna vecka och 602 totalt.
comments: []"###);
}
#[test]
fn test_0751793483() {
let document = include_str!("../../fixtures/eniro/0751793483.html");
let expected = Entry {
messages: vec![],
history: vec!["29 denna vecka och 900 totalt.".to_string()],
comments: vec![],
};
assert_eq!(from_html(&document), Ok(expected));
assert_yaml_snapshot_matches!(from_html(&document), @r###"Ok:
messages: []
history:
- 29 denna vecka och 900 totalt.
comments: []"###);
}
#[test]
fn test_0751793499() {
let document = include_str!("../../fixtures/eniro/0751793499.html");
let expected = Entry {
messages: vec![],
history: vec!["303 denna vecka och 304 totalt.".to_string()],
comments: vec![],
};
assert_eq!(from_html(&document), Ok(expected));
assert_yaml_snapshot_matches!(from_html(&document), @r###"Ok:
messages: []
history:
- 303 denna vecka och 304 totalt.
comments: []"###);
}
}