aboutsummaryrefslogblamecommitdiffstats
path: root/tests/misc_url.rs
blob: a6f8ead66ca65b205cb6a8532511001b05074842 (plain) (tree)























































































































































                                                                                                                                                                                                                                                           
extern crate micromark;
use micromark::micromark;

#[test]
fn url() {
    assert_eq!(
        micromark("<https://%>"),
        "<p><a href=\"https://%25\">https://%</a></p>",
        "should support incorrect percentage encoded values (0)"
    );

    // To do: link.
    // assert_eq!(
    //     micromark("[](<%>)"),
    //     "<p><a href=\"%25\"></a></p>",
    //     "should support incorrect percentage encoded values (1)"
    // );

    // To do: link.
    // assert_eq!(
    //     micromark("[](<%%20>)"),
    //     "<p><a href=\"%25%20\"></a></p>",
    //     "should support incorrect percentage encoded values (2)"
    // );

    // To do: link.
    // assert_eq!(
    //     micromark("[](<%a%20>)"),
    //     "<p><a href=\"%25a%20\"></a></p>",
    //     "should support incorrect percentage encoded values (3)"
    // );

    // Surrogate handling not needed in Rust.
    //   assert_eq!(
    //     micromark("[](<foo\u{D800}bar>)"),
    //     "<p><a href=\"foo%EF%BF%BDbar\"></a></p>",
    //     "should support a lone high surrogate (lowest)"
    //   );

    // Surrogate handling not needed in Rust.
    //   assert_eq!(
    //     micromark("[](<foo\u{DBFF}bar>)"),
    //     "<p><a href=\"foo%EF%BF%BDbar\"></a></p>",
    //     "should support a lone high surrogate (highest)"
    //   );

    // Surrogate handling not needed in Rust.
    //   assert_eq!(
    //     micromark("[](<\u{D800}bar>)"),
    //     "<p><a href=\"%EF%BF%BDbar\"></a></p>",
    //     "should support a lone high surrogate at the start (lowest)"
    //   );

    // Surrogate handling not needed in Rust.
    //   assert_eq!(
    //     micromark("[](<\u{DBFF}bar>)"),
    //     "<p><a href=\"%EF%BF%BDbar\"></a></p>",
    //     "should support a lone high surrogate at the start (highest)"
    //   );

    // Surrogate handling not needed in Rust.
    //   assert_eq!(
    //     micromark("[](<foo\u{D800}>)"),
    //     "<p><a href=\"foo%EF%BF%BD\"></a></p>",
    //     "should support a lone high surrogate at the end (lowest)"
    //   );

    // Surrogate handling not needed in Rust.
    //   assert_eq!(
    //     micromark("[](<foo\u{DBFF}>)"),
    //     "<p><a href=\"foo%EF%BF%BD\"></a></p>",
    //     "should support a lone high surrogate at the end (highest)"
    //   );

    // Surrogate handling not needed in Rust.
    //   assert_eq!(
    //     micromark("[](<foo\u{DC00}bar>)"),
    //     "<p><a href=\"foo%EF%BF%BDbar\"></a></p>",
    //     "should support a lone low surrogate (lowest)"
    //   );

    // Surrogate handling not needed in Rust.
    //   assert_eq!(
    //     micromark("[](<foo\u{DFFF}bar>)"),
    //     "<p><a href=\"foo%EF%BF%BDbar\"></a></p>",
    //     "should support a lone low surrogate (highest)"
    //   );

    // Surrogate handling not needed in Rust.
    //   assert_eq!(
    //     micromark("[](<\u{DC00}bar>)"),
    //     "<p><a href=\"%EF%BF%BDbar\"></a></p>",
    //     "should support a lone low surrogate at the start (lowest)"
    //   );

    // Surrogate handling not needed in Rust.
    //   assert_eq!(
    //     micromark("[](<\u{DFFF}bar>)"),
    //     "<p><a href=\"%EF%BF%BDbar\"></a></p>",
    //     "should support a lone low surrogate at the start (highest)"
    //   );

    // Surrogate handling not needed in Rust.
    //   assert_eq!(
    //     micromark("[](<foo\u{DC00}>)"),
    //     "<p><a href=\"foo%EF%BF%BD\"></a></p>",
    //     "should support a lone low surrogate at the end (lowest)"
    //   );

    // Surrogate handling not needed in Rust.
    //   assert_eq!(
    //     micromark("[](<foo\u{DFFF}>)"),
    //     "<p><a href=\"foo%EF%BF%BD\"></a></p>",
    //     "should support a lone low surrogate at the end (highest)"
    //   );

    // To do: link.
    // assert_eq!(
    //     micromark("[](<🤔>)"),
    //     "<p><a href=\"%F0%9F%A4%94\"></a></p>",
    //     "should support an emoji"
    // );

    // To do: link.
    // let mut ascii: Vec<char> = vec![];
    // let mut code = 0;

    // while code < 128 {
    //     // LF and CR can’t be in resources.
    //     if code == 10 || code == 13 {
    //         code += 1;
    //         continue;
    //     }

    //     // `<`, `>`, `\` need to be escaped.
    //     if code == 60 || code == 62 || code == 92 {
    //         ascii.push('\\');
    //     }

    //     ascii.push(char::from_u32(code).unwrap());

    //     code += 1;
    // }

    // let ascii_in = ascii.into_iter().collect::<String>();
    // let ascii_out = "%EF%BF%BD%01%02%03%04%05%06%07%08%09%0B%0C%0E%0F%10%11%12%13%14%15%16%17%18%19%1A%1B%1C%1D%1E%1F%20!%22#$%25&amp;\"()*+,-./0123456789:;%3C=%3E?@ABCDEFGHIJKLMNOPQRSTUVWXYZ%5B%5C%5D%5E_%60abcdefghijklmnopqrstuvwxyz%7B%7C%7D~%7F";
    // assert_eq!(
    //     micromark(&format!("[](<{}>)", ascii_in)),
    //     format!("<p><a href=\"{}\"></a></p>", ascii_out),
    //     "should support ascii characters"
    // );
}