2020-02-14 05:46:08 +01:00
|
|
|
use assert_cmd::prelude::*;
|
2020-03-08 20:31:42 +01:00
|
|
|
use std::env;
|
2020-03-29 09:54:20 +02:00
|
|
|
use std::io::Write;
|
2020-02-14 05:46:08 +01:00
|
|
|
use std::process::Command;
|
2020-03-29 09:54:20 +02:00
|
|
|
use tempfile::NamedTempFile;
|
2020-02-14 05:46:08 +01:00
|
|
|
|
2020-03-23 03:08:41 +01:00
|
|
|
// ██████╗ █████╗ ███████╗███████╗██╗███╗ ██╗ ██████╗
|
|
|
|
// ██╔══██╗██╔══██╗██╔════╝██╔════╝██║████╗ ██║██╔════╝
|
|
|
|
// ██████╔╝███████║███████╗███████╗██║██╔██╗ ██║██║ ███╗
|
|
|
|
// ██╔═══╝ ██╔══██║╚════██║╚════██║██║██║╚██╗██║██║ ██║
|
|
|
|
// ██║ ██║ ██║███████║███████║██║██║ ╚████║╚██████╔╝
|
|
|
|
// ╚═╝ ╚═╝ ╚═╝╚══════╝╚══════╝╚═╝╚═╝ ╚═══╝ ╚═════╝
|
|
|
|
|
2020-02-14 05:46:08 +01:00
|
|
|
#[test]
|
2020-03-23 03:08:41 +01:00
|
|
|
fn passing_print_version() -> Result<(), Box<dyn std::error::Error>> {
|
2020-02-14 05:46:08 +01:00
|
|
|
let mut cmd = Command::cargo_bin(env!("CARGO_PKG_NAME"))?;
|
|
|
|
let out = cmd.arg("-V").output().unwrap();
|
|
|
|
|
|
|
|
// STDOUT should contain program name and version
|
|
|
|
assert_eq!(
|
|
|
|
std::str::from_utf8(&out.stdout).unwrap(),
|
|
|
|
format!("{} {}\n", env!("CARGO_PKG_NAME"), env!("CARGO_PKG_VERSION"))
|
|
|
|
);
|
|
|
|
|
|
|
|
// STDERR should be empty
|
|
|
|
assert_eq!(std::str::from_utf8(&out.stderr).unwrap(), "");
|
|
|
|
|
|
|
|
// The exit code should be 0
|
|
|
|
out.assert().code(0);
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2020-03-23 03:08:41 +01:00
|
|
|
fn passing_bad_input_empty_target() -> Result<(), Box<dyn std::error::Error>> {
|
2020-02-14 05:46:08 +01:00
|
|
|
let mut cmd = Command::cargo_bin(env!("CARGO_PKG_NAME"))?;
|
2020-03-08 20:31:42 +01:00
|
|
|
let out = cmd.arg("").output().unwrap();
|
2020-02-14 05:46:08 +01:00
|
|
|
|
|
|
|
// STDOUT should be empty
|
|
|
|
assert_eq!(std::str::from_utf8(&out.stdout).unwrap(), "");
|
|
|
|
|
|
|
|
// STDERR should contain error description
|
|
|
|
assert_eq!(
|
|
|
|
std::str::from_utf8(&out.stderr).unwrap(),
|
2020-03-08 20:31:42 +01:00
|
|
|
"No target specified\n"
|
2020-02-14 05:46:08 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
// The exit code should be 1
|
|
|
|
out.assert().code(1);
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2020-03-23 03:08:41 +01:00
|
|
|
fn passing_bad_input_data_url() -> Result<(), Box<dyn std::error::Error>> {
|
2020-02-14 05:46:08 +01:00
|
|
|
let mut cmd = Command::cargo_bin(env!("CARGO_PKG_NAME"))?;
|
|
|
|
let out = cmd.arg("data:,Hello%2C%20World!").output().unwrap();
|
|
|
|
|
|
|
|
// STDOUT should contain HTML
|
|
|
|
assert_eq!(std::str::from_utf8(&out.stdout).unwrap(), "");
|
|
|
|
|
|
|
|
// STDERR should contain error description
|
|
|
|
assert_eq!(
|
|
|
|
std::str::from_utf8(&out.stderr).unwrap(),
|
2020-04-10 11:06:07 +02:00
|
|
|
"Unsupported data URL media type\n"
|
2020-02-14 05:46:08 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
// The exit code should be 1
|
|
|
|
out.assert().code(1);
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2020-03-23 03:08:41 +01:00
|
|
|
fn passing_isolate_data_url() -> Result<(), Box<dyn std::error::Error>> {
|
2020-02-14 05:46:08 +01:00
|
|
|
let mut cmd = Command::cargo_bin(env!("CARGO_PKG_NAME"))?;
|
|
|
|
let out = cmd
|
2020-04-26 02:59:34 +02:00
|
|
|
.arg("-M")
|
2020-02-14 05:46:08 +01:00
|
|
|
.arg("-I")
|
|
|
|
.arg("data:text/html,Hello%2C%20World!")
|
|
|
|
.output()
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
// STDOUT should contain isolated HTML
|
|
|
|
assert_eq!(
|
|
|
|
std::str::from_utf8(&out.stdout).unwrap(),
|
2020-03-08 20:31:42 +01:00
|
|
|
"<html><head>\
|
|
|
|
<meta http-equiv=\"Content-Security-Policy\" content=\"default-src 'unsafe-inline' data:;\"></meta>\
|
|
|
|
</head><body>Hello, World!</body></html>\n"
|
2020-02-14 05:46:08 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
// STDERR should be empty
|
|
|
|
assert_eq!(std::str::from_utf8(&out.stderr).unwrap(), "");
|
|
|
|
|
|
|
|
// The exit code should be 0
|
|
|
|
out.assert().code(0);
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2020-03-23 03:08:41 +01:00
|
|
|
fn passing_remove_css_from_data_url() -> Result<(), Box<dyn std::error::Error>> {
|
2020-02-14 05:46:08 +01:00
|
|
|
let mut cmd = Command::cargo_bin(env!("CARGO_PKG_NAME"))?;
|
|
|
|
let out = cmd
|
2020-04-26 02:59:34 +02:00
|
|
|
.arg("-M")
|
2020-02-14 05:46:08 +01:00
|
|
|
.arg("-c")
|
|
|
|
.arg("data:text/html,<style>body{background-color:pink}</style>Hello")
|
|
|
|
.output()
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
// STDOUT should contain HTML with no CSS
|
|
|
|
assert_eq!(
|
|
|
|
std::str::from_utf8(&out.stdout).unwrap(),
|
2020-03-08 20:31:42 +01:00
|
|
|
"<html><head>\
|
|
|
|
<meta http-equiv=\"Content-Security-Policy\" content=\"style-src 'none';\"></meta>\
|
|
|
|
<style></style>\
|
|
|
|
</head><body>Hello</body></html>\n"
|
2020-02-14 05:46:08 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
// STDERR should be empty
|
|
|
|
assert_eq!(std::str::from_utf8(&out.stderr).unwrap(), "");
|
|
|
|
|
|
|
|
// The exit code should be 0
|
|
|
|
out.assert().code(0);
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2020-03-23 03:08:41 +01:00
|
|
|
fn passing_remove_frames_from_data_url() -> Result<(), Box<dyn std::error::Error>> {
|
2020-02-14 05:46:08 +01:00
|
|
|
let mut cmd = Command::cargo_bin(env!("CARGO_PKG_NAME"))?;
|
|
|
|
let out = cmd
|
2020-04-26 02:59:34 +02:00
|
|
|
.arg("-M")
|
2020-02-14 05:46:08 +01:00
|
|
|
.arg("-f")
|
|
|
|
.arg("data:text/html,<iframe src=\"https://google.com\"></iframe>Hi")
|
|
|
|
.output()
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
// STDOUT should contain HTML with no iframes
|
|
|
|
assert_eq!(
|
|
|
|
std::str::from_utf8(&out.stdout).unwrap(),
|
2020-03-08 20:31:42 +01:00
|
|
|
"<html><head>\
|
|
|
|
<meta http-equiv=\"Content-Security-Policy\" content=\"frame-src 'none';child-src 'none';\"></meta>\
|
|
|
|
</head><body><iframe src=\"\"></iframe>Hi</body></html>\n"
|
2020-02-14 05:46:08 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
// STDERR should be empty
|
|
|
|
assert_eq!(std::str::from_utf8(&out.stderr).unwrap(), "");
|
|
|
|
|
|
|
|
// The exit code should be 0
|
|
|
|
out.assert().code(0);
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2020-03-23 03:08:41 +01:00
|
|
|
fn passing_remove_images_from_data_url() -> Result<(), Box<dyn std::error::Error>> {
|
2020-02-14 05:46:08 +01:00
|
|
|
let mut cmd = Command::cargo_bin(env!("CARGO_PKG_NAME"))?;
|
|
|
|
let out = cmd
|
2020-04-26 02:59:34 +02:00
|
|
|
.arg("-M")
|
2020-02-14 05:46:08 +01:00
|
|
|
.arg("-i")
|
|
|
|
.arg("data:text/html,<img src=\"https://google.com\"/>Hi")
|
|
|
|
.output()
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
// STDOUT should contain HTML with no images
|
|
|
|
assert_eq!(
|
|
|
|
std::str::from_utf8(&out.stdout).unwrap(),
|
2020-04-03 09:30:52 +02:00
|
|
|
format!(
|
|
|
|
"<html>\
|
2020-03-08 20:31:42 +01:00
|
|
|
<head>\
|
|
|
|
<meta http-equiv=\"Content-Security-Policy\" content=\"img-src data:;\"></meta>\
|
|
|
|
</head>\
|
|
|
|
<body>\
|
2020-04-03 09:30:52 +02:00
|
|
|
<img src=\"{empty_image}\">\
|
2020-03-08 20:31:42 +01:00
|
|
|
Hi\
|
|
|
|
</body>\
|
2020-04-03 09:30:52 +02:00
|
|
|
</html>\n",
|
|
|
|
empty_image = empty_image!()
|
|
|
|
)
|
2020-02-14 05:46:08 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
// STDERR should be empty
|
|
|
|
assert_eq!(std::str::from_utf8(&out.stderr).unwrap(), "");
|
|
|
|
|
|
|
|
// The exit code should be 0
|
|
|
|
out.assert().code(0);
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2020-03-23 03:08:41 +01:00
|
|
|
fn passing_remove_js_from_data_url() -> Result<(), Box<dyn std::error::Error>> {
|
2020-02-14 05:46:08 +01:00
|
|
|
let mut cmd = Command::cargo_bin(env!("CARGO_PKG_NAME"))?;
|
|
|
|
let out = cmd
|
2020-04-26 02:59:34 +02:00
|
|
|
.arg("-M")
|
2020-02-14 05:46:08 +01:00
|
|
|
.arg("-j")
|
|
|
|
.arg("data:text/html,<script>alert(2)</script>Hi")
|
|
|
|
.output()
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
// STDOUT should contain HTML with no JS
|
|
|
|
assert_eq!(
|
|
|
|
std::str::from_utf8(&out.stdout).unwrap(),
|
2020-03-08 20:31:42 +01:00
|
|
|
"<html>\
|
|
|
|
<head>\
|
|
|
|
<meta http-equiv=\"Content-Security-Policy\" content=\"script-src 'none';\"></meta>\
|
|
|
|
<script></script></head>\
|
|
|
|
<body>Hi</body>\
|
|
|
|
</html>\n"
|
|
|
|
);
|
|
|
|
|
|
|
|
// STDERR should be empty
|
|
|
|
assert_eq!(std::str::from_utf8(&out.stderr).unwrap(), "");
|
|
|
|
|
|
|
|
// The exit code should be 0
|
|
|
|
out.assert().code(0);
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2020-03-23 03:08:41 +01:00
|
|
|
fn passing_local_file_target_input() -> Result<(), Box<dyn std::error::Error>> {
|
2020-03-08 20:31:42 +01:00
|
|
|
let mut cmd = Command::cargo_bin(env!("CARGO_PKG_NAME"))?;
|
|
|
|
let cwd_normalized: String =
|
|
|
|
str!(env::current_dir().unwrap().to_str().unwrap()).replace("\\", "/");
|
|
|
|
let out = cmd
|
2020-04-26 02:59:34 +02:00
|
|
|
.arg("-M")
|
2020-03-08 20:31:42 +01:00
|
|
|
.arg(if cfg!(windows) {
|
2020-05-17 19:54:07 +02:00
|
|
|
"src\\tests\\data\\basic\\local-file.html"
|
2020-03-08 20:31:42 +01:00
|
|
|
} else {
|
2020-05-17 19:54:07 +02:00
|
|
|
"src/tests/data/basic/local-file.html"
|
2020-03-08 20:31:42 +01:00
|
|
|
})
|
|
|
|
.output()
|
|
|
|
.unwrap();
|
|
|
|
let file_url_protocol: &str = if cfg!(windows) { "file:///" } else { "file://" };
|
|
|
|
|
|
|
|
// STDOUT should contain HTML from the local file
|
|
|
|
assert_eq!(
|
|
|
|
std::str::from_utf8(&out.stdout).unwrap(),
|
2020-04-03 09:30:52 +02:00
|
|
|
"\
|
|
|
|
<!DOCTYPE html><html lang=\"en\"><head>\n \
|
2020-03-08 20:31:42 +01:00
|
|
|
<meta http-equiv=\"Content-Type\" content=\"text/html; charset=utf-8\">\n \
|
|
|
|
<title>Local HTML file</title>\n \
|
2020-05-02 12:13:28 +02:00
|
|
|
<link rel=\"stylesheet\" type=\"text/css\" href=\"data:text/css;base64,Ym9keSB7CiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAjMDAwOwogICAgY29sb3I6ICNmZmY7Cn0K\">\n \
|
|
|
|
<link rel=\"stylesheet\" type=\"text/css\">\n</head>\n\n<body>\n \
|
|
|
|
<img alt=\"\">\n \
|
2020-03-08 20:31:42 +01:00
|
|
|
<a href=\"file://local-file.html/\">Tricky href</a>\n \
|
|
|
|
<a href=\"https://github.com/Y2Z/monolith\">Remote URL</a>\n \
|
|
|
|
<script src=\"data:application/javascript;base64,ZG9jdW1lbnQuYm9keS5zdHlsZS5iYWNrZ3JvdW5kQ29sb3IgPSAiZ3JlZW4iOwpkb2N1bWVudC5ib2R5LnN0eWxlLmNvbG9yID0gInJlZCI7Cg==\"></script>\n\n\n\n\
|
2020-04-03 09:30:52 +02:00
|
|
|
</body></html>\n\
|
|
|
|
"
|
2020-03-08 20:31:42 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
// STDERR should contain list of retrieved file URLs
|
|
|
|
assert_eq!(
|
|
|
|
std::str::from_utf8(&out.stderr).unwrap(),
|
|
|
|
format!(
|
2020-04-03 09:30:52 +02:00
|
|
|
"\
|
2020-05-17 19:54:07 +02:00
|
|
|
{file}{cwd}/src/tests/data/basic/local-file.html\n\
|
|
|
|
{file}{cwd}/src/tests/data/basic/local-style.css\n\
|
|
|
|
{file}{cwd}/src/tests/data/basic/local-script.js\n\
|
2020-04-03 09:30:52 +02:00
|
|
|
",
|
2020-03-08 20:31:42 +01:00
|
|
|
file = file_url_protocol,
|
|
|
|
cwd = cwd_normalized
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
// The exit code should be 0
|
|
|
|
out.assert().code(0);
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2020-03-23 03:08:41 +01:00
|
|
|
fn passing_local_file_target_input_absolute_target_path() -> Result<(), Box<dyn std::error::Error>>
|
|
|
|
{
|
2020-03-08 20:31:42 +01:00
|
|
|
let cwd = env::current_dir().unwrap();
|
|
|
|
let cwd_normalized: String =
|
|
|
|
str!(env::current_dir().unwrap().to_str().unwrap()).replace("\\", "/");
|
|
|
|
let mut cmd = Command::cargo_bin(env!("CARGO_PKG_NAME"))?;
|
|
|
|
let out = cmd
|
2020-04-26 02:59:34 +02:00
|
|
|
.arg("-M")
|
2020-03-08 20:31:42 +01:00
|
|
|
.arg("-jciI")
|
|
|
|
.arg(if cfg!(windows) {
|
|
|
|
format!(
|
2020-05-17 19:54:07 +02:00
|
|
|
"{cwd}\\src\\tests\\data\\basic\\local-file.html",
|
2020-03-08 20:31:42 +01:00
|
|
|
cwd = cwd.to_str().unwrap()
|
|
|
|
)
|
|
|
|
} else {
|
|
|
|
format!(
|
2020-05-17 19:54:07 +02:00
|
|
|
"{cwd}/src/tests/data/basic/local-file.html",
|
2020-03-08 20:31:42 +01:00
|
|
|
cwd = cwd.to_str().unwrap()
|
|
|
|
)
|
|
|
|
})
|
|
|
|
.output()
|
|
|
|
.unwrap();
|
|
|
|
let file_url_protocol: &str = if cfg!(windows) { "file:///" } else { "file://" };
|
|
|
|
|
|
|
|
// STDOUT should contain HTML from the local file
|
|
|
|
assert_eq!(
|
|
|
|
std::str::from_utf8(&out.stdout).unwrap(),
|
2020-04-03 09:30:52 +02:00
|
|
|
format!(
|
|
|
|
"\
|
|
|
|
<!DOCTYPE html><html lang=\"en\"><head>\
|
2020-03-08 20:31:42 +01:00
|
|
|
<meta http-equiv=\"Content-Security-Policy\" content=\"default-src 'unsafe-inline' data:; style-src 'none'; script-src 'none'; img-src data:;\"></meta>\n \
|
|
|
|
<meta http-equiv=\"Content-Type\" content=\"text/html; charset=utf-8\">\n \
|
|
|
|
<title>Local HTML file</title>\n \
|
2020-05-02 12:13:28 +02:00
|
|
|
<link rel=\"stylesheet\" type=\"text/css\">\n \
|
|
|
|
<link rel=\"stylesheet\" type=\"text/css\">\n</head>\n\n<body>\n \
|
2020-04-03 09:30:52 +02:00
|
|
|
<img alt=\"\" src=\"{empty_image}\">\n \
|
2020-03-08 20:31:42 +01:00
|
|
|
<a href=\"file://local-file.html/\">Tricky href</a>\n \
|
|
|
|
<a href=\"https://github.com/Y2Z/monolith\">Remote URL</a>\n \
|
2020-05-02 12:13:28 +02:00
|
|
|
<script></script>\n\n\n\n\
|
2020-04-03 09:30:52 +02:00
|
|
|
</body></html>\n\
|
|
|
|
",
|
|
|
|
empty_image = empty_image!()
|
|
|
|
)
|
2020-03-08 20:31:42 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
// STDERR should contain only the target file
|
|
|
|
assert_eq!(
|
|
|
|
std::str::from_utf8(&out.stderr).unwrap(),
|
|
|
|
format!(
|
2020-05-17 19:54:07 +02:00
|
|
|
"{file}{cwd}/src/tests/data/basic/local-file.html\n",
|
2020-03-08 20:31:42 +01:00
|
|
|
file = file_url_protocol,
|
|
|
|
cwd = cwd_normalized,
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
// The exit code should be 0
|
|
|
|
out.assert().code(0);
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2020-03-23 03:08:41 +01:00
|
|
|
fn passing_local_file_url_target_input() -> Result<(), Box<dyn std::error::Error>> {
|
2020-03-08 20:31:42 +01:00
|
|
|
let mut cmd = Command::cargo_bin(env!("CARGO_PKG_NAME"))?;
|
2020-03-29 09:54:20 +02:00
|
|
|
let cwd_normalized: String =
|
|
|
|
str!(env::current_dir().unwrap().to_str().unwrap()).replace("\\", "/");
|
2020-03-08 20:31:42 +01:00
|
|
|
let file_url_protocol: &str = if cfg!(windows) { "file:///" } else { "file://" };
|
|
|
|
let out = cmd
|
2020-04-26 02:59:34 +02:00
|
|
|
.arg("-M")
|
2020-03-08 20:31:42 +01:00
|
|
|
.arg("-cji")
|
|
|
|
.arg(if cfg!(windows) {
|
|
|
|
format!(
|
2020-05-17 19:54:07 +02:00
|
|
|
"{file}{cwd}/src/tests/data/basic/local-file.html",
|
2020-03-08 20:31:42 +01:00
|
|
|
file = file_url_protocol,
|
2020-03-29 09:54:20 +02:00
|
|
|
cwd = cwd_normalized,
|
2020-03-08 20:31:42 +01:00
|
|
|
)
|
|
|
|
} else {
|
|
|
|
format!(
|
2020-05-17 19:54:07 +02:00
|
|
|
"{file}{cwd}/src/tests/data/basic/local-file.html",
|
2020-03-08 20:31:42 +01:00
|
|
|
file = file_url_protocol,
|
2020-03-29 09:54:20 +02:00
|
|
|
cwd = cwd_normalized,
|
2020-03-08 20:31:42 +01:00
|
|
|
)
|
|
|
|
})
|
|
|
|
.output()
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
// STDOUT should contain HTML from the local file
|
|
|
|
assert_eq!(
|
|
|
|
std::str::from_utf8(&out.stdout).unwrap(),
|
2020-04-03 09:30:52 +02:00
|
|
|
format!(
|
|
|
|
"\
|
|
|
|
<!DOCTYPE html><html lang=\"en\"><head>\
|
2020-03-08 20:31:42 +01:00
|
|
|
<meta http-equiv=\"Content-Security-Policy\" content=\"style-src 'none'; script-src 'none'; img-src data:;\"></meta>\n \
|
|
|
|
<meta http-equiv=\"Content-Type\" content=\"text/html; charset=utf-8\">\n \
|
|
|
|
<title>Local HTML file</title>\n \
|
2020-05-02 12:13:28 +02:00
|
|
|
<link rel=\"stylesheet\" type=\"text/css\">\n \
|
|
|
|
<link rel=\"stylesheet\" type=\"text/css\">\n</head>\n\n<body>\n \
|
2020-04-03 09:30:52 +02:00
|
|
|
<img alt=\"\" src=\"{empty_image}\">\n \
|
2020-03-08 20:31:42 +01:00
|
|
|
<a href=\"file://local-file.html/\">Tricky href</a>\n \
|
|
|
|
<a href=\"https://github.com/Y2Z/monolith\">Remote URL</a>\n \
|
2020-05-02 12:13:28 +02:00
|
|
|
<script></script>\n\n\n\n\
|
2020-04-03 09:30:52 +02:00
|
|
|
</body></html>\n\
|
|
|
|
",
|
|
|
|
empty_image = empty_image!()
|
|
|
|
)
|
2020-03-08 20:31:42 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
// STDERR should contain list of retrieved file URLs
|
|
|
|
assert_eq!(
|
|
|
|
std::str::from_utf8(&out.stderr).unwrap(),
|
|
|
|
if cfg!(windows) {
|
|
|
|
format!(
|
2020-05-17 19:54:07 +02:00
|
|
|
"{file}{cwd}/src/tests/data/basic/local-file.html\n",
|
2020-03-08 20:31:42 +01:00
|
|
|
file = file_url_protocol,
|
2020-03-29 09:54:20 +02:00
|
|
|
cwd = cwd_normalized,
|
2020-03-08 20:31:42 +01:00
|
|
|
)
|
|
|
|
} else {
|
|
|
|
format!(
|
2020-05-17 19:54:07 +02:00
|
|
|
"{file}{cwd}/src/tests/data/basic/local-file.html\n",
|
2020-03-08 20:31:42 +01:00
|
|
|
file = file_url_protocol,
|
2020-03-29 09:54:20 +02:00
|
|
|
cwd = cwd_normalized,
|
2020-03-08 20:31:42 +01:00
|
|
|
)
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
// The exit code should be 0
|
|
|
|
out.assert().code(0);
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2020-03-23 03:08:41 +01:00
|
|
|
fn passing_security_disallow_local_assets_within_data_url_targets(
|
|
|
|
) -> Result<(), Box<dyn std::error::Error>> {
|
2020-03-08 20:31:42 +01:00
|
|
|
let mut cmd = Command::cargo_bin(env!("CARGO_PKG_NAME"))?;
|
|
|
|
let out = cmd
|
2020-04-26 02:59:34 +02:00
|
|
|
.arg("-M")
|
2020-05-17 19:54:07 +02:00
|
|
|
.arg("data:text/html,%3Cscript%20src=\"src/tests/data/basic/local-script.js\"%3E%3C/script%3E")
|
2020-03-08 20:31:42 +01:00
|
|
|
.output()
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
// STDOUT should contain HTML with no JS in it
|
|
|
|
assert_eq!(
|
|
|
|
std::str::from_utf8(&out.stdout).unwrap(),
|
2020-05-02 12:13:28 +02:00
|
|
|
"<html><head><script></script></head><body></body></html>\n"
|
2020-02-14 05:46:08 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
// STDERR should be empty
|
|
|
|
assert_eq!(std::str::from_utf8(&out.stderr).unwrap(), "");
|
|
|
|
|
|
|
|
// The exit code should be 0
|
|
|
|
out.assert().code(0);
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|
2020-03-29 09:54:20 +02:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn passing_embed_file_url_local_asset_within_style_attribute(
|
|
|
|
) -> Result<(), Box<dyn std::error::Error>> {
|
|
|
|
let file_url_prefix: &str = if cfg!(windows) { "file:///" } else { "file://" };
|
|
|
|
let mut cmd = Command::cargo_bin(env!("CARGO_PKG_NAME"))?;
|
|
|
|
let mut file_svg = NamedTempFile::new()?;
|
|
|
|
writeln!(file_svg, "<svg version=\"1.1\" baseProfile=\"full\" width=\"300\" height=\"200\" xmlns=\"http://www.w3.org/2000/svg\">\
|
|
|
|
<rect width=\"100%\" height=\"100%\" fill=\"red\" />\
|
|
|
|
<circle cx=\"150\" cy=\"100\" r=\"80\" fill=\"green\" />\
|
|
|
|
<text x=\"150\" y=\"125\" font-size=\"60\" text-anchor=\"middle\" fill=\"white\">SVG</text>\
|
|
|
|
</svg>\n")?;
|
|
|
|
let mut file_html = NamedTempFile::new()?;
|
|
|
|
writeln!(
|
|
|
|
file_html,
|
|
|
|
"<div style='background-image: url(\"{file}{path}\")'></div>\n",
|
|
|
|
file = file_url_prefix,
|
|
|
|
path = str!(file_svg.path().to_str().unwrap()).replace("\\", "/"),
|
|
|
|
)?;
|
2020-04-26 02:59:34 +02:00
|
|
|
let out = cmd.arg("-M").arg(file_html.path()).output().unwrap();
|
2020-03-29 09:54:20 +02:00
|
|
|
|
|
|
|
// STDOUT should contain HTML with date URL for background-image in it
|
|
|
|
assert_eq!(
|
|
|
|
std::str::from_utf8(&out.stdout).unwrap(),
|
|
|
|
"<html><head></head><body><div style=\"background-image: url('')\"></div>\n\n</body></html>\n"
|
|
|
|
);
|
|
|
|
|
|
|
|
// STDERR should list temporary files that got retrieved
|
|
|
|
assert_eq!(
|
|
|
|
std::str::from_utf8(&out.stderr).unwrap(),
|
|
|
|
format!(
|
|
|
|
"\
|
|
|
|
{file}{html_path}\n\
|
|
|
|
{file}{svg_path}\n\
|
|
|
|
",
|
|
|
|
file = file_url_prefix,
|
|
|
|
html_path = str!(file_html.path().to_str().unwrap()).replace("\\", "/"),
|
|
|
|
svg_path = str!(file_svg.path().to_str().unwrap()).replace("\\", "/"),
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
// The exit code should be 0
|
|
|
|
out.assert().code(0);
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn passing_css_import_string() -> Result<(), Box<dyn std::error::Error>> {
|
|
|
|
let file_url_prefix: &str = if cfg!(windows) { "file:///" } else { "file://" };
|
|
|
|
let mut cmd = Command::cargo_bin(env!("CARGO_PKG_NAME"))?;
|
|
|
|
let mut file_css = NamedTempFile::new()?;
|
|
|
|
writeln!(file_css, "body{{background-color:#000;color:#fff}}")?;
|
|
|
|
let mut file_html = NamedTempFile::new()?;
|
|
|
|
writeln!(
|
|
|
|
file_html,
|
2020-04-03 09:30:52 +02:00
|
|
|
"\
|
|
|
|
<style>\n\
|
2020-03-29 09:54:20 +02:00
|
|
|
@charset 'UTF-8';\n\
|
|
|
|
\n\
|
|
|
|
@import '{file}{css_path}';\n\
|
|
|
|
\n\
|
|
|
|
@import url({file}{css_path});\n\
|
|
|
|
\n\
|
|
|
|
@import url('{file}{css_path}')\n\
|
2020-04-03 09:30:52 +02:00
|
|
|
</style>\n\
|
|
|
|
",
|
2020-03-29 09:54:20 +02:00
|
|
|
file = file_url_prefix,
|
|
|
|
css_path = str!(file_css.path().to_str().unwrap()).replace("\\", "/"),
|
|
|
|
)?;
|
2020-04-26 02:59:34 +02:00
|
|
|
let out = cmd.arg("-M").arg(file_html.path()).output().unwrap();
|
2020-03-29 09:54:20 +02:00
|
|
|
|
|
|
|
// STDOUT should contain embedded CSS url()'s
|
|
|
|
assert_eq!(
|
|
|
|
std::str::from_utf8(&out.stdout).unwrap(),
|
|
|
|
"<html><head><style>\n@charset 'UTF-8';\n\n@import 'data:text/css;base64,Ym9keXtiYWNrZ3JvdW5kLWNvbG9yOiMwMDA7Y29sb3I6I2ZmZn0K';\n\n@import url('data:text/css;base64,Ym9keXtiYWNrZ3JvdW5kLWNvbG9yOiMwMDA7Y29sb3I6I2ZmZn0K');\n\n@import url('data:text/css;base64,Ym9keXtiYWNrZ3JvdW5kLWNvbG9yOiMwMDA7Y29sb3I6I2ZmZn0K')\n</style>\n\n</head><body></body></html>\n"
|
|
|
|
);
|
|
|
|
|
|
|
|
// STDERR should list temporary files that got retrieved
|
|
|
|
assert_eq!(
|
|
|
|
std::str::from_utf8(&out.stderr).unwrap(),
|
|
|
|
format!(
|
|
|
|
"\
|
|
|
|
{file}{html_path}\n\
|
|
|
|
{file}{css_path}\n\
|
|
|
|
{file}{css_path}\n\
|
|
|
|
{file}{css_path}\n\
|
|
|
|
",
|
|
|
|
file = file_url_prefix,
|
|
|
|
html_path = str!(file_html.path().to_str().unwrap()).replace("\\", "/"),
|
|
|
|
css_path = str!(file_css.path().to_str().unwrap()).replace("\\", "/"),
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
// The exit code should be 0
|
|
|
|
out.assert().code(0);
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|