mdBook/tests/tomlconfig.rs

201 lines
6.6 KiB
Rust
Raw Permalink Normal View History

2017-05-19 01:32:08 +08:00
extern crate mdbook;
use mdbook::config::BookConfig;
use mdbook::config::tomlconfig::TomlConfig;
use std::path::PathBuf;
// Tests that the `source` key is correctly parsed in the TOML config
2017-05-19 01:32:08 +08:00
#[test]
fn from_toml_source() {
let toml = r#"source = "source""#;
2017-06-27 15:08:58 +08:00
let parsed = TomlConfig::from_toml(toml).expect("This should parse");
2017-05-19 01:32:08 +08:00
let config = BookConfig::from_tomlconfig("root", parsed);
assert_eq!(config.get_source(), PathBuf::from("root/source"));
}
// Tests that the `title` key is correctly parsed in the TOML config
2017-05-19 01:32:08 +08:00
#[test]
fn from_toml_title() {
let toml = r#"title = "Some title""#;
2017-06-27 15:08:58 +08:00
let parsed = TomlConfig::from_toml(toml).expect("This should parse");
2017-05-19 01:32:08 +08:00
let config = BookConfig::from_tomlconfig("root", parsed);
assert_eq!(config.get_title(), "Some title");
}
// Tests that the `description` key is correctly parsed in the TOML config
2017-05-19 01:32:08 +08:00
#[test]
fn from_toml_description() {
let toml = r#"description = "This is a description""#;
2017-06-27 15:08:58 +08:00
let parsed = TomlConfig::from_toml(toml).expect("This should parse");
2017-05-19 01:32:08 +08:00
let config = BookConfig::from_tomlconfig("root", parsed);
assert_eq!(config.get_description(), "This is a description");
}
// Tests that the `author` key is correctly parsed in the TOML config
2017-05-19 01:32:08 +08:00
#[test]
fn from_toml_author() {
let toml = r#"author = "John Doe""#;
2017-06-27 15:08:58 +08:00
let parsed = TomlConfig::from_toml(toml).expect("This should parse");
2017-05-19 01:32:08 +08:00
let config = BookConfig::from_tomlconfig("root", parsed);
assert_eq!(config.get_authors(), &[String::from("John Doe")]);
}
// Tests that the `authors` key is correctly parsed in the TOML config
2017-05-19 01:32:08 +08:00
#[test]
fn from_toml_authors() {
let toml = r#"authors = ["John Doe", "Jane Doe"]"#;
2017-06-27 15:08:58 +08:00
let parsed = TomlConfig::from_toml(toml).expect("This should parse");
2017-05-19 01:32:08 +08:00
let config = BookConfig::from_tomlconfig("root", parsed);
assert_eq!(config.get_authors(), &[String::from("John Doe"), String::from("Jane Doe")]);
}
2017-06-29 12:35:20 +08:00
// Tests that the default `playpen` config is correct in the TOML config
#[test]
fn from_toml_playpen_default() {
let toml = "";
let parsed = TomlConfig::from_toml(toml).expect("This should parse");
let config = BookConfig::from_tomlconfig("root", parsed);
let playpenconfig = config.get_html_config().get_playpen_config();
assert_eq!(playpenconfig.get_editor(), PathBuf::from("root/theme/editor"));
assert_eq!(playpenconfig.is_editable(), false);
}
// Tests that the `playpen.editor` key is correctly parsed in the TOML config
#[test]
fn from_toml_playpen_editor() {
let toml = r#"[output.html.playpen]
editor = "editordir""#;
let parsed = TomlConfig::from_toml(toml).expect("This should parse");
let config = BookConfig::from_tomlconfig("root", parsed);
let playpenconfig = config.get_html_config().get_playpen_config();
assert_eq!(playpenconfig.get_editor(), PathBuf::from("root/theme/editordir"));
}
// Tests that the `playpen.editable` key is correctly parsed in the TOML config
#[test]
fn from_toml_playpen_editable() {
let toml = r#"[output.html.playpen]
editable = true"#;
let parsed = TomlConfig::from_toml(toml).expect("This should parse");
let config = BookConfig::from_tomlconfig("root", parsed);
let playpenconfig = config.get_html_config().get_playpen_config();
assert_eq!(playpenconfig.is_editable(), true);
}
// Tests that the `output.html.destination` key is correcly parsed in the TOML config
2017-05-19 01:32:08 +08:00
#[test]
fn from_toml_output_html_destination() {
let toml = r#"[output.html]
destination = "htmlbook""#;
2017-06-27 15:08:58 +08:00
let parsed = TomlConfig::from_toml(toml).expect("This should parse");
2017-05-19 01:32:08 +08:00
let config = BookConfig::from_tomlconfig("root", parsed);
let htmlconfig = config.get_html_config();
2017-05-19 01:32:08 +08:00
assert_eq!(htmlconfig.get_destination(), PathBuf::from("root/htmlbook"));
}
// Tests that the `output.html.theme` key is correctly parsed in the TOML config
2017-05-19 01:32:08 +08:00
#[test]
fn from_toml_output_html_theme() {
let toml = r#"[output.html]
theme = "theme""#;
2017-06-27 15:08:58 +08:00
let parsed = TomlConfig::from_toml(toml).expect("This should parse");
2017-05-19 01:32:08 +08:00
let config = BookConfig::from_tomlconfig("root", parsed);
let htmlconfig = config.get_html_config();
2017-05-19 01:32:08 +08:00
assert_eq!(htmlconfig.get_theme(), &PathBuf::from("root/theme"));
}
// Tests that the `output.html.curly-quotes` key is correctly parsed in the TOML config
#[test]
fn from_toml_output_html_curly_quotes() {
let toml = r#"[output.html]
curly-quotes = true"#;
2017-06-27 15:08:58 +08:00
let parsed = TomlConfig::from_toml(toml).expect("This should parse");
let config = BookConfig::from_tomlconfig("root", parsed);
let htmlconfig = config.get_html_config();
assert_eq!(htmlconfig.get_curly_quotes(), true);
}
// Tests that the `output.html.mathjax-support` key is correctly parsed in the TOML config
#[test]
fn from_toml_output_html_mathjax_support() {
let toml = r#"[output.html]
mathjax-support = true"#;
2017-06-27 15:08:58 +08:00
let parsed = TomlConfig::from_toml(toml).expect("This should parse");
let config = BookConfig::from_tomlconfig("root", parsed);
let htmlconfig = config.get_html_config();
assert_eq!(htmlconfig.get_mathjax_support(), true);
}
// Tests that the `output.html.google-analytics` key is correctly parsed in the TOML config
#[test]
fn from_toml_output_html_google_analytics() {
let toml = r#"[output.html]
google-analytics = "123456""#;
2017-06-27 15:08:58 +08:00
let parsed = TomlConfig::from_toml(toml).expect("This should parse");
let config = BookConfig::from_tomlconfig("root", parsed);
let htmlconfig = config.get_html_config();
assert_eq!(htmlconfig.get_google_analytics_id().expect("the google-analytics key was provided"), String::from("123456"));
}
// Tests that the `output.html.additional-css` key is correctly parsed in the TOML config
#[test]
fn from_toml_output_html_additional_stylesheet() {
let toml = r#"[output.html]
additional-css = ["custom.css", "two/custom.css"]"#;
2017-06-27 15:08:58 +08:00
let parsed = TomlConfig::from_toml(toml).expect("This should parse");
let config = BookConfig::from_tomlconfig("root", parsed);
let htmlconfig = config.get_html_config();
assert_eq!(htmlconfig.get_additional_css(), &[PathBuf::from("root/custom.css"), PathBuf::from("root/two/custom.css")]);
2017-06-07 02:34:57 +08:00
}
// Tests that the `output.html.additional-js` key is correctly parsed in the TOML config
2017-06-07 02:34:57 +08:00
#[test]
fn from_toml_output_html_additional_scripts() {
let toml = r#"[output.html]
additional-js = ["custom.js", "two/custom.js"]"#;
2017-06-27 15:08:58 +08:00
let parsed = TomlConfig::from_toml(toml).expect("This should parse");
2017-06-07 02:34:57 +08:00
let config = BookConfig::from_tomlconfig("root", parsed);
let htmlconfig = config.get_html_config();
2017-06-07 02:34:57 +08:00
assert_eq!(htmlconfig.get_additional_js(), &[PathBuf::from("root/custom.js"), PathBuf::from("root/two/custom.js")]);
}