aboutsummaryrefslogtreecommitdiffstats
path: root/tests/readme.rs
diff options
context:
space:
mode:
authorGaurav <allmanpride@gmail.com>2022-09-02 22:45:44 +0000
committerGaurav <allmanpride@gmail.com>2022-09-02 22:47:27 +0000
commit6c9c49316f9bb21365166385045dc4bd9d90678b (patch)
tree62e17509edccc0bdf59779b36aa72c4756c9bb1c /tests/readme.rs
parentAdd test for README.md file for `--readme` (diff)
downloadminiserve-6c9c49316f9bb21365166385045dc4bd9d90678b.tar.gz
miniserve-6c9c49316f9bb21365166385045dc4bd9d90678b.zip
Test for different README.md in all directories.
Diffstat (limited to 'tests/readme.rs')
-rw-r--r--tests/readme.rs86
1 files changed, 41 insertions, 45 deletions
diff --git a/tests/readme.rs b/tests/readme.rs
index 5287963..530a2a1 100644
--- a/tests/readme.rs
+++ b/tests/readme.rs
@@ -4,7 +4,7 @@ use fixtures::{server, Error, TestServer, DIRECTORIES, FILES};
use rstest::rstest;
use select::predicate::Attr;
use select::{document::Document, node::Node};
-use std::fs::{create_dir_all, File};
+use std::fs::{remove_file, File};
use std::io::Write;
#[rstest]
@@ -26,60 +26,56 @@ fn no_readme_contents(server: TestServer) -> Result<(), Error> {
}
#[rstest(
- makedir,
- dir,
- content,
- case(false, "", "Test Hello Yes"),
- case(false, "/dira/", "This is dira/readme.md"),
- case(false, "/dirb/", "This is dirb/readme.md"),
- case(true, "/readme-dira/", "This is readme-dira/README.md")
+ readme_name,
+ case("Readme.md"),
+ case("readme.md"),
+ case("README.md"),
+ case("README.MD"),
+ case("ReAdMe.Md")
)]
/// Show readme contents when told to if there is readme.md/README.md file
fn show_readme_contents(
#[with(&["--readme"])] server: TestServer,
- makedir: bool,
- dir: &str,
- content: &str,
+ readme_name: &str,
) -> Result<(), Error> {
- if makedir {
- let tempdir = server.path().join(dir.strip_prefix("/").unwrap());
- create_dir_all(tempdir.clone()).unwrap();
- let mut readme_file = File::create(tempdir.join("README.md"))?;
+ for dir in DIRECTORIES {
+ let readme_path = server.path().join(dir).join(readme_name);
+ let mut readme_file = File::create(&readme_path)?;
readme_file
- .write(content.to_string().as_bytes())
- .expect("Couldn't write README.md");
- }
-
- let body = reqwest::blocking::get(server.url().join(dir)?)?.error_for_status()?;
- let parsed = Document::from_read(body)?;
+ .write(
+ format!("Contents of {}", readme_name)
+ .to_string()
+ .as_bytes(),
+ )
+ .expect("Couldn't write readme");
+ let body = reqwest::blocking::get(server.url().join(dir)?)?.error_for_status()?;
+ let parsed = Document::from_read(body)?;
- if !makedir {
for &file in FILES {
assert!(parsed.find(|x: &Node| x.text() == file).next().is_some());
}
- }
-
- assert!(parsed.find(Attr("id", "readme")).next().is_some());
- assert!(parsed.find(Attr("id", "readme-filename")).next().is_some());
- assert!(
- parsed
- .find(Attr("id", "readme-filename"))
- .next()
- .unwrap()
- .text()
- .to_lowercase()
- == "readme.md"
- );
- assert!(parsed.find(Attr("id", "readme-contents")).next().is_some());
- assert!(
- parsed
- .find(Attr("id", "readme-contents"))
- .next()
- .unwrap()
- .text()
- .trim()
- == content
- );
+ assert!(parsed.find(Attr("id", "readme")).next().is_some());
+ assert!(parsed.find(Attr("id", "readme-filename")).next().is_some());
+ assert!(
+ parsed
+ .find(Attr("id", "readme-filename"))
+ .next()
+ .unwrap()
+ .text()
+ == readme_name
+ );
+ assert!(parsed.find(Attr("id", "readme-contents")).next().is_some());
+ assert!(
+ parsed
+ .find(Attr("id", "readme-contents"))
+ .next()
+ .unwrap()
+ .text()
+ .trim()
+ == format!("Contents of {}", readme_name)
+ );
+ remove_file(readme_path).unwrap();
+ }
Ok(())
}