mirror of
https://github.com/denoland/deno.git
synced 2025-01-12 00:54:02 -05:00
feat(runtime): add WorkerLogLevel
(#19316)
This is not really used yet, but provides some infrastructure for doing more fine grained logging in JS. I will add warn messages in a future PR.
This commit is contained in:
parent
02ff280496
commit
03398ddace
7 changed files with 60 additions and 23 deletions
|
@ -678,11 +678,7 @@ impl CliFactory {
|
||||||
) -> Result<CliMainWorkerOptions, AnyError> {
|
) -> Result<CliMainWorkerOptions, AnyError> {
|
||||||
Ok(CliMainWorkerOptions {
|
Ok(CliMainWorkerOptions {
|
||||||
argv: self.options.argv().clone(),
|
argv: self.options.argv().clone(),
|
||||||
debug: self
|
log_level: self.options.log_level().unwrap_or(log::Level::Info).into(),
|
||||||
.options
|
|
||||||
.log_level()
|
|
||||||
.map(|l| l == log::Level::Debug)
|
|
||||||
.unwrap_or(false),
|
|
||||||
coverage_dir: self.options.coverage_dir(),
|
coverage_dir: self.options.coverage_dir(),
|
||||||
enable_testing_features: self.options.enable_testing_features(),
|
enable_testing_features: self.options.enable_testing_features(),
|
||||||
has_node_modules_dir: self.options.has_node_modules_dir(),
|
has_node_modules_dir: self.options.has_node_modules_dir(),
|
||||||
|
|
|
@ -46,6 +46,7 @@ use deno_runtime::deno_tls::RootCertStoreProvider;
|
||||||
use deno_runtime::deno_web::BlobStore;
|
use deno_runtime::deno_web::BlobStore;
|
||||||
use deno_runtime::permissions::Permissions;
|
use deno_runtime::permissions::Permissions;
|
||||||
use deno_runtime::permissions::PermissionsContainer;
|
use deno_runtime::permissions::PermissionsContainer;
|
||||||
|
use deno_runtime::WorkerLogLevel;
|
||||||
use deno_semver::npm::NpmPackageReqReference;
|
use deno_semver::npm::NpmPackageReqReference;
|
||||||
use import_map::parse_from_json;
|
use import_map::parse_from_json;
|
||||||
use std::pin::Pin;
|
use std::pin::Pin;
|
||||||
|
@ -423,7 +424,7 @@ pub async fn run(
|
||||||
None,
|
None,
|
||||||
CliMainWorkerOptions {
|
CliMainWorkerOptions {
|
||||||
argv: metadata.argv,
|
argv: metadata.argv,
|
||||||
debug: false,
|
log_level: WorkerLogLevel::Info,
|
||||||
coverage_dir: None,
|
coverage_dir: None,
|
||||||
enable_testing_features: false,
|
enable_testing_features: false,
|
||||||
has_node_modules_dir,
|
has_node_modules_dir,
|
||||||
|
|
|
@ -37,6 +37,7 @@ use deno_runtime::web_worker::WebWorkerOptions;
|
||||||
use deno_runtime::worker::MainWorker;
|
use deno_runtime::worker::MainWorker;
|
||||||
use deno_runtime::worker::WorkerOptions;
|
use deno_runtime::worker::WorkerOptions;
|
||||||
use deno_runtime::BootstrapOptions;
|
use deno_runtime::BootstrapOptions;
|
||||||
|
use deno_runtime::WorkerLogLevel;
|
||||||
use deno_semver::npm::NpmPackageReqReference;
|
use deno_semver::npm::NpmPackageReqReference;
|
||||||
|
|
||||||
use crate::args::StorageKeyResolver;
|
use crate::args::StorageKeyResolver;
|
||||||
|
@ -73,7 +74,7 @@ pub trait HasNodeSpecifierChecker: Send + Sync {
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
pub struct CliMainWorkerOptions {
|
pub struct CliMainWorkerOptions {
|
||||||
pub argv: Vec<String>,
|
pub argv: Vec<String>,
|
||||||
pub debug: bool,
|
pub log_level: WorkerLogLevel,
|
||||||
pub coverage_dir: Option<String>,
|
pub coverage_dir: Option<String>,
|
||||||
pub enable_testing_features: bool,
|
pub enable_testing_features: bool,
|
||||||
pub has_node_modules_dir: bool,
|
pub has_node_modules_dir: bool,
|
||||||
|
@ -434,7 +435,7 @@ impl CliMainWorkerFactory {
|
||||||
cpu_count: std::thread::available_parallelism()
|
cpu_count: std::thread::available_parallelism()
|
||||||
.map(|p| p.get())
|
.map(|p| p.get())
|
||||||
.unwrap_or(1),
|
.unwrap_or(1),
|
||||||
debug_flag: shared.options.debug,
|
log_level: shared.options.log_level,
|
||||||
enable_testing_features: shared.options.enable_testing_features,
|
enable_testing_features: shared.options.enable_testing_features,
|
||||||
locale: deno_core::v8::icu::get_language_tag(),
|
locale: deno_core::v8::icu::get_language_tag(),
|
||||||
location: shared.options.location.clone(),
|
location: shared.options.location.clone(),
|
||||||
|
@ -562,7 +563,7 @@ fn create_web_worker_callback(
|
||||||
cpu_count: std::thread::available_parallelism()
|
cpu_count: std::thread::available_parallelism()
|
||||||
.map(|p| p.get())
|
.map(|p| p.get())
|
||||||
.unwrap_or(1),
|
.unwrap_or(1),
|
||||||
debug_flag: shared.options.debug,
|
log_level: shared.options.log_level,
|
||||||
enable_testing_features: shared.options.enable_testing_features,
|
enable_testing_features: shared.options.enable_testing_features,
|
||||||
locale: deno_core::v8::icu::get_language_tag(),
|
locale: deno_core::v8::icu::get_language_tag(),
|
||||||
location: Some(args.main_module.clone()),
|
location: Some(args.main_module.clone()),
|
||||||
|
|
|
@ -5,18 +5,27 @@ const {
|
||||||
Promise,
|
Promise,
|
||||||
SafeArrayIterator,
|
SafeArrayIterator,
|
||||||
} = primordials;
|
} = primordials;
|
||||||
let logDebug = false;
|
|
||||||
|
// WARNING: Keep this in sync with Rust (search for LogLevel)
|
||||||
|
const LogLevel = {
|
||||||
|
Error: 1,
|
||||||
|
Warn: 2,
|
||||||
|
Info: 3,
|
||||||
|
Debug: 4,
|
||||||
|
};
|
||||||
|
|
||||||
|
let logLevel = 3;
|
||||||
let logSource = "JS";
|
let logSource = "JS";
|
||||||
|
|
||||||
function setLogDebug(debug, source) {
|
function setLogLevel(level, source) {
|
||||||
logDebug = debug;
|
logLevel = level;
|
||||||
if (source) {
|
if (source) {
|
||||||
logSource = source;
|
logSource = source;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function log(...args) {
|
function log(...args) {
|
||||||
if (logDebug) {
|
if (logLevel >= LogLevel.Debug) {
|
||||||
// if we destructure `console` off `globalThis` too early, we don't bind to
|
// if we destructure `console` off `globalThis` too early, we don't bind to
|
||||||
// the right console, therefore we don't log anything out.
|
// the right console, therefore we don't log anything out.
|
||||||
globalThis.console.error(
|
globalThis.console.error(
|
||||||
|
@ -80,6 +89,6 @@ export {
|
||||||
log,
|
log,
|
||||||
nonEnumerable,
|
nonEnumerable,
|
||||||
readOnly,
|
readOnly,
|
||||||
setLogDebug,
|
setLogLevel,
|
||||||
writable,
|
writable,
|
||||||
};
|
};
|
||||||
|
|
|
@ -299,7 +299,7 @@ function runtimeStart(
|
||||||
v8Version,
|
v8Version,
|
||||||
tsVersion,
|
tsVersion,
|
||||||
target,
|
target,
|
||||||
debugFlag,
|
logLevel,
|
||||||
noColor,
|
noColor,
|
||||||
isTty,
|
isTty,
|
||||||
source,
|
source,
|
||||||
|
@ -315,7 +315,7 @@ function runtimeStart(
|
||||||
tsVersion,
|
tsVersion,
|
||||||
);
|
);
|
||||||
core.setBuildInfo(target);
|
core.setBuildInfo(target);
|
||||||
util.setLogDebug(debugFlag, source);
|
util.setLogLevel(logLevel, source);
|
||||||
setNoColor(noColor || !isTty);
|
setNoColor(noColor || !isTty);
|
||||||
// deno-lint-ignore prefer-primordials
|
// deno-lint-ignore prefer-primordials
|
||||||
Error.prepareStackTrace = core.prepareStackTrace;
|
Error.prepareStackTrace = core.prepareStackTrace;
|
||||||
|
@ -428,7 +428,7 @@ function bootstrapMainRuntime(runtimeOptions) {
|
||||||
const {
|
const {
|
||||||
0: args,
|
0: args,
|
||||||
1: cpuCount,
|
1: cpuCount,
|
||||||
2: debugFlag,
|
2: logLevel,
|
||||||
3: denoVersion,
|
3: denoVersion,
|
||||||
4: locale,
|
4: locale,
|
||||||
5: location_,
|
5: location_,
|
||||||
|
@ -495,7 +495,7 @@ function bootstrapMainRuntime(runtimeOptions) {
|
||||||
v8Version,
|
v8Version,
|
||||||
tsVersion,
|
tsVersion,
|
||||||
target,
|
target,
|
||||||
debugFlag,
|
logLevel,
|
||||||
noColor,
|
noColor,
|
||||||
isTty,
|
isTty,
|
||||||
);
|
);
|
||||||
|
@ -542,7 +542,7 @@ function bootstrapWorkerRuntime(
|
||||||
const {
|
const {
|
||||||
0: args,
|
0: args,
|
||||||
1: cpuCount,
|
1: cpuCount,
|
||||||
2: debugFlag,
|
2: logLevel,
|
||||||
3: denoVersion,
|
3: denoVersion,
|
||||||
4: locale,
|
4: locale,
|
||||||
5: location_,
|
5: location_,
|
||||||
|
@ -610,7 +610,7 @@ function bootstrapWorkerRuntime(
|
||||||
v8Version,
|
v8Version,
|
||||||
tsVersion,
|
tsVersion,
|
||||||
target,
|
target,
|
||||||
debugFlag,
|
logLevel,
|
||||||
noColor,
|
noColor,
|
||||||
isTty,
|
isTty,
|
||||||
internalName ?? name,
|
internalName ?? name,
|
||||||
|
|
|
@ -35,3 +35,4 @@ pub mod worker;
|
||||||
|
|
||||||
mod worker_bootstrap;
|
mod worker_bootstrap;
|
||||||
pub use worker_bootstrap::BootstrapOptions;
|
pub use worker_bootstrap::BootstrapOptions;
|
||||||
|
pub use worker_bootstrap::WorkerLogLevel;
|
||||||
|
|
|
@ -6,13 +6,42 @@ use std::thread;
|
||||||
|
|
||||||
use crate::colors;
|
use crate::colors;
|
||||||
|
|
||||||
|
/// The log level to use when printing diagnostic log messages, warnings,
|
||||||
|
/// or errors in the worker.
|
||||||
|
///
|
||||||
|
/// Note: This is disconnected with the log crate's log level and the Rust code
|
||||||
|
/// in this crate will respect that value instead. To specify that, use
|
||||||
|
/// `log::set_max_level`.
|
||||||
|
#[derive(Debug, Default, Clone, Copy)]
|
||||||
|
pub enum WorkerLogLevel {
|
||||||
|
// WARNING: Ensure this is kept in sync with
|
||||||
|
// the JS values (search for LogLevel).
|
||||||
|
Error = 1,
|
||||||
|
Warn = 2,
|
||||||
|
#[default]
|
||||||
|
Info = 3,
|
||||||
|
Debug = 4,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl From<log::Level> for WorkerLogLevel {
|
||||||
|
fn from(value: log::Level) -> Self {
|
||||||
|
match value {
|
||||||
|
log::Level::Error => WorkerLogLevel::Error,
|
||||||
|
log::Level::Warn => WorkerLogLevel::Warn,
|
||||||
|
log::Level::Info => WorkerLogLevel::Info,
|
||||||
|
log::Level::Debug => WorkerLogLevel::Debug,
|
||||||
|
log::Level::Trace => WorkerLogLevel::Debug,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// Common bootstrap options for MainWorker & WebWorker
|
/// Common bootstrap options for MainWorker & WebWorker
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
pub struct BootstrapOptions {
|
pub struct BootstrapOptions {
|
||||||
/// Sets `Deno.args` in JS runtime.
|
/// Sets `Deno.args` in JS runtime.
|
||||||
pub args: Vec<String>,
|
pub args: Vec<String>,
|
||||||
pub cpu_count: usize,
|
pub cpu_count: usize,
|
||||||
pub debug_flag: bool,
|
pub log_level: WorkerLogLevel,
|
||||||
pub enable_testing_features: bool,
|
pub enable_testing_features: bool,
|
||||||
pub locale: String,
|
pub locale: String,
|
||||||
pub location: Option<ModuleSpecifier>,
|
pub location: Option<ModuleSpecifier>,
|
||||||
|
@ -44,7 +73,7 @@ impl Default for BootstrapOptions {
|
||||||
no_color: !colors::use_color(),
|
no_color: !colors::use_color(),
|
||||||
is_tty: colors::is_tty(),
|
is_tty: colors::is_tty(),
|
||||||
enable_testing_features: Default::default(),
|
enable_testing_features: Default::default(),
|
||||||
debug_flag: Default::default(),
|
log_level: Default::default(),
|
||||||
ts_version: Default::default(),
|
ts_version: Default::default(),
|
||||||
locale: "en".to_string(),
|
locale: "en".to_string(),
|
||||||
location: Default::default(),
|
location: Default::default(),
|
||||||
|
@ -77,7 +106,7 @@ impl BootstrapOptions {
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
let val = v8::Boolean::new(scope, self.debug_flag);
|
let val = v8::Integer::new(scope, self.log_level as i32);
|
||||||
array.set_index(scope, 2, val.into());
|
array.set_index(scope, 2, val.into());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue