mirror of
https://github.com/denoland/deno.git
synced 2024-11-21 15:04:11 -05:00
fix(node): Fix --allow-scripts
with no deno.json
(#24533)
We would resolve the wrong package.json, resulting in an inability to run CJS (or other node-mode) scripts
This commit is contained in:
parent
29186d7e59
commit
04f9db5b22
10 changed files with 82 additions and 20 deletions
|
@ -722,15 +722,15 @@ pub enum NpmProcessStateKind {
|
|||
Byonm,
|
||||
}
|
||||
|
||||
const RESOLUTION_STATE_ENV_VAR_NAME: &str =
|
||||
pub(crate) const NPM_RESOLUTION_STATE_ENV_VAR_NAME: &str =
|
||||
"DENO_DONT_USE_INTERNAL_NODE_COMPAT_STATE";
|
||||
|
||||
static NPM_PROCESS_STATE: Lazy<Option<NpmProcessState>> = Lazy::new(|| {
|
||||
let state = std::env::var(RESOLUTION_STATE_ENV_VAR_NAME).ok()?;
|
||||
let state = std::env::var(NPM_RESOLUTION_STATE_ENV_VAR_NAME).ok()?;
|
||||
let state: NpmProcessState = serde_json::from_str(&state).ok()?;
|
||||
// remove the environment variable so that sub processes
|
||||
// that are spawned do not also use this.
|
||||
std::env::remove_var(RESOLUTION_STATE_ENV_VAR_NAME);
|
||||
std::env::remove_var(NPM_RESOLUTION_STATE_ENV_VAR_NAME);
|
||||
Some(state)
|
||||
});
|
||||
|
||||
|
|
|
@ -518,22 +518,25 @@ impl ManagedCliNpmResolver {
|
|||
}
|
||||
}
|
||||
|
||||
fn npm_process_state(
|
||||
snapshot: ValidSerializedNpmResolutionSnapshot,
|
||||
node_modules_path: Option<&Path>,
|
||||
) -> String {
|
||||
serde_json::to_string(&NpmProcessState {
|
||||
kind: NpmProcessStateKind::Snapshot(snapshot.into_serialized()),
|
||||
local_node_modules_path: node_modules_path
|
||||
.map(|p| p.to_string_lossy().to_string()),
|
||||
})
|
||||
.unwrap()
|
||||
}
|
||||
|
||||
impl NpmResolver for ManagedCliNpmResolver {
|
||||
/// Gets the state of npm for the process.
|
||||
fn get_npm_process_state(&self) -> String {
|
||||
serde_json::to_string(&NpmProcessState {
|
||||
kind: NpmProcessStateKind::Snapshot(
|
||||
self
|
||||
.resolution
|
||||
.serialized_valid_snapshot()
|
||||
.into_serialized(),
|
||||
),
|
||||
local_node_modules_path: self
|
||||
.fs_resolver
|
||||
.node_modules_path()
|
||||
.map(|p| p.to_string_lossy().to_string()),
|
||||
})
|
||||
.unwrap()
|
||||
npm_process_state(
|
||||
self.resolution.serialized_valid_snapshot(),
|
||||
self.fs_resolver.node_modules_path().map(|p| p.as_path()),
|
||||
)
|
||||
}
|
||||
|
||||
fn resolve_package_folder_from_package(
|
||||
|
|
|
@ -282,8 +282,12 @@ fn resolve_baseline_custom_commands(
|
|||
custom_commands
|
||||
.insert("npm".to_string(), Rc::new(crate::task_runner::NpmCommand));
|
||||
|
||||
custom_commands
|
||||
.insert("node".to_string(), Rc::new(crate::task_runner::NodeCommand));
|
||||
custom_commands.insert(
|
||||
"node".to_string(),
|
||||
Rc::new(crate::task_runner::NodeCommand {
|
||||
force_node_modules_dir: true,
|
||||
}),
|
||||
);
|
||||
|
||||
custom_commands.insert(
|
||||
"node-gyp".to_string(),
|
||||
|
@ -687,7 +691,16 @@ async fn sync_resolution_with_fs(
|
|||
&deno_local_registry_dir,
|
||||
)?;
|
||||
let init_cwd = lifecycle_scripts.initial_cwd.as_deref().unwrap();
|
||||
let process_state = crate::npm::managed::npm_process_state(
|
||||
snapshot.as_valid_serialized(),
|
||||
Some(root_node_modules_dir_path),
|
||||
);
|
||||
|
||||
let mut env_vars = crate::task_runner::real_env_vars();
|
||||
env_vars.insert(
|
||||
crate::args::NPM_RESOLUTION_STATE_ENV_VAR_NAME.to_string(),
|
||||
process_state,
|
||||
);
|
||||
for (package, package_path, scripts_run_path) in packages_with_scripts {
|
||||
// add custom commands for binaries from the package's dependencies. this will take precedence over the
|
||||
// baseline commands, so if the package relies on a bin that conflicts with one higher in the dependency tree, the
|
||||
|
@ -710,7 +723,7 @@ async fn sync_resolution_with_fs(
|
|||
task_name: script_name,
|
||||
script,
|
||||
cwd: &package_path,
|
||||
env_vars: crate::task_runner::real_env_vars(),
|
||||
env_vars: env_vars.clone(),
|
||||
custom_commands: custom_commands.clone(),
|
||||
init_cwd,
|
||||
argv: &[],
|
||||
|
|
|
@ -164,7 +164,9 @@ impl ShellCommand for NpmCommand {
|
|||
}
|
||||
}
|
||||
|
||||
pub struct NodeCommand;
|
||||
pub struct NodeCommand {
|
||||
pub force_node_modules_dir: bool,
|
||||
}
|
||||
|
||||
impl ShellCommand for NodeCommand {
|
||||
fn execute(
|
||||
|
@ -191,6 +193,9 @@ impl ShellCommand for NodeCommand {
|
|||
.execute(context);
|
||||
}
|
||||
args.extend(["run", "-A"].into_iter().map(|s| s.to_string()));
|
||||
if self.force_node_modules_dir {
|
||||
args.push("--node-modules-dir=true".to_string());
|
||||
}
|
||||
args.extend(context.args.iter().cloned());
|
||||
|
||||
let mut state = context.state;
|
||||
|
@ -303,6 +308,7 @@ impl ShellCommand for NodeModulesFileRunCommand {
|
|||
let mut args = vec![
|
||||
"run".to_string(),
|
||||
"--ext=js".to_string(),
|
||||
"--node-modules-dir=true".to_string(),
|
||||
"-A".to_string(),
|
||||
self.path.to_string_lossy().to_string(),
|
||||
];
|
||||
|
|
|
@ -0,0 +1,11 @@
|
|||
{
|
||||
"name": "@denotest/lifecycle-scripts-cjs",
|
||||
"version": "1.0.0",
|
||||
"scripts": {
|
||||
"preinstall": "echo preinstall && node preinstall.js",
|
||||
"install": "echo install && cli-cjs 'hello from install script'"
|
||||
},
|
||||
"dependencies": {
|
||||
"@denotest/bin": "1.0.0"
|
||||
}
|
||||
}
|
|
@ -0,0 +1,5 @@
|
|||
const inspect = require('util').inspect;
|
||||
|
||||
inspect({
|
||||
"preinstall": "script"
|
||||
});
|
|
@ -1,4 +1,5 @@
|
|||
if ("Deno" in globalThis && typeof globalThis.Deno === 'object') {
|
||||
require('./helper.js');
|
||||
console.log('deno preinstall.js');
|
||||
} else {
|
||||
console.log('node preinstall.js');
|
||||
|
|
|
@ -119,6 +119,19 @@
|
|||
"output": ""
|
||||
}
|
||||
]
|
||||
},
|
||||
"lifecycle_scripts_no_deno_json": {
|
||||
"tempDir": true,
|
||||
"steps": [
|
||||
{
|
||||
"args": ["eval", "Deno.removeSync('deno.json')"],
|
||||
"output": ""
|
||||
},
|
||||
{
|
||||
"args": "cache --allow-scripts --node-modules-dir=true no_deno_json.js",
|
||||
"output": "no_deno_json.out"
|
||||
}
|
||||
]
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
1
tests/specs/npm/lifecycle_scripts/no_deno_json.js
Normal file
1
tests/specs/npm/lifecycle_scripts/no_deno_json.js
Normal file
|
@ -0,0 +1 @@
|
|||
import {} from "npm:@denotest/lifecycle-scripts-cjs@1.0.0";
|
9
tests/specs/npm/lifecycle_scripts/no_deno_json.out
Normal file
9
tests/specs/npm/lifecycle_scripts/no_deno_json.out
Normal file
|
@ -0,0 +1,9 @@
|
|||
Download http://localhost:4260/@denotest/lifecycle-scripts-cjs
|
||||
Download http://localhost:4260/@denotest/bin
|
||||
Download http://localhost:4260/@denotest/lifecycle-scripts-cjs/1.0.0.tgz
|
||||
Download http://localhost:4260/@denotest/bin/1.0.0.tgz
|
||||
Initialize @denotest/lifecycle-scripts-cjs@1.0.0
|
||||
Initialize @denotest/bin@1.0.0
|
||||
preinstall
|
||||
install
|
||||
hello from install script
|
Loading…
Reference in a new issue