aboutsummaryrefslogtreecommitdiffstats
path: root/tests/serve_request.rs
diff options
context:
space:
mode:
authorSven-Hendrik Haase <svenstaro@gmail.com>2021-03-20 22:31:38 +0000
committerGitHub <noreply@github.com>2021-03-20 22:31:38 +0000
commit9da7de7fffcb68c1c600efbee2ccb14e2f5df7b6 (patch)
treee196f4f9b87df39800569d08af57ab6c9bc79939 /tests/serve_request.rs
parentBump deps (diff)
parentAdd negative test for hidden directories (diff)
downloadminiserve-9da7de7fffcb68c1c600efbee2ccb14e2f5df7b6.tar.gz
miniserve-9da7de7fffcb68c1c600efbee2ccb14e2f5df7b6.zip
Merge pull request #471 from svenstaro/show-hidden
Show hidden
Diffstat (limited to 'tests/serve_request.rs')
-rw-r--r--tests/serve_request.rs79
1 files changed, 78 insertions, 1 deletions
diff --git a/tests/serve_request.rs b/tests/serve_request.rs
index 032e084..95449f5 100644
--- a/tests/serve_request.rs
+++ b/tests/serve_request.rs
@@ -2,7 +2,8 @@ mod fixtures;
use assert_cmd::prelude::*;
use assert_fs::fixture::TempDir;
-use fixtures::{port, tmpdir, Error, DIRECTORIES, FILES};
+use fixtures::{port, tmpdir, Error, DIRECTORIES, FILES, HIDDEN_DIRECTORIES, HIDDEN_FILES};
+use http::StatusCode;
use regex::Regex;
use rstest::rstest;
use select::document::Document;
@@ -77,6 +78,82 @@ fn serves_requests_with_non_default_port(tmpdir: TempDir, port: u16) -> Result<(
}
#[rstest]
+fn serves_requests_hidden_files(tmpdir: TempDir, port: u16) -> Result<(), Error> {
+ let mut child = Command::cargo_bin("miniserve")?
+ .arg(tmpdir.path())
+ .arg("-p")
+ .arg(port.to_string())
+ .arg("--hidden")
+ .stdout(Stdio::null())
+ .spawn()?;
+
+ sleep(Duration::from_secs(1));
+
+ let body = reqwest::blocking::get(format!("http://localhost:{}", port).as_str())?
+ .error_for_status()?;
+ let parsed = Document::from_read(body)?;
+
+ for &file in FILES.into_iter().chain(HIDDEN_FILES) {
+ let f = parsed.find(|x: &Node| x.text() == file).next().unwrap();
+ assert_eq!(
+ format!("/{}", file),
+ percent_encoding::percent_decode_str(f.attr("href").unwrap()).decode_utf8_lossy(),
+ );
+ }
+
+ for &directory in DIRECTORIES.into_iter().chain(HIDDEN_DIRECTORIES) {
+ assert!(parsed
+ .find(|x: &Node| x.text() == directory)
+ .next()
+ .is_some());
+ let dir_body =
+ reqwest::blocking::get(format!("http://localhost:{}/{}", port, directory).as_str())?
+ .error_for_status()?;
+ let dir_body_parsed = Document::from_read(dir_body)?;
+ for &file in FILES.into_iter().chain(HIDDEN_FILES) {
+ assert!(dir_body_parsed
+ .find(|x: &Node| x.text() == file)
+ .next()
+ .is_some());
+ }
+ }
+
+ child.kill()?;
+
+ Ok(())
+}
+
+#[rstest]
+fn serves_requests_no_hidden_files_without_flag(tmpdir: TempDir, port: u16) -> Result<(), Error> {
+ let mut child = Command::cargo_bin("miniserve")?
+ .arg(tmpdir.path())
+ .arg("-p")
+ .arg(port.to_string())
+ .stdout(Stdio::null())
+ .spawn()?;
+
+ sleep(Duration::from_secs(1));
+
+ let body = reqwest::blocking::get(format!("http://localhost:{}", port).as_str())?
+ .error_for_status()?;
+ let parsed = Document::from_read(body)?;
+
+ for &hidden_item in HIDDEN_FILES.into_iter().chain(HIDDEN_DIRECTORIES) {
+ assert!(parsed
+ .find(|x: &Node| x.text() == hidden_item)
+ .next()
+ .is_none());
+ let resp =
+ reqwest::blocking::get(format!("http://localhost:{}/{}", port, hidden_item).as_str())?;
+ assert_eq!(resp.status(), StatusCode::BAD_REQUEST);
+ }
+
+ child.kill()?;
+
+ Ok(())
+}
+
+#[rstest]
fn serves_requests_with_randomly_assigned_port(tmpdir: TempDir) -> Result<(), Error> {
let mut child = Command::cargo_bin("miniserve")?
.arg(tmpdir.path())