You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

site.rs 11KB

7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289
  1. extern crate gutenberg;
  2. extern crate tempdir;
  3. extern crate glob;
  4. use std::env;
  5. use std::path::Path;
  6. use std::fs::File;
  7. use std::io::prelude::*;
  8. use tempdir::TempDir;
  9. use gutenberg::{Site};
  10. #[test]
  11. fn test_can_parse_site() {
  12. let mut path = env::current_dir().unwrap().to_path_buf();
  13. path.push("test_site");
  14. let mut site = Site::new(&path, "config.toml").unwrap();
  15. site.load().unwrap();
  16. // Correct number of pages (sections are pages too)
  17. assert_eq!(site.pages.len(), 10);
  18. let posts_path = path.join("content").join("posts");
  19. // We have an index page
  20. assert!(site.index.is_some());
  21. // Make sure we remove all the pwd + content from the sections
  22. let basic = &site.pages[&posts_path.join("simple.md")];
  23. assert_eq!(basic.components, vec!["posts".to_string()]);
  24. // Make sure the page with a url doesn't have any sections
  25. let url_post = &site.pages[&posts_path.join("fixed-url.md")];
  26. assert_eq!(url_post.path, "a-fixed-url");
  27. // Make sure the article in a folder with only asset doesn't get counted as a section
  28. let asset_folder_post = &site.pages[&posts_path.join("with-assets").join("index.md")];
  29. assert_eq!(asset_folder_post.components, vec!["posts".to_string()]);
  30. // That we have the right number of sections
  31. assert_eq!(site.sections.len(), 4);
  32. // And that the sections are correct
  33. let posts_section = &site.sections[&posts_path];
  34. assert_eq!(posts_section.subsections.len(), 1);
  35. //println!("{:#?}", posts_section.pages);
  36. assert_eq!(posts_section.pages.len(), 4);
  37. let tutorials_section = &site.sections[&posts_path.join("tutorials")];
  38. assert_eq!(tutorials_section.subsections.len(), 2);
  39. assert_eq!(tutorials_section.pages.len(), 0);
  40. let devops_section = &site.sections[&posts_path.join("tutorials").join("devops")];
  41. assert_eq!(devops_section.subsections.len(), 0);
  42. assert_eq!(devops_section.pages.len(), 2);
  43. let prog_section = &site.sections[&posts_path.join("tutorials").join("programming")];
  44. assert_eq!(prog_section.subsections.len(), 0);
  45. assert_eq!(prog_section.pages.len(), 2);
  46. }
  47. // 2 helper macros to make all the build testing more bearable
  48. macro_rules! file_exists {
  49. ($root: expr, $path: expr) => {
  50. {
  51. let mut path = $root.clone();
  52. for component in $path.split("/") {
  53. path = path.join(component);
  54. }
  55. Path::new(&path).exists()
  56. }
  57. }
  58. }
  59. macro_rules! file_contains {
  60. ($root: expr, $path: expr, $text: expr) => {
  61. {
  62. let mut path = $root.clone();
  63. for component in $path.split("/") {
  64. path = path.join(component);
  65. }
  66. let mut file = File::open(&path).unwrap();
  67. let mut s = String::new();
  68. file.read_to_string(&mut s).unwrap();
  69. s.contains($text)
  70. }
  71. }
  72. }
  73. #[test]
  74. fn test_can_build_site_without_live_reload() {
  75. let mut path = env::current_dir().unwrap().to_path_buf();
  76. path.push("test_site");
  77. let mut site = Site::new(&path, "config.toml").unwrap();
  78. site.load().unwrap();
  79. let tmp_dir = TempDir::new("example").expect("create temp dir");
  80. let public = &tmp_dir.path().join("public");
  81. site.set_output_path(&public);
  82. site.build().unwrap();
  83. assert!(Path::new(&public).exists());
  84. assert!(file_exists!(public, "index.html"));
  85. assert!(file_exists!(public, "sitemap.xml"));
  86. assert!(file_exists!(public, "robots.txt"));
  87. assert!(file_exists!(public, "a-fixed-url/index.html"));
  88. assert!(file_exists!(public, "posts/python/index.html"));
  89. assert!(file_exists!(public, "posts/tutorials/devops/nix/index.html"));
  90. assert!(file_exists!(public, "posts/with-assets/index.html"));
  91. // Sections
  92. assert!(file_exists!(public, "posts/index.html"));
  93. assert!(file_exists!(public, "posts/tutorials/index.html"));
  94. assert!(file_exists!(public, "posts/tutorials/devops/index.html"));
  95. assert!(file_exists!(public, "posts/tutorials/programming/index.html"));
  96. // TODO: add assertion for syntax highlighting
  97. // No tags or categories
  98. assert_eq!(file_exists!(public, "categories/index.html"), false);
  99. assert_eq!(file_exists!(public, "tags/index.html"), false);
  100. // no live reload code
  101. assert_eq!(file_contains!(public, "index.html", "/livereload.js?port=1112&mindelay=10"), false);
  102. // Both pages and sections are in the sitemap
  103. assert!(file_contains!(public, "sitemap.xml", "<loc>https://replace-this-with-your-url.com/posts/simple</loc>"));
  104. assert!(file_contains!(public, "sitemap.xml", "<loc>https://replace-this-with-your-url.com/posts</loc>"));
  105. assert!(file_contains!(public, "a-fixed-url/index.html", "Previous article: "));
  106. assert!(file_contains!(public, "a-fixed-url/index.html", "Next article: "));
  107. }
  108. #[test]
  109. fn test_can_build_site_with_live_reload() {
  110. let mut path = env::current_dir().unwrap().to_path_buf();
  111. path.push("test_site");
  112. let mut site = Site::new(&path, "config.toml").unwrap();
  113. site.load().unwrap();
  114. let tmp_dir = TempDir::new("example").expect("create temp dir");
  115. let public = &tmp_dir.path().join("public");
  116. site.set_output_path(&public);
  117. site.enable_live_reload();
  118. site.build().unwrap();
  119. assert!(Path::new(&public).exists());
  120. assert!(file_exists!(public, "index.html"));
  121. assert!(file_exists!(public, "sitemap.xml"));
  122. assert!(file_exists!(public, "robots.txt"));
  123. assert!(file_exists!(public, "a-fixed-url/index.html"));
  124. assert!(file_exists!(public, "posts/python/index.html"));
  125. assert!(file_exists!(public, "posts/tutorials/devops/nix/index.html"));
  126. assert!(file_exists!(public, "posts/with-assets/index.html"));
  127. // Sections
  128. assert!(file_exists!(public, "posts/index.html"));
  129. assert!(file_exists!(public, "posts/tutorials/index.html"));
  130. assert!(file_exists!(public, "posts/tutorials/devops/index.html"));
  131. assert!(file_exists!(public, "posts/tutorials/programming/index.html"));
  132. // TODO: add assertion for syntax highlighting
  133. // No tags or categories
  134. assert_eq!(file_exists!(public, "categories/index.html"), false);
  135. assert_eq!(file_exists!(public, "tags/index.html"), false);
  136. // no live reload code
  137. assert!(file_contains!(public, "index.html", "/livereload.js?port=1112&mindelay=10"));
  138. }
  139. #[test]
  140. fn test_can_build_site_with_categories() {
  141. let mut path = env::current_dir().unwrap().to_path_buf();
  142. path.push("test_site");
  143. let mut site = Site::new(&path, "config.toml").unwrap();
  144. site.load().unwrap();
  145. for (i, page) in site.pages.values_mut().enumerate() {
  146. page.meta.category = if i % 2 == 0 {
  147. Some("A".to_string())
  148. } else {
  149. Some("B".to_string())
  150. };
  151. }
  152. site.populate_tags_and_categories();
  153. let tmp_dir = TempDir::new("example").expect("create temp dir");
  154. let public = &tmp_dir.path().join("public");
  155. site.set_output_path(&public);
  156. site.build().unwrap();
  157. assert!(Path::new(&public).exists());
  158. assert_eq!(site.categories.len(), 2);
  159. assert!(file_exists!(public, "index.html"));
  160. assert!(file_exists!(public, "sitemap.xml"));
  161. assert!(file_exists!(public, "robots.txt"));
  162. assert!(file_exists!(public, "a-fixed-url/index.html"));
  163. assert!(file_exists!(public, "posts/python/index.html"));
  164. assert!(file_exists!(public, "posts/tutorials/devops/nix/index.html"));
  165. assert!(file_exists!(public, "posts/with-assets/index.html"));
  166. // Sections
  167. assert!(file_exists!(public, "posts/index.html"));
  168. assert!(file_exists!(public, "posts/tutorials/index.html"));
  169. assert!(file_exists!(public, "posts/tutorials/devops/index.html"));
  170. assert!(file_exists!(public, "posts/tutorials/programming/index.html"));
  171. // TODO: add assertion for syntax highlighting
  172. // Categories are there
  173. assert!(file_exists!(public, "categories/index.html"));
  174. assert!(file_exists!(public, "categories/a/index.html"));
  175. assert!(file_exists!(public, "categories/b/index.html"));
  176. // Tags aren't
  177. assert_eq!(file_exists!(public, "tags/index.html"), false);
  178. // Categories are in the sitemap
  179. assert!(file_contains!(public, "sitemap.xml", "<loc>https://replace-this-with-your-url.com/categories</loc>"));
  180. assert!(file_contains!(public, "sitemap.xml", "<loc>https://replace-this-with-your-url.com/categories/a</loc>"));
  181. }
  182. #[test]
  183. fn test_can_build_site_with_tags() {
  184. let mut path = env::current_dir().unwrap().to_path_buf();
  185. path.push("test_site");
  186. let mut site = Site::new(&path, "config.toml").unwrap();
  187. site.load().unwrap();
  188. for (i, page) in site.pages.values_mut().enumerate() {
  189. page.meta.tags = if i % 2 == 0 {
  190. Some(vec!["tag1".to_string(), "tag2".to_string()])
  191. } else {
  192. Some(vec!["tag with space".to_string()])
  193. };
  194. }
  195. site.populate_tags_and_categories();
  196. let tmp_dir = TempDir::new("example").expect("create temp dir");
  197. let public = &tmp_dir.path().join("public");
  198. site.set_output_path(&public);
  199. site.build().unwrap();
  200. assert!(Path::new(&public).exists());
  201. assert_eq!(site.tags.len(), 3);
  202. assert!(file_exists!(public, "index.html"));
  203. assert!(file_exists!(public, "sitemap.xml"));
  204. assert!(file_exists!(public, "robots.txt"));
  205. assert!(file_exists!(public, "a-fixed-url/index.html"));
  206. assert!(file_exists!(public, "posts/python/index.html"));
  207. assert!(file_exists!(public, "posts/tutorials/devops/nix/index.html"));
  208. assert!(file_exists!(public, "posts/with-assets/index.html"));
  209. // Sections
  210. assert!(file_exists!(public, "posts/index.html"));
  211. assert!(file_exists!(public, "posts/tutorials/index.html"));
  212. assert!(file_exists!(public, "posts/tutorials/devops/index.html"));
  213. assert!(file_exists!(public, "posts/tutorials/programming/index.html"));
  214. // TODO: add assertion for syntax highlighting
  215. // Tags are there
  216. assert!(file_exists!(public, "tags/index.html"));
  217. assert!(file_exists!(public, "tags/tag1/index.html"));
  218. assert!(file_exists!(public, "tags/tag2/index.html"));
  219. assert!(file_exists!(public, "tags/tag-with-space/index.html"));
  220. // Categories aren't
  221. assert_eq!(file_exists!(public, "categories/index.html"), false);
  222. // Tags are in the sitemap
  223. assert!(file_contains!(public, "sitemap.xml", "<loc>https://replace-this-with-your-url.com/tags</loc>"));
  224. assert!(file_contains!(public, "sitemap.xml", "<loc>https://replace-this-with-your-url.com/tags/tag-with-space</loc>"));
  225. }
  226. #[test]
  227. fn test_can_build_site_and_insert_anchor_links() {
  228. let mut path = env::current_dir().unwrap().to_path_buf();
  229. path.push("test_site");
  230. let mut site = Site::new(&path, "config.toml").unwrap();
  231. site.config.insert_anchor_links = Some(true);
  232. site.load().unwrap();
  233. let tmp_dir = TempDir::new("example").expect("create temp dir");
  234. let public = &tmp_dir.path().join("public");
  235. site.set_output_path(&public);
  236. site.build().unwrap();
  237. assert!(Path::new(&public).exists());
  238. // anchor link inserted
  239. assert!(file_contains!(public, "posts/something-else/index.html", "<h1 id=\"title\"><a class=\"anchor\" href=\"#title\""));
  240. }