mirror of
https://github.com/denoland/deno.git
synced 2025-01-03 21:08:56 -05:00
382 lines
11 KiB
Rust
382 lines
11 KiB
Rust
// Copyright 2018-2022 the Deno authors. All rights reserved. MIT license.
|
|
|
|
use std::fs;
|
|
use test_util as util;
|
|
use test_util::TempDir;
|
|
|
|
mod coverage {
|
|
use super::*;
|
|
#[test]
|
|
fn branch() {
|
|
run_coverage_text("branch", "ts");
|
|
}
|
|
|
|
#[test]
|
|
fn complex() {
|
|
run_coverage_text("complex", "ts");
|
|
}
|
|
|
|
#[test]
|
|
fn final_blankline() {
|
|
run_coverage_text("final_blankline", "js");
|
|
}
|
|
|
|
#[test]
|
|
fn no_snaps() {
|
|
no_snaps_included("no_snaps_included", "ts");
|
|
}
|
|
|
|
#[test]
|
|
fn error_if_invalid_cache() {
|
|
let deno_dir = TempDir::new();
|
|
let deno_dir_path = deno_dir.path();
|
|
let tempdir = TempDir::new();
|
|
let tempdir = tempdir.path().join("cov");
|
|
|
|
let invalid_cache_path =
|
|
util::testdata_path().join("coverage/invalid_cache");
|
|
let mod_before_path = util::testdata_path()
|
|
.join(&invalid_cache_path)
|
|
.join("mod_before.ts");
|
|
let mod_after_path = util::testdata_path()
|
|
.join(&invalid_cache_path)
|
|
.join("mod_after.ts");
|
|
let mod_test_path = util::testdata_path()
|
|
.join(&invalid_cache_path)
|
|
.join("mod.test.ts");
|
|
|
|
let mod_temp_path = deno_dir_path.join("mod.ts");
|
|
let mod_test_temp_path = deno_dir_path.join("mod.test.ts");
|
|
|
|
// Write the inital mod.ts file
|
|
std::fs::copy(mod_before_path, &mod_temp_path).unwrap();
|
|
// And the test file
|
|
std::fs::copy(mod_test_path, mod_test_temp_path).unwrap();
|
|
|
|
// Generate coverage
|
|
let status = util::deno_cmd_with_deno_dir(&deno_dir)
|
|
.current_dir(deno_dir_path)
|
|
.arg("test")
|
|
.arg("--quiet")
|
|
.arg(format!("--coverage={}", tempdir.to_str().unwrap()))
|
|
.stdout(std::process::Stdio::piped())
|
|
.stderr(std::process::Stdio::inherit())
|
|
.status()
|
|
.unwrap();
|
|
|
|
assert!(status.success());
|
|
|
|
// Modify the file between deno test and deno coverage, thus invalidating the cache
|
|
std::fs::copy(mod_after_path, mod_temp_path).unwrap();
|
|
|
|
let output = util::deno_cmd_with_deno_dir(&deno_dir)
|
|
.current_dir(deno_dir_path)
|
|
.arg("coverage")
|
|
.arg(format!("{}/", tempdir.to_str().unwrap()))
|
|
.stdout(std::process::Stdio::piped())
|
|
.stderr(std::process::Stdio::piped())
|
|
.output()
|
|
.unwrap();
|
|
|
|
assert!(output.stdout.is_empty());
|
|
|
|
// Expect error
|
|
let error =
|
|
util::strip_ansi_codes(std::str::from_utf8(&output.stderr).unwrap())
|
|
.to_string();
|
|
assert!(error.contains("error: Missing transpiled source code"));
|
|
assert!(error.contains("Before generating coverage report, run `deno test --coverage` to ensure consistent state."));
|
|
}
|
|
|
|
fn run_coverage_text(test_name: &str, extension: &str) {
|
|
let deno_dir = TempDir::new();
|
|
let tempdir = TempDir::new();
|
|
let tempdir = tempdir.path().join("cov");
|
|
|
|
let status = util::deno_cmd_with_deno_dir(&deno_dir)
|
|
.current_dir(util::testdata_path())
|
|
.arg("test")
|
|
.arg("-A")
|
|
.arg("--quiet")
|
|
.arg("--unstable")
|
|
.arg(format!("--coverage={}", tempdir.to_str().unwrap()))
|
|
.arg(format!("coverage/{}_test.{}", test_name, extension))
|
|
.stdout(std::process::Stdio::piped())
|
|
.stderr(std::process::Stdio::inherit())
|
|
.status()
|
|
.unwrap();
|
|
|
|
assert!(status.success());
|
|
|
|
let output = util::deno_cmd_with_deno_dir(&deno_dir)
|
|
.current_dir(util::testdata_path())
|
|
.arg("coverage")
|
|
.arg("--unstable")
|
|
.arg(format!("{}/", tempdir.to_str().unwrap()))
|
|
.stdout(std::process::Stdio::piped())
|
|
.stderr(std::process::Stdio::piped())
|
|
.output()
|
|
.unwrap();
|
|
|
|
// Verify there's no "Check" being printed
|
|
assert!(output.stderr.is_empty());
|
|
|
|
let actual =
|
|
util::strip_ansi_codes(std::str::from_utf8(&output.stdout).unwrap())
|
|
.to_string();
|
|
|
|
let expected = fs::read_to_string(
|
|
util::testdata_path()
|
|
.join(format!("coverage/{}_expected.out", test_name)),
|
|
)
|
|
.unwrap();
|
|
|
|
if !util::wildcard_match(&expected, &actual) {
|
|
println!("OUTPUT\n{}\nOUTPUT", actual);
|
|
println!("EXPECTED\n{}\nEXPECTED", expected);
|
|
panic!("pattern match failed");
|
|
}
|
|
|
|
assert!(output.status.success());
|
|
|
|
let output = util::deno_cmd_with_deno_dir(&deno_dir)
|
|
.current_dir(util::testdata_path())
|
|
.arg("coverage")
|
|
.arg("--quiet")
|
|
.arg("--unstable")
|
|
.arg("--lcov")
|
|
.arg(format!("{}/", tempdir.to_str().unwrap()))
|
|
.stdout(std::process::Stdio::piped())
|
|
.stderr(std::process::Stdio::inherit())
|
|
.output()
|
|
.unwrap();
|
|
|
|
let actual =
|
|
util::strip_ansi_codes(std::str::from_utf8(&output.stdout).unwrap())
|
|
.to_string();
|
|
|
|
let expected = fs::read_to_string(
|
|
util::testdata_path()
|
|
.join(format!("coverage/{}_expected.lcov", test_name)),
|
|
)
|
|
.unwrap();
|
|
|
|
if !util::wildcard_match(&expected, &actual) {
|
|
println!("OUTPUT\n{}\nOUTPUT", actual);
|
|
println!("EXPECTED\n{}\nEXPECTED", expected);
|
|
panic!("pattern match failed");
|
|
}
|
|
|
|
assert!(output.status.success());
|
|
}
|
|
|
|
#[test]
|
|
fn multifile_coverage() {
|
|
let deno_dir = TempDir::new();
|
|
let tempdir = TempDir::new();
|
|
let tempdir = tempdir.path().join("cov");
|
|
|
|
let status = util::deno_cmd_with_deno_dir(&deno_dir)
|
|
.current_dir(util::testdata_path())
|
|
.arg("test")
|
|
.arg("--quiet")
|
|
.arg("--unstable")
|
|
.arg(format!("--coverage={}", tempdir.to_str().unwrap()))
|
|
.arg("coverage/multifile/")
|
|
.stdout(std::process::Stdio::piped())
|
|
.stderr(std::process::Stdio::inherit())
|
|
.status()
|
|
.unwrap();
|
|
|
|
assert!(status.success());
|
|
|
|
let output = util::deno_cmd_with_deno_dir(&deno_dir)
|
|
.current_dir(util::testdata_path())
|
|
.arg("coverage")
|
|
.arg("--unstable")
|
|
.arg(format!("{}/", tempdir.to_str().unwrap()))
|
|
.stdout(std::process::Stdio::piped())
|
|
.stderr(std::process::Stdio::piped())
|
|
.output()
|
|
.unwrap();
|
|
|
|
// Verify there's no "Check" being printed
|
|
assert!(output.stderr.is_empty());
|
|
|
|
let actual =
|
|
util::strip_ansi_codes(std::str::from_utf8(&output.stdout).unwrap())
|
|
.to_string();
|
|
|
|
let expected = fs::read_to_string(
|
|
util::testdata_path().join("coverage/multifile/expected.out"),
|
|
)
|
|
.unwrap();
|
|
|
|
if !util::wildcard_match(&expected, &actual) {
|
|
println!("OUTPUT\n{}\nOUTPUT", actual);
|
|
println!("EXPECTED\n{}\nEXPECTED", expected);
|
|
panic!("pattern match failed");
|
|
}
|
|
|
|
assert!(output.status.success());
|
|
|
|
let output = util::deno_cmd_with_deno_dir(&deno_dir)
|
|
.current_dir(util::testdata_path())
|
|
.arg("coverage")
|
|
.arg("--quiet")
|
|
.arg("--unstable")
|
|
.arg("--lcov")
|
|
.arg(format!("{}/", tempdir.to_str().unwrap()))
|
|
.stdout(std::process::Stdio::piped())
|
|
.stderr(std::process::Stdio::inherit())
|
|
.output()
|
|
.unwrap();
|
|
|
|
let actual =
|
|
util::strip_ansi_codes(std::str::from_utf8(&output.stdout).unwrap())
|
|
.to_string();
|
|
|
|
let expected = fs::read_to_string(
|
|
util::testdata_path().join("coverage/multifile/expected.lcov"),
|
|
)
|
|
.unwrap();
|
|
|
|
if !util::wildcard_match(&expected, &actual) {
|
|
println!("OUTPUT\n{}\nOUTPUT", actual);
|
|
println!("EXPECTED\n{}\nEXPECTED", expected);
|
|
panic!("pattern match failed");
|
|
}
|
|
|
|
assert!(output.status.success());
|
|
}
|
|
|
|
fn no_snaps_included(test_name: &str, extension: &str) {
|
|
let deno_dir = TempDir::new();
|
|
let tempdir = TempDir::new();
|
|
let tempdir = tempdir.path().join("cov");
|
|
|
|
let status = util::deno_cmd_with_deno_dir(&deno_dir)
|
|
.current_dir(util::testdata_path())
|
|
.arg("test")
|
|
.arg("--quiet")
|
|
.arg("--unstable")
|
|
.arg("--allow-read")
|
|
.arg(format!("--coverage={}", tempdir.to_str().unwrap()))
|
|
.arg(format!(
|
|
"coverage/no_snaps_included/{}_test.{}",
|
|
test_name, extension
|
|
))
|
|
.stdout(std::process::Stdio::piped())
|
|
.stderr(std::process::Stdio::piped())
|
|
.status()
|
|
.unwrap();
|
|
|
|
assert!(status.success());
|
|
|
|
let output = util::deno_cmd_with_deno_dir(&deno_dir)
|
|
.current_dir(util::testdata_path())
|
|
.arg("coverage")
|
|
.arg("--unstable")
|
|
.arg("--include=no_snaps_included.ts")
|
|
.arg(format!("{}/", tempdir.to_str().unwrap()))
|
|
.stdout(std::process::Stdio::piped())
|
|
.stderr(std::process::Stdio::piped())
|
|
.output()
|
|
.unwrap();
|
|
|
|
// Verify there's no "Check" being printed
|
|
assert!(output.stderr.is_empty());
|
|
|
|
let actual =
|
|
util::strip_ansi_codes(std::str::from_utf8(&output.stdout).unwrap())
|
|
.to_string();
|
|
|
|
let expected = fs::read_to_string(
|
|
util::testdata_path().join("coverage/no_snaps_included/expected.out"),
|
|
)
|
|
.unwrap();
|
|
|
|
if !util::wildcard_match(&expected, &actual) {
|
|
println!("OUTPUT\n{}\nOUTPUT", actual);
|
|
println!("EXPECTED\n{}\nEXPECTED", expected);
|
|
panic!("pattern match failed");
|
|
}
|
|
|
|
assert!(output.status.success());
|
|
}
|
|
|
|
#[test]
|
|
fn no_transpiled_lines() {
|
|
let deno_dir = TempDir::new();
|
|
let tempdir = TempDir::new();
|
|
let tempdir = tempdir.path().join("cov");
|
|
|
|
let status = util::deno_cmd_with_deno_dir(&deno_dir)
|
|
.current_dir(util::testdata_path())
|
|
.arg("test")
|
|
.arg("--quiet")
|
|
.arg(format!("--coverage={}", tempdir.to_str().unwrap()))
|
|
.arg("coverage/no_transpiled_lines/")
|
|
.stdout(std::process::Stdio::piped())
|
|
.stderr(std::process::Stdio::inherit())
|
|
.status()
|
|
.unwrap();
|
|
|
|
assert!(status.success());
|
|
|
|
let output = util::deno_cmd_with_deno_dir(&deno_dir)
|
|
.current_dir(util::testdata_path())
|
|
.arg("coverage")
|
|
.arg("--include=no_transpiled_lines/index.ts")
|
|
.arg(format!("{}/", tempdir.to_str().unwrap()))
|
|
.stdout(std::process::Stdio::piped())
|
|
.stderr(std::process::Stdio::piped())
|
|
.output()
|
|
.unwrap();
|
|
|
|
let actual =
|
|
util::strip_ansi_codes(std::str::from_utf8(&output.stdout).unwrap())
|
|
.to_string();
|
|
|
|
let expected = fs::read_to_string(
|
|
util::testdata_path().join("coverage/no_transpiled_lines/expected.out"),
|
|
)
|
|
.unwrap();
|
|
|
|
if !util::wildcard_match(&expected, &actual) {
|
|
println!("OUTPUT\n{}\nOUTPUT", actual);
|
|
println!("EXPECTED\n{}\nEXPECTED", expected);
|
|
panic!("pattern match failed");
|
|
}
|
|
|
|
assert!(output.status.success());
|
|
|
|
let output = util::deno_cmd_with_deno_dir(&deno_dir)
|
|
.current_dir(util::testdata_path())
|
|
.arg("coverage")
|
|
.arg("--lcov")
|
|
.arg("--include=no_transpiled_lines/index.ts")
|
|
.arg(format!("{}/", tempdir.to_str().unwrap()))
|
|
.stdout(std::process::Stdio::piped())
|
|
.stderr(std::process::Stdio::inherit())
|
|
.output()
|
|
.unwrap();
|
|
|
|
let actual =
|
|
util::strip_ansi_codes(std::str::from_utf8(&output.stdout).unwrap())
|
|
.to_string();
|
|
|
|
let expected = fs::read_to_string(
|
|
util::testdata_path().join("coverage/no_transpiled_lines/expected.lcov"),
|
|
)
|
|
.unwrap();
|
|
|
|
if !util::wildcard_match(&expected, &actual) {
|
|
println!("OUTPUT\n{}\nOUTPUT", actual);
|
|
println!("EXPECTED\n{}\nEXPECTED", expected);
|
|
panic!("pattern match failed");
|
|
}
|
|
|
|
assert!(output.status.success());
|
|
}
|
|
}
|