aboutsummaryrefslogtreecommitdiffstats
path: root/tests/serve_request.rs
diff options
context:
space:
mode:
authorboastful-squirrel <boastful.squirrel@gmail.com>2019-05-03 05:28:31 +0000
committerboastful-squirrel <boastful.squirrel@gmail.com>2019-05-03 05:28:31 +0000
commit8f1793e02f0dadbab668b51850e14bd160b440d8 (patch)
tree4e125df23c71e092c3f83d0289554df980e0bb2e /tests/serve_request.rs
parentPrint error when parsing query parameters fail (diff)
parentMerge pull request #99 from KSXGitHub/new-clippy (diff)
downloadminiserve-8f1793e02f0dadbab668b51850e14bd160b440d8.tar.gz
miniserve-8f1793e02f0dadbab668b51850e14bd160b440d8.zip
Merge branch 'master' into themed-errors
Diffstat (limited to 'tests/serve_request.rs')
-rw-r--r--tests/serve_request.rs53
1 files changed, 53 insertions, 0 deletions
diff --git a/tests/serve_request.rs b/tests/serve_request.rs
new file mode 100644
index 0000000..ef346b2
--- /dev/null
+++ b/tests/serve_request.rs
@@ -0,0 +1,53 @@
+mod fixtures;
+
+use assert_cmd::prelude::*;
+use assert_fs::fixture::TempDir;
+use fixtures::{port, tmpdir, Error, FILES};
+use rstest::rstest;
+use select::document::Document;
+use select::predicate::Text;
+use std::process::{Command, Stdio};
+use std::thread::sleep;
+use std::time::Duration;
+
+#[rstest]
+fn serves_requests_with_no_options(tmpdir: TempDir) -> Result<(), Error> {
+ let mut child = Command::cargo_bin("miniserve")?
+ .arg(tmpdir.path())
+ .stdout(Stdio::null())
+ .spawn()?;
+
+ sleep(Duration::from_secs(1));
+
+ let body = reqwest::get("http://localhost:8080")?.error_for_status()?;
+ let parsed = Document::from_read(body)?;
+ for &file in FILES {
+ assert!(parsed.find(Text).any(|x| x.text() == file));
+ }
+
+ child.kill()?;
+
+ Ok(())
+}
+
+#[rstest]
+fn serves_requests_with_non_default_port(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::get(format!("http://localhost:{}", port).as_str())?.error_for_status()?;
+ let parsed = Document::from_read(body)?;
+ for &file in FILES {
+ assert!(parsed.find(Text).any(|x| x.text() == file));
+ }
+
+ child.kill()?;
+
+ Ok(())
+}