mirror of
https://github.com/denoland/deno.git
synced 2024-11-21 15:04:11 -05:00
fix(coverage): ensure coverage is only collected in certain situations (#15467)
This commit is contained in:
parent
ee2f4e745c
commit
8eed24cd3d
7 changed files with 60 additions and 12 deletions
|
@ -162,6 +162,12 @@ pub struct RunFlags {
|
||||||
pub script: String,
|
pub script: String,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl RunFlags {
|
||||||
|
pub fn is_stdin(&self) -> bool {
|
||||||
|
self.script == "-"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[derive(Clone, Debug, PartialEq, Deserialize, Serialize)]
|
#[derive(Clone, Debug, PartialEq, Deserialize, Serialize)]
|
||||||
pub struct TaskFlags {
|
pub struct TaskFlags {
|
||||||
pub cwd: Option<String>,
|
pub cwd: Option<String>,
|
||||||
|
|
|
@ -278,8 +278,25 @@ impl CliOptions {
|
||||||
self.flags.compat
|
self.flags.compat
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn coverage_dir(&self) -> Option<&String> {
|
pub fn coverage_dir(&self) -> Option<String> {
|
||||||
self.flags.coverage_dir.as_ref()
|
fn allow_coverage(sub_command: &DenoSubcommand) -> bool {
|
||||||
|
match sub_command {
|
||||||
|
DenoSubcommand::Test(_) => true,
|
||||||
|
DenoSubcommand::Run(flags) => !flags.is_stdin(),
|
||||||
|
_ => false,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if allow_coverage(self.sub_command()) {
|
||||||
|
self
|
||||||
|
.flags
|
||||||
|
.coverage_dir
|
||||||
|
.as_ref()
|
||||||
|
.map(ToOwned::to_owned)
|
||||||
|
.or_else(|| env::var("DENO_UNSTABLE_COVERAGE_DIR").ok())
|
||||||
|
} else {
|
||||||
|
None
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn enable_testing_features(&self) -> bool {
|
pub fn enable_testing_features(&self) -> bool {
|
||||||
|
|
|
@ -774,7 +774,7 @@ async fn run_command(
|
||||||
run_flags: RunFlags,
|
run_flags: RunFlags,
|
||||||
) -> Result<i32, AnyError> {
|
) -> Result<i32, AnyError> {
|
||||||
// Read script content from stdin
|
// Read script content from stdin
|
||||||
if run_flags.script == "-" {
|
if run_flags.is_stdin() {
|
||||||
return run_from_stdin(flags).await;
|
return run_from_stdin(flags).await;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -51,7 +51,6 @@ use deno_runtime::permissions::Permissions;
|
||||||
use import_map::ImportMap;
|
use import_map::ImportMap;
|
||||||
use log::warn;
|
use log::warn;
|
||||||
use std::collections::HashSet;
|
use std::collections::HashSet;
|
||||||
use std::env;
|
|
||||||
use std::ops::Deref;
|
use std::ops::Deref;
|
||||||
use std::path::PathBuf;
|
use std::path::PathBuf;
|
||||||
use std::sync::Arc;
|
use std::sync::Arc;
|
||||||
|
@ -64,7 +63,6 @@ pub struct ProcState(Arc<Inner>);
|
||||||
|
|
||||||
pub struct Inner {
|
pub struct Inner {
|
||||||
pub dir: deno_dir::DenoDir,
|
pub dir: deno_dir::DenoDir,
|
||||||
pub coverage_dir: Option<String>,
|
|
||||||
pub file_fetcher: FileFetcher,
|
pub file_fetcher: FileFetcher,
|
||||||
pub options: Arc<CliOptions>,
|
pub options: Arc<CliOptions>,
|
||||||
pub emit_cache: EmitCache,
|
pub emit_cache: EmitCache,
|
||||||
|
@ -176,11 +174,6 @@ impl ProcState {
|
||||||
let maybe_inspector_server =
|
let maybe_inspector_server =
|
||||||
cli_options.resolve_inspector_server().map(Arc::new);
|
cli_options.resolve_inspector_server().map(Arc::new);
|
||||||
|
|
||||||
let coverage_dir = cli_options
|
|
||||||
.coverage_dir()
|
|
||||||
.map(ToOwned::to_owned)
|
|
||||||
.or_else(|| env::var("DENO_UNSTABLE_COVERAGE_DIR").ok());
|
|
||||||
|
|
||||||
// FIXME(bartlomieju): `NodeEsmResolver` is not aware of JSX resolver
|
// FIXME(bartlomieju): `NodeEsmResolver` is not aware of JSX resolver
|
||||||
// created below
|
// created below
|
||||||
let node_resolver = NodeEsmResolver::new(
|
let node_resolver = NodeEsmResolver::new(
|
||||||
|
@ -220,7 +213,6 @@ impl ProcState {
|
||||||
|
|
||||||
Ok(ProcState(Arc::new(Inner {
|
Ok(ProcState(Arc::new(Inner {
|
||||||
dir,
|
dir,
|
||||||
coverage_dir,
|
|
||||||
options: cli_options,
|
options: cli_options,
|
||||||
emit_cache,
|
emit_cache,
|
||||||
emit_options_hash: FastInsecureHasher::new()
|
emit_options_hash: FastInsecureHasher::new()
|
||||||
|
|
|
@ -32,6 +32,7 @@ fn run_coverage_text(test_name: &str, extension: &str) {
|
||||||
let status = util::deno_cmd_with_deno_dir(&deno_dir)
|
let status = util::deno_cmd_with_deno_dir(&deno_dir)
|
||||||
.current_dir(util::testdata_path())
|
.current_dir(util::testdata_path())
|
||||||
.arg("test")
|
.arg("test")
|
||||||
|
.arg("-A")
|
||||||
.arg("--quiet")
|
.arg("--quiet")
|
||||||
.arg("--unstable")
|
.arg("--unstable")
|
||||||
.arg(format!("--coverage={}", tempdir.to_str().unwrap()))
|
.arg(format!("--coverage={}", tempdir.to_str().unwrap()))
|
||||||
|
|
32
cli/tests/testdata/coverage/complex_test.ts
vendored
32
cli/tests/testdata/coverage/complex_test.ts
vendored
|
@ -3,3 +3,35 @@ import { complex } from "./complex.ts";
|
||||||
Deno.test("complex", function () {
|
Deno.test("complex", function () {
|
||||||
complex("foo", "bar", "baz");
|
complex("foo", "bar", "baz");
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Deno.test("sub process with stdin", async () => {
|
||||||
|
// ensure launching deno run with stdin doesn't affect coverage
|
||||||
|
const code = "console.log('5')";
|
||||||
|
const p = await Deno.run({
|
||||||
|
cmd: [Deno.execPath(), "run", "-"],
|
||||||
|
stdin: "piped",
|
||||||
|
stdout: "piped",
|
||||||
|
});
|
||||||
|
const encoder = new TextEncoder();
|
||||||
|
await p.stdin.write(encoder.encode(code));
|
||||||
|
await p.stdin.close();
|
||||||
|
const output = new TextDecoder().decode(await p.output());
|
||||||
|
p.close();
|
||||||
|
if (output.trim() !== "5") {
|
||||||
|
throw new Error("Failed");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
Deno.test("sub process with deno eval", async () => {
|
||||||
|
// ensure launching deno eval doesn't affect coverage
|
||||||
|
const code = "console.log('5')";
|
||||||
|
const p = await Deno.run({
|
||||||
|
cmd: [Deno.execPath(), "eval", code],
|
||||||
|
stdout: "piped",
|
||||||
|
});
|
||||||
|
const output = new TextDecoder().decode(await p.output());
|
||||||
|
p.close();
|
||||||
|
if (output.trim() !== "5") {
|
||||||
|
throw new Error("Failed");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
|
@ -390,7 +390,7 @@ impl CliMainWorker {
|
||||||
async fn maybe_setup_coverage_collector(
|
async fn maybe_setup_coverage_collector(
|
||||||
&mut self,
|
&mut self,
|
||||||
) -> Result<Option<CoverageCollector>, AnyError> {
|
) -> Result<Option<CoverageCollector>, AnyError> {
|
||||||
if let Some(ref coverage_dir) = self.ps.coverage_dir {
|
if let Some(ref coverage_dir) = self.ps.options.coverage_dir() {
|
||||||
let session = self.worker.create_inspector_session().await;
|
let session = self.worker.create_inspector_session().await;
|
||||||
|
|
||||||
let coverage_dir = PathBuf::from(coverage_dir);
|
let coverage_dir = PathBuf::from(coverage_dir);
|
||||||
|
|
Loading…
Reference in a new issue