decon-spf 0.3.3

This is a simple tool that allows you to deconstruct an existing SPF record that might be retreived in a normal DNS TXT lookup. With version 0.2.0 you can now also construct a new Spf record.
Documentation
use crate::spf::mechanism::Mechanism;

#[test]
fn basic_ptr() {
    let input = "ptr";

    let m: Mechanism<String> = input.parse().unwrap();
    assert_eq!(m.kind().is_ptr(), true);
    assert_eq!(m.is_pass(), true);
    assert_eq!(m.raw(), "ptr");
    assert_eq!(m.to_string(), input);
}
#[test]
fn ptr_with_slash_error() {
    let input = "ptr:test.com/";

    let m = input.parse::<Mechanism<String>>().unwrap_err();
    assert_eq!(
        m.to_string(),
        "ptr:test.com/ does not conform to any Mechanism format"
    );
}
#[test]
fn ptr_with_colon_only_error() {
    let input = "ptr:";

    let m = input.parse::<Mechanism<String>>().unwrap_err();
    assert_eq!(
        m.to_string(),
        "ptr: does not conform to any Mechanism format"
    );
}
#[test]
fn with_pass() {
    let input = "+ptr";

    let m: Mechanism<String> = input.parse().unwrap();
    assert_eq!(m.kind().is_ptr(), true);
    assert_eq!(m.raw(), "ptr");
    assert_eq!(m.to_string(), "ptr");
}
#[test]
fn neutral_rrdata() {
    let input = "~ptr:example.com";

    let m: Mechanism<String> = input.parse().unwrap();
    assert_eq!(m.raw(), "example.com");
    assert_eq!(m.to_string(), input);
}
#[test]
fn default_rrdata() {
    let input = "ptr:example.com";

    let m: Mechanism<String> = input.parse().unwrap();
    assert_eq!(m.raw(), "example.com");
    assert_eq!(m.to_string(), input);
}