diff options
author | Alex Crichton <alex@alexcrichton.com> | 2017-08-13 16:30:09 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-08-13 16:30:09 -0700 |
commit | be0f6fac0fcd0685e9da0c0afbeb1570fbf3e827 (patch) | |
tree | c40738dd0041bc8a21400a937df2ca66eba1367a /tests | |
parent | 4b3139e2b66896376dd257040014a313db5fcc1e (diff) | |
parent | eaa0c17220dc8ea1f5ed0b6bdb71ecbe32305404 (diff) | |
download | milf-rs-be0f6fac0fcd0685e9da0c0afbeb1570fbf3e827.tar.gz milf-rs-be0f6fac0fcd0685e9da0c0afbeb1570fbf3e827.zip |
Merge pull request #208 from vitiral/no-literal
add pretty_string_literal to be able to disable literal strings
Diffstat (limited to 'tests')
-rw-r--r-- | tests/pretty.rs | 44 |
1 files changed, 43 insertions, 1 deletions
diff --git a/tests/pretty.rs b/tests/pretty.rs index 3a9777c..ce906d9 100644 --- a/tests/pretty.rs +++ b/tests/pretty.rs @@ -198,7 +198,7 @@ text = """ this is the first line. This has a ''' in it and \"\"\" cuz it's tricky yo Also ' and \" because why not -this is the third line +this is the fourth line """ "##; @@ -260,3 +260,45 @@ fn table_array() { println!("\nRESULT:\n{}", result); assert_eq!(toml, &result); } + +// FIXME: add the `glass` line to this. Unfortunately there seems to +// be an issue with the deserialization module that treats the first \n +// as a real newline in that case (not cool) +const PRETTY_TRICKY_NON_LITERAL: &'static str = r##"[example] +f = "\f" +plain = """ +This has a couple of lines +Because it likes to. +""" +r = "\r" +r_newline = """ +\r +""" +single = "this is a single line but has '' cuz it's tricky" +single_tricky = "single line with ''' in it" +tabs = """ +this is pretty standard +\texcept for some \ttabs right here +""" +text = """ +this is the first line. +This has a ''' in it and \"\"\" cuz it's tricky yo +Also ' and \" because why not +this is the fourth line +""" +"##; + +#[test] +fn pretty_tricky_non_literal() { + let toml = PRETTY_TRICKY_NON_LITERAL; + let value: toml::Value = toml::from_str(toml).unwrap(); + let mut result = String::with_capacity(128); + { + let mut serializer = toml::Serializer::pretty(&mut result); + serializer.pretty_string_literal(false); + value.serialize(&mut serializer).unwrap(); + } + println!("EXPECTED:\n{}", toml); + println!("\nRESULT:\n{}", result); + assert_eq!(toml, &result); +} |