mirror of
https://github.com/getzola/zola
synced 2024-12-14 06:12:27 +00:00
afc30543cc
Closes #385
233 lines
6.5 KiB
Rust
233 lines
6.5 KiB
Rust
extern crate fs_extra;
|
|
extern crate rebuild;
|
|
extern crate site;
|
|
extern crate tempfile;
|
|
|
|
use std::env;
|
|
use std::fs::{self, File};
|
|
use std::io::prelude::*;
|
|
|
|
use fs_extra::dir;
|
|
use site::Site;
|
|
use tempfile::tempdir;
|
|
|
|
use rebuild::{after_content_change, after_content_rename};
|
|
|
|
// Loads the test_site in a tempdir and build it there
|
|
// Returns (site_path_in_tempdir, site)
|
|
macro_rules! load_and_build_site {
|
|
($tmp_dir: expr) => {{
|
|
let mut path =
|
|
env::current_dir().unwrap().parent().unwrap().parent().unwrap().to_path_buf();
|
|
path.push("test_site");
|
|
let mut options = dir::CopyOptions::new();
|
|
options.copy_inside = true;
|
|
dir::copy(&path, &$tmp_dir, &options).unwrap();
|
|
|
|
let site_path = $tmp_dir.path().join("test_site");
|
|
let mut site = Site::new(&site_path, "config.toml").unwrap();
|
|
site.load().unwrap();
|
|
let public = &site_path.join("public");
|
|
site.set_output_path(&public);
|
|
site.build().unwrap();
|
|
|
|
(site_path, site)
|
|
}};
|
|
}
|
|
|
|
/// Replace the file at the path (starting from root) by the given content
|
|
/// and return the file path that was modified
|
|
macro_rules! edit_file {
|
|
($site_path: expr, $path: expr, $content: expr) => {{
|
|
let mut t = $site_path.clone();
|
|
for c in $path.split('/') {
|
|
t.push(c);
|
|
}
|
|
let mut file = File::create(&t).expect("Could not open/create file");
|
|
file.write_all($content).expect("Could not write to the file");
|
|
t
|
|
}};
|
|
}
|
|
|
|
macro_rules! file_contains {
|
|
($site_path: expr, $path: expr, $text: expr) => {{
|
|
let mut path = $site_path.clone();
|
|
for component in $path.split("/") {
|
|
path.push(component);
|
|
}
|
|
let mut file = File::open(&path).unwrap();
|
|
let mut s = String::new();
|
|
file.read_to_string(&mut s).unwrap();
|
|
println!("{:?} -> {}", path, s);
|
|
s.contains($text)
|
|
}};
|
|
}
|
|
|
|
/// Rename a file or a folder to the new given name
|
|
macro_rules! rename {
|
|
($site_path: expr, $path: expr, $new_name: expr) => {{
|
|
let mut t = $site_path.clone();
|
|
for c in $path.split('/') {
|
|
t.push(c);
|
|
}
|
|
let mut new_path = t.parent().unwrap().to_path_buf();
|
|
new_path.push($new_name);
|
|
fs::rename(&t, &new_path).unwrap();
|
|
println!("Renamed {:?} to {:?}", t, new_path);
|
|
(t, new_path)
|
|
}};
|
|
}
|
|
|
|
|
|
#[test]
|
|
fn can_rebuild_after_simple_change_to_page_content() {
|
|
let tmp_dir = tempdir().expect("create temp dir");
|
|
let (site_path, mut site) = load_and_build_site!(tmp_dir);
|
|
let file_path = edit_file!(
|
|
site_path,
|
|
"content/rebuild/first.md",
|
|
br#"
|
|
+++
|
|
title = "first"
|
|
weight = 1
|
|
date = 2017-01-01
|
|
+++
|
|
|
|
Some content"#
|
|
);
|
|
|
|
let res = after_content_change(&mut site, &file_path);
|
|
assert!(res.is_ok());
|
|
assert!(file_contains!(site_path, "public/rebuild/first/index.html", "<p>Some content</p>"));
|
|
}
|
|
|
|
#[test]
|
|
fn can_rebuild_after_title_change_page_global_func_usage() {
|
|
let tmp_dir = tempdir().expect("create temp dir");
|
|
let (site_path, mut site) = load_and_build_site!(tmp_dir);
|
|
let file_path = edit_file!(
|
|
site_path,
|
|
"content/rebuild/first.md",
|
|
br#"
|
|
+++
|
|
title = "Premier"
|
|
weight = 10
|
|
date = 2017-01-01
|
|
+++
|
|
|
|
# A title"#
|
|
);
|
|
|
|
let res = after_content_change(&mut site, &file_path);
|
|
assert!(res.is_ok());
|
|
assert!(file_contains!(site_path, "public/rebuild/index.html", "<h1>Premier</h1>"));
|
|
}
|
|
|
|
#[test]
|
|
fn can_rebuild_after_sort_change_in_section() {
|
|
let tmp_dir = tempdir().expect("create temp dir");
|
|
let (site_path, mut site) = load_and_build_site!(tmp_dir);
|
|
let file_path = edit_file!(
|
|
site_path,
|
|
"content/rebuild/_index.md",
|
|
br#"
|
|
+++
|
|
paginate_by = 1
|
|
sort_by = "weight"
|
|
template = "rebuild.html"
|
|
+++
|
|
"#
|
|
);
|
|
|
|
let res = after_content_change(&mut site, &file_path);
|
|
assert!(res.is_ok());
|
|
assert!(file_contains!(
|
|
site_path,
|
|
"public/rebuild/index.html",
|
|
"<h1>first</h1><h1>second</h1>"
|
|
));
|
|
}
|
|
|
|
#[test]
|
|
fn can_rebuild_after_transparent_change() {
|
|
let tmp_dir = tempdir().expect("create temp dir");
|
|
let (site_path, mut site) = load_and_build_site!(tmp_dir);
|
|
let file_path = edit_file!(
|
|
site_path,
|
|
"content/posts/2018/_index.md",
|
|
br#"
|
|
+++
|
|
transparent = false
|
|
render = false
|
|
+++
|
|
"#
|
|
);
|
|
// Also remove pagination from posts section so we check whether the transparent page title
|
|
// is there or not without dealing with pagination
|
|
edit_file!(
|
|
site_path,
|
|
"content/posts/_index.md",
|
|
br#"
|
|
+++
|
|
template = "section.html"
|
|
insert_anchor_links = "left"
|
|
+++
|
|
"#
|
|
);
|
|
|
|
let res = after_content_change(&mut site, &file_path);
|
|
assert!(res.is_ok());
|
|
assert!(!file_contains!(
|
|
site_path,
|
|
"public/posts/index.html",
|
|
"A transparent page"
|
|
));
|
|
}
|
|
|
|
#[test]
|
|
fn can_rebuild_after_renaming_page() {
|
|
let tmp_dir = tempdir().expect("create temp dir");
|
|
let (site_path, mut site) = load_and_build_site!(tmp_dir);
|
|
let (old_path, new_path) = rename!(site_path, "content/posts/simple.md", "hard.md");
|
|
|
|
let res = after_content_rename(&mut site, &old_path, &new_path);
|
|
println!("{:?}", res);
|
|
assert!(res.is_ok());
|
|
assert!(file_contains!(
|
|
site_path,
|
|
"public/posts/hard/index.html",
|
|
"A simple page"
|
|
));
|
|
}
|
|
|
|
// https://github.com/Keats/gutenberg/issues/385
|
|
#[test]
|
|
fn can_rebuild_after_renaming_colocated_asset_folder() {
|
|
let tmp_dir = tempdir().expect("create temp dir");
|
|
let (site_path, mut site) = load_and_build_site!(tmp_dir);
|
|
let (old_path, new_path) = rename!(site_path, "content/posts/with-assets", "with-assets-updated");
|
|
assert!(file_contains!(site_path, "content/posts/with-assets-updated/index.md", "Hello"));
|
|
|
|
let res = after_content_rename(&mut site, &old_path, &new_path);
|
|
println!("{:?}", res);
|
|
assert!(res.is_ok());
|
|
assert!(file_contains!(
|
|
site_path,
|
|
"public/posts/with-assets-updated/index.html",
|
|
"Hello world"
|
|
));
|
|
}
|
|
|
|
// https://github.com/Keats/gutenberg/issues/385
|
|
#[test]
|
|
fn can_rebuild_after_renaming_section_folder() {
|
|
let tmp_dir = tempdir().expect("create temp dir");
|
|
let (site_path, mut site) = load_and_build_site!(tmp_dir);
|
|
let (old_path, new_path) = rename!(site_path, "content/posts", "new-posts");
|
|
assert!(file_contains!(site_path, "content/new-posts/simple.md", "simple"));
|
|
|
|
let res = after_content_rename(&mut site, &old_path, &new_path);
|
|
assert!(res.is_ok());
|
|
|
|
assert!(file_contains!(site_path, "public/new-posts/simple/index.html", "simple"));
|
|
}
|