1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-08 15:19:40 -05:00

refactor(core): add AssertedModuleType enum (#14501)

Co-authored-by: Luca Casonato <hello@lcas.dev>
This commit is contained in:
Bartek Iwańczuk 2022-05-07 18:46:35 +02:00 committed by GitHub
parent ff49bd9e32
commit bcd875030a
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 199 additions and 130 deletions

View file

@ -1,5 +1,5 @@
[WILDCARD] [WILDCARD]
error: Uncaught (in promise) TypeError: Expected a "JavaScript" module but loaded a "JSON" module. error: Uncaught (in promise) TypeError: Expected a "JavaScriptOrWasm" module but loaded a "JSON" module.
const data = await import("./data.json"); const data = await import("./data.json");
^ ^
at async [WILDCARD]dynamic_error.ts:1:14 at async [WILDCARD]dynamic_error.ts:1:14

View file

@ -2,7 +2,7 @@
use crate::error::is_instance_of_error; use crate::error::is_instance_of_error;
use crate::error::JsError; use crate::error::JsError;
use crate::modules::get_module_type_from_assertions; use crate::modules::get_asserted_module_type_from_assertions;
use crate::modules::parse_import_assertions; use crate::modules::parse_import_assertions;
use crate::modules::validate_import_assertions; use crate::modules::validate_import_assertions;
use crate::modules::ImportAssertionsKind; use crate::modules::ImportAssertionsKind;
@ -343,7 +343,8 @@ pub extern "C" fn host_import_module_dynamically_callback(
resolver.reject(tc_scope, e); resolver.reject(tc_scope, e);
} }
} }
let module_type = get_module_type_from_assertions(&assertions); let asserted_module_type =
get_asserted_module_type_from_assertions(&assertions);
let resolver_handle = v8::Global::new(scope, resolver); let resolver_handle = v8::Global::new(scope, resolver);
{ {
@ -358,7 +359,7 @@ pub extern "C" fn host_import_module_dynamically_callback(
module_map_rc, module_map_rc,
&specifier_str, &specifier_str,
&referrer_name_str, &referrer_name_str,
module_type, asserted_module_type,
resolver_handle, resolver_handle,
); );
state_rc.borrow_mut().notify_new_dynamic_import(); state_rc.borrow_mut().notify_new_dynamic_import();

View file

@ -100,19 +100,19 @@ pub(crate) fn parse_import_assertions(
assertions assertions
} }
pub(crate) fn get_module_type_from_assertions( pub(crate) fn get_asserted_module_type_from_assertions(
assertions: &HashMap<String, String>, assertions: &HashMap<String, String>,
) -> ModuleType { ) -> AssertedModuleType {
assertions assertions
.get("type") .get("type")
.map(|ty| { .map(|ty| {
if ty == "json" { if ty == "json" {
ModuleType::Json AssertedModuleType::Json
} else { } else {
ModuleType::JavaScript AssertedModuleType::JavaScriptOrWasm
} }
}) })
.unwrap_or(ModuleType::JavaScript) .unwrap_or(AssertedModuleType::JavaScriptOrWasm)
} }
// Clippy thinks the return value doesn't need to be an Option, it's unaware // Clippy thinks the return value doesn't need to be an Option, it's unaware
@ -337,7 +337,7 @@ enum LoadInit {
Side(String), Side(String),
/// Dynamic import specifier with referrer and expected /// Dynamic import specifier with referrer and expected
/// module type (which is determined by import assertion). /// module type (which is determined by import assertion).
DynamicImport(String, String, ModuleType), DynamicImport(String, String, AssertedModuleType),
} }
#[derive(Debug, Eq, PartialEq)] #[derive(Debug, Eq, PartialEq)]
@ -353,6 +353,7 @@ pub(crate) struct RecursiveModuleLoad {
pub id: ModuleLoadId, pub id: ModuleLoadId,
pub root_module_id: Option<ModuleId>, pub root_module_id: Option<ModuleId>,
init: LoadInit, init: LoadInit,
root_asserted_module_type: Option<AssertedModuleType>,
root_module_type: Option<ModuleType>, root_module_type: Option<ModuleType>,
state: LoadState, state: LoadState,
module_map_rc: Rc<RefCell<ModuleMap>>, module_map_rc: Rc<RefCell<ModuleMap>>,
@ -383,14 +384,14 @@ impl RecursiveModuleLoad {
fn dynamic_import( fn dynamic_import(
specifier: &str, specifier: &str,
referrer: &str, referrer: &str,
module_type: ModuleType, asserted_module_type: AssertedModuleType,
module_map_rc: Rc<RefCell<ModuleMap>>, module_map_rc: Rc<RefCell<ModuleMap>>,
) -> Self { ) -> Self {
Self::new( Self::new(
LoadInit::DynamicImport( LoadInit::DynamicImport(
specifier.to_string(), specifier.to_string(),
referrer.to_string(), referrer.to_string(),
module_type, asserted_module_type,
), ),
module_map_rc, module_map_rc,
) )
@ -405,13 +406,14 @@ impl RecursiveModuleLoad {
}; };
let op_state = module_map_rc.borrow().op_state.clone(); let op_state = module_map_rc.borrow().op_state.clone();
let loader = module_map_rc.borrow().loader.clone(); let loader = module_map_rc.borrow().loader.clone();
let expected_module_type = match init { let asserted_module_type = match init {
LoadInit::DynamicImport(_, _, module_type) => module_type, LoadInit::DynamicImport(_, _, module_type) => module_type,
_ => ModuleType::JavaScript, _ => AssertedModuleType::JavaScriptOrWasm,
}; };
let mut load = Self { let mut load = Self {
id, id,
root_module_id: None, root_module_id: None,
root_asserted_module_type: None,
root_module_type: None, root_module_type: None,
init, init,
state: LoadState::Init, state: LoadState::Init,
@ -426,10 +428,17 @@ impl RecursiveModuleLoad {
if let Ok(root_specifier) = load.resolve_root() { if let Ok(root_specifier) = load.resolve_root() {
if let Some(module_id) = module_map_rc if let Some(module_id) = module_map_rc
.borrow() .borrow()
.get_id(root_specifier.as_str(), expected_module_type) .get_id(root_specifier.as_str(), asserted_module_type)
{ {
load.root_module_id = Some(module_id); load.root_module_id = Some(module_id);
load.root_module_type = Some(expected_module_type); load.root_asserted_module_type = Some(asserted_module_type);
load.root_module_type = Some(
module_map_rc
.borrow()
.get_info_by_id(&module_id)
.unwrap()
.module_type,
);
} }
} }
load load
@ -493,10 +502,11 @@ impl RecursiveModuleLoad {
module_request: &ModuleRequest, module_request: &ModuleRequest,
module_source: &ModuleSource, module_source: &ModuleSource,
) -> Result<(), ModuleError> { ) -> Result<(), ModuleError> {
if module_request.expected_module_type != module_source.module_type { let expected_asserted_module_type = module_source.module_type.into();
if module_request.asserted_module_type != expected_asserted_module_type {
return Err(ModuleError::Other(generic_error(format!( return Err(ModuleError::Other(generic_error(format!(
"Expected a \"{}\" module but loaded a \"{}\" module.", "Expected a \"{}\" module but loaded a \"{}\" module.",
module_request.expected_module_type, module_source.module_type, module_request.asserted_module_type, module_source.module_type,
)))); ))));
} }
@ -505,14 +515,14 @@ impl RecursiveModuleLoad {
if module_source.module_url_specified != module_source.module_url_found { if module_source.module_url_specified != module_source.module_url_found {
self.module_map_rc.borrow_mut().alias( self.module_map_rc.borrow_mut().alias(
&module_source.module_url_specified, &module_source.module_url_specified,
module_source.module_type, expected_asserted_module_type,
&module_source.module_url_found, &module_source.module_url_found,
); );
} }
let maybe_module_id = self let maybe_module_id = self.module_map_rc.borrow().get_id(
.module_map_rc &module_source.module_url_found,
.borrow() expected_asserted_module_type,
.get_id(&module_source.module_url_found, module_source.module_type); );
let module_id = match maybe_module_id { let module_id = match maybe_module_id {
Some(id) => { Some(id) => {
debug!( debug!(
@ -562,7 +572,7 @@ impl RecursiveModuleLoad {
if !self.visited.contains(&module_request) { if !self.visited.contains(&module_request) {
if let Some(module_id) = self.module_map_rc.borrow().get_id( if let Some(module_id) = self.module_map_rc.borrow().get_id(
module_request.specifier.as_str(), module_request.specifier.as_str(),
module_request.expected_module_type, module_request.asserted_module_type,
) { ) {
already_registered.push_back((module_id, module_request.clone())); already_registered.push_back((module_id, module_request.clone()));
} else { } else {
@ -590,7 +600,7 @@ impl RecursiveModuleLoad {
// Update `self.state` however applicable. // Update `self.state` however applicable.
if self.state == LoadState::LoadingRoot { if self.state == LoadState::LoadingRoot {
self.root_module_id = Some(module_id); self.root_module_id = Some(module_id);
self.root_module_type = Some(module_source.module_type); self.root_asserted_module_type = Some(module_source.module_type.into());
self.state = LoadState::LoadingImports; self.state = LoadState::LoadingImports;
} }
if self.pending.is_empty() { if self.pending.is_empty() {
@ -625,10 +635,11 @@ impl Stream for RecursiveModuleLoad {
// like the bottom of `RecursiveModuleLoad::register_and_recurse()`. // like the bottom of `RecursiveModuleLoad::register_and_recurse()`.
// But the module map cannot be borrowed here. Instead fake a load // But the module map cannot be borrowed here. Instead fake a load
// event so it gets passed to that function and recursed eventually. // event so it gets passed to that function and recursed eventually.
let asserted_module_type = inner.root_asserted_module_type.unwrap();
let module_type = inner.root_module_type.unwrap(); let module_type = inner.root_module_type.unwrap();
let module_request = ModuleRequest { let module_request = ModuleRequest {
specifier: module_specifier.clone(), specifier: module_specifier.clone(),
expected_module_type: module_type, asserted_module_type,
}; };
let module_source = ModuleSource { let module_source = ModuleSource {
module_url_specified: module_specifier.to_string(), module_url_specified: module_specifier.to_string(),
@ -646,13 +657,13 @@ impl Stream for RecursiveModuleLoad {
} }
_ => None, _ => None,
}; };
let expected_module_type = match inner.init { let asserted_module_type = match inner.init {
LoadInit::DynamicImport(_, _, module_type) => module_type, LoadInit::DynamicImport(_, _, module_type) => module_type,
_ => ModuleType::JavaScript, _ => AssertedModuleType::JavaScriptOrWasm,
}; };
let module_request = ModuleRequest { let module_request = ModuleRequest {
specifier: module_specifier.clone(), specifier: module_specifier.clone(),
expected_module_type, asserted_module_type,
}; };
let loader = inner.loader.clone(); let loader = inner.loader.clone();
let is_dynamic_import = inner.is_dynamic_import(); let is_dynamic_import = inner.is_dynamic_import();
@ -680,13 +691,38 @@ impl Stream for RecursiveModuleLoad {
} }
} }
/// Describes what is the expected type of module, usually #[derive(Clone, Copy, Debug, Eq, Hash, PartialEq)]
/// it's `ModuleType::JavaScript`, but if there were import assertions pub(crate) enum AssertedModuleType {
/// it might be `ModuleType::Json`. JavaScriptOrWasm,
Json,
}
impl From<ModuleType> for AssertedModuleType {
fn from(module_type: ModuleType) -> AssertedModuleType {
match module_type {
ModuleType::JavaScript => AssertedModuleType::JavaScriptOrWasm,
ModuleType::Json => AssertedModuleType::Json,
}
}
}
impl std::fmt::Display for AssertedModuleType {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
match self {
Self::JavaScriptOrWasm => write!(f, "JavaScriptOrWasm"),
Self::Json => write!(f, "JSON"),
}
}
}
/// Describes a request for a module as parsed from the source code.
/// Usually executable (`JavaScriptOrWasm`) is used, except when an
/// import assertions explicitly constrains an import to JSON, in
/// which case this will have a `AssertedModuleType::Json`.
#[derive(Clone, Debug, Eq, Hash, PartialEq)] #[derive(Clone, Debug, Eq, Hash, PartialEq)]
pub(crate) struct ModuleRequest { pub(crate) struct ModuleRequest {
pub specifier: ModuleSpecifier, pub specifier: ModuleSpecifier,
pub expected_module_type: ModuleType, pub asserted_module_type: AssertedModuleType,
} }
pub(crate) struct ModuleInfo { pub(crate) struct ModuleInfo {
@ -721,7 +757,7 @@ pub(crate) struct ModuleMap {
ids_by_handle: HashMap<v8::Global<v8::Module>, ModuleId>, ids_by_handle: HashMap<v8::Global<v8::Module>, ModuleId>,
handles_by_id: HashMap<ModuleId, v8::Global<v8::Module>>, handles_by_id: HashMap<ModuleId, v8::Global<v8::Module>>,
info: HashMap<ModuleId, ModuleInfo>, info: HashMap<ModuleId, ModuleInfo>,
by_name: HashMap<(String, ModuleType), SymbolicModule>, by_name: HashMap<(String, AssertedModuleType), SymbolicModule>,
next_module_id: ModuleId, next_module_id: ModuleId,
next_load_id: ModuleLoadId, next_load_id: ModuleLoadId,
@ -763,11 +799,16 @@ impl ModuleMap {
/// Get module id, following all aliases in case of module specifier /// Get module id, following all aliases in case of module specifier
/// that had been redirected. /// that had been redirected.
fn get_id(&self, name: &str, module_type: ModuleType) -> Option<ModuleId> { fn get_id(
&self,
name: &str,
asserted_module_type: AssertedModuleType,
) -> Option<ModuleId> {
let mut mod_name = name; let mut mod_name = name;
loop { loop {
let symbolic_module = let symbolic_module = self
self.by_name.get(&(mod_name.to_string(), module_type))?; .by_name
.get(&(mod_name.to_string(), asserted_module_type))?;
match symbolic_module { match symbolic_module {
SymbolicModule::Alias(target) => { SymbolicModule::Alias(target) => {
mod_name = target; mod_name = target;
@ -883,10 +924,11 @@ impl ModuleMap {
Ok(s) => s, Ok(s) => s,
Err(e) => return Err(ModuleError::Other(e)), Err(e) => return Err(ModuleError::Other(e)),
}; };
let expected_module_type = get_module_type_from_assertions(&assertions); let asserted_module_type =
get_asserted_module_type_from_assertions(&assertions);
let request = ModuleRequest { let request = ModuleRequest {
specifier: module_specifier, specifier: module_specifier,
expected_module_type, asserted_module_type,
}; };
requests.push(request); requests.push(request);
} }
@ -924,9 +966,10 @@ impl ModuleMap {
) -> ModuleId { ) -> ModuleId {
let id = self.next_module_id; let id = self.next_module_id;
self.next_module_id += 1; self.next_module_id += 1;
self self.by_name.insert(
.by_name (name.to_string(), module_type.into()),
.insert((name.to_string(), module_type), SymbolicModule::Mod(id)); SymbolicModule::Mod(id),
);
self.handles_by_id.insert(id, handle.clone()); self.handles_by_id.insert(id, handle.clone());
self.ids_by_handle.insert(handle, id); self.ids_by_handle.insert(handle, id);
self.info.insert( self.info.insert(
@ -950,26 +993,35 @@ impl ModuleMap {
fn is_registered( fn is_registered(
&self, &self,
specifier: &ModuleSpecifier, specifier: &ModuleSpecifier,
module_type: ModuleType, asserted_module_type: AssertedModuleType,
) -> bool { ) -> bool {
if let Some(id) = self.get_id(specifier.as_str(), module_type) { if let Some(id) = self.get_id(specifier.as_str(), asserted_module_type) {
let info = self.get_info_by_id(&id).unwrap(); let info = self.get_info_by_id(&id).unwrap();
return info.module_type == module_type; return asserted_module_type == info.module_type.into();
} }
false false
} }
fn alias(&mut self, name: &str, module_type: ModuleType, target: &str) { fn alias(
&mut self,
name: &str,
asserted_module_type: AssertedModuleType,
target: &str,
) {
self.by_name.insert( self.by_name.insert(
(name.to_string(), module_type), (name.to_string(), asserted_module_type),
SymbolicModule::Alias(target.to_string()), SymbolicModule::Alias(target.to_string()),
); );
} }
#[cfg(test)] #[cfg(test)]
fn is_alias(&self, name: &str, module_type: ModuleType) -> bool { fn is_alias(
let cond = self.by_name.get(&(name.to_string(), module_type)); &self,
name: &str,
asserted_module_type: AssertedModuleType,
) -> bool {
let cond = self.by_name.get(&(name.to_string(), asserted_module_type));
matches!(cond, Some(SymbolicModule::Alias(_))) matches!(cond, Some(SymbolicModule::Alias(_)))
} }
@ -1018,13 +1070,13 @@ impl ModuleMap {
module_map_rc: Rc<RefCell<ModuleMap>>, module_map_rc: Rc<RefCell<ModuleMap>>,
specifier: &str, specifier: &str,
referrer: &str, referrer: &str,
module_type: ModuleType, asserted_module_type: AssertedModuleType,
resolver_handle: v8::Global<v8::PromiseResolver>, resolver_handle: v8::Global<v8::PromiseResolver>,
) { ) {
let load = RecursiveModuleLoad::dynamic_import( let load = RecursiveModuleLoad::dynamic_import(
specifier, specifier,
referrer, referrer,
module_type, asserted_module_type,
module_map_rc.clone(), module_map_rc.clone(),
); );
module_map_rc module_map_rc
@ -1039,7 +1091,7 @@ impl ModuleMap {
Ok(module_specifier) => { Ok(module_specifier) => {
if module_map_rc if module_map_rc
.borrow() .borrow()
.is_registered(&module_specifier, module_type) .is_registered(&module_specifier, asserted_module_type)
{ {
async move { (load.id, Ok(load)) }.boxed_local() async move { (load.id, Ok(load)) }.boxed_local()
} else { } else {
@ -1073,7 +1125,8 @@ impl ModuleMap {
.resolve(specifier, referrer, false) .resolve(specifier, referrer, false)
.expect("Module should have been already resolved"); .expect("Module should have been already resolved");
let module_type = get_module_type_from_assertions(&import_assertions); let module_type =
get_asserted_module_type_from_assertions(&import_assertions);
if let Some(id) = self.get_id(resolved_specifier.as_str(), module_type) { if let Some(id) = self.get_id(resolved_specifier.as_str(), module_type) {
if let Some(handle) = self.get_handle(id) { if let Some(handle) = self.get_handle(id) {
@ -1342,28 +1395,28 @@ import "/a.js";
let modules = module_map_rc.borrow(); let modules = module_map_rc.borrow();
assert_eq!( assert_eq!(
modules.get_id("file:///a.js", ModuleType::JavaScript), modules.get_id("file:///a.js", AssertedModuleType::JavaScriptOrWasm),
Some(a_id) Some(a_id)
); );
let b_id = modules let b_id = modules
.get_id("file:///b.js", ModuleType::JavaScript) .get_id("file:///b.js", AssertedModuleType::JavaScriptOrWasm)
.unwrap(); .unwrap();
let c_id = modules let c_id = modules
.get_id("file:///c.js", ModuleType::JavaScript) .get_id("file:///c.js", AssertedModuleType::JavaScriptOrWasm)
.unwrap(); .unwrap();
let d_id = modules let d_id = modules
.get_id("file:///d.js", ModuleType::JavaScript) .get_id("file:///d.js", AssertedModuleType::JavaScriptOrWasm)
.unwrap(); .unwrap();
assert_eq!( assert_eq!(
modules.get_requested_modules(a_id), modules.get_requested_modules(a_id),
Some(&vec![ Some(&vec![
ModuleRequest { ModuleRequest {
specifier: resolve_url("file:///b.js").unwrap(), specifier: resolve_url("file:///b.js").unwrap(),
expected_module_type: ModuleType::JavaScript, asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
}, },
ModuleRequest { ModuleRequest {
specifier: resolve_url("file:///c.js").unwrap(), specifier: resolve_url("file:///c.js").unwrap(),
expected_module_type: ModuleType::JavaScript, asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
}, },
]) ])
); );
@ -1371,14 +1424,14 @@ import "/a.js";
modules.get_requested_modules(b_id), modules.get_requested_modules(b_id),
Some(&vec![ModuleRequest { Some(&vec![ModuleRequest {
specifier: resolve_url("file:///c.js").unwrap(), specifier: resolve_url("file:///c.js").unwrap(),
expected_module_type: ModuleType::JavaScript, asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
},]) },])
); );
assert_eq!( assert_eq!(
modules.get_requested_modules(c_id), modules.get_requested_modules(c_id),
Some(&vec![ModuleRequest { Some(&vec![ModuleRequest {
specifier: resolve_url("file:///d.js").unwrap(), specifier: resolve_url("file:///d.js").unwrap(),
expected_module_type: ModuleType::JavaScript, asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
},]) },])
); );
assert_eq!(modules.get_requested_modules(d_id), Some(&vec![])); assert_eq!(modules.get_requested_modules(d_id), Some(&vec![]));
@ -1476,7 +1529,7 @@ import "/a.js";
imports, imports,
Some(&vec![ModuleRequest { Some(&vec![ModuleRequest {
specifier: resolve_url("file:///b.js").unwrap(), specifier: resolve_url("file:///b.js").unwrap(),
expected_module_type: ModuleType::JavaScript, asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
},]) },])
); );
@ -1581,7 +1634,7 @@ import "/a.js";
imports, imports,
Some(&vec![ModuleRequest { Some(&vec![ModuleRequest {
specifier: resolve_url("file:///b.json").unwrap(), specifier: resolve_url("file:///b.json").unwrap(),
expected_module_type: ModuleType::Json, asserted_module_type: AssertedModuleType::Json,
},]) },])
); );
@ -1900,18 +1953,19 @@ import "/a.js";
let modules = module_map_rc.borrow(); let modules = module_map_rc.borrow();
assert_eq!( assert_eq!(
modules.get_id("file:///circular1.js", ModuleType::JavaScript), modules
.get_id("file:///circular1.js", AssertedModuleType::JavaScriptOrWasm),
Some(circular1_id) Some(circular1_id)
); );
let circular2_id = modules let circular2_id = modules
.get_id("file:///circular2.js", ModuleType::JavaScript) .get_id("file:///circular2.js", AssertedModuleType::JavaScriptOrWasm)
.unwrap(); .unwrap();
assert_eq!( assert_eq!(
modules.get_requested_modules(circular1_id), modules.get_requested_modules(circular1_id),
Some(&vec![ModuleRequest { Some(&vec![ModuleRequest {
specifier: resolve_url("file:///circular2.js").unwrap(), specifier: resolve_url("file:///circular2.js").unwrap(),
expected_module_type: ModuleType::JavaScript, asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
}]) }])
); );
@ -1919,26 +1973,26 @@ import "/a.js";
modules.get_requested_modules(circular2_id), modules.get_requested_modules(circular2_id),
Some(&vec![ModuleRequest { Some(&vec![ModuleRequest {
specifier: resolve_url("file:///circular3.js").unwrap(), specifier: resolve_url("file:///circular3.js").unwrap(),
expected_module_type: ModuleType::JavaScript, asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
}]) }])
); );
assert!(modules assert!(modules
.get_id("file:///circular3.js", ModuleType::JavaScript) .get_id("file:///circular3.js", AssertedModuleType::JavaScriptOrWasm)
.is_some()); .is_some());
let circular3_id = modules let circular3_id = modules
.get_id("file:///circular3.js", ModuleType::JavaScript) .get_id("file:///circular3.js", AssertedModuleType::JavaScriptOrWasm)
.unwrap(); .unwrap();
assert_eq!( assert_eq!(
modules.get_requested_modules(circular3_id), modules.get_requested_modules(circular3_id),
Some(&vec![ Some(&vec![
ModuleRequest { ModuleRequest {
specifier: resolve_url("file:///circular1.js").unwrap(), specifier: resolve_url("file:///circular1.js").unwrap(),
expected_module_type: ModuleType::JavaScript, asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
}, },
ModuleRequest { ModuleRequest {
specifier: resolve_url("file:///circular2.js").unwrap(), specifier: resolve_url("file:///circular2.js").unwrap(),
expected_module_type: ModuleType::JavaScript, asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
} }
]) ])
); );
@ -1957,61 +2011,72 @@ import "/a.js";
..Default::default() ..Default::default()
}); });
let fut = let fut = async move {
async move { let spec = resolve_url("file:///redirect1.js").unwrap();
let spec = resolve_url("file:///redirect1.js").unwrap(); let result = runtime.load_main_module(&spec, None).await;
let result = runtime.load_main_module(&spec, None).await; assert!(result.is_ok());
assert!(result.is_ok()); let redirect1_id = result.unwrap();
let redirect1_id = result.unwrap(); let _ = runtime.mod_evaluate(redirect1_id);
let _ = runtime.mod_evaluate(redirect1_id); runtime.run_event_loop(false).await.unwrap();
runtime.run_event_loop(false).await.unwrap(); let l = loads.lock();
let l = loads.lock(); assert_eq!(
assert_eq!( l.to_vec(),
l.to_vec(), vec![
vec![ "file:///redirect1.js",
"file:///redirect1.js", "file:///redirect2.js",
"file:///redirect2.js", "file:///dir/redirect3.js"
"file:///dir/redirect3.js" ]
] );
);
let module_map_rc = JsRuntime::module_map(runtime.v8_isolate()); let module_map_rc = JsRuntime::module_map(runtime.v8_isolate());
let modules = module_map_rc.borrow(); let modules = module_map_rc.borrow();
assert_eq!( assert_eq!(
modules.get_id("file:///redirect1.js", ModuleType::JavaScript), modules
Some(redirect1_id) .get_id("file:///redirect1.js", AssertedModuleType::JavaScriptOrWasm),
); Some(redirect1_id)
);
let redirect2_id = modules let redirect2_id = modules
.get_id("file:///dir/redirect2.js", ModuleType::JavaScript) .get_id(
.unwrap(); "file:///dir/redirect2.js",
assert!( AssertedModuleType::JavaScriptOrWasm,
modules.is_alias("file:///redirect2.js", ModuleType::JavaScript) )
); .unwrap();
assert!( assert!(modules.is_alias(
!modules.is_alias("file:///dir/redirect2.js", ModuleType::JavaScript) "file:///redirect2.js",
); AssertedModuleType::JavaScriptOrWasm
assert_eq!( ));
modules.get_id("file:///redirect2.js", ModuleType::JavaScript), assert!(!modules.is_alias(
Some(redirect2_id) "file:///dir/redirect2.js",
); AssertedModuleType::JavaScriptOrWasm
));
assert_eq!(
modules
.get_id("file:///redirect2.js", AssertedModuleType::JavaScriptOrWasm),
Some(redirect2_id)
);
let redirect3_id = modules let redirect3_id = modules
.get_id("file:///redirect3.js", ModuleType::JavaScript) .get_id("file:///redirect3.js", AssertedModuleType::JavaScriptOrWasm)
.unwrap(); .unwrap();
assert!( assert!(modules.is_alias(
modules.is_alias("file:///dir/redirect3.js", ModuleType::JavaScript) "file:///dir/redirect3.js",
); AssertedModuleType::JavaScriptOrWasm
assert!( ));
!modules.is_alias("file:///redirect3.js", ModuleType::JavaScript) assert!(!modules.is_alias(
); "file:///redirect3.js",
assert_eq!( AssertedModuleType::JavaScriptOrWasm
modules.get_id("file:///dir/redirect3.js", ModuleType::JavaScript), ));
Some(redirect3_id) assert_eq!(
); modules.get_id(
} "file:///dir/redirect3.js",
.boxed_local(); AssertedModuleType::JavaScriptOrWasm
),
Some(redirect3_id)
);
}
.boxed_local();
futures::executor::block_on(fut); futures::executor::block_on(fut);
} }
@ -2122,17 +2187,20 @@ if (import.meta.url != 'file:///main_with_code.js') throw Error();
let modules = module_map_rc.borrow(); let modules = module_map_rc.borrow();
assert_eq!( assert_eq!(
modules.get_id("file:///main_with_code.js", ModuleType::JavaScript), modules.get_id(
"file:///main_with_code.js",
AssertedModuleType::JavaScriptOrWasm
),
Some(main_id) Some(main_id)
); );
let b_id = modules let b_id = modules
.get_id("file:///b.js", ModuleType::JavaScript) .get_id("file:///b.js", AssertedModuleType::JavaScriptOrWasm)
.unwrap(); .unwrap();
let c_id = modules let c_id = modules
.get_id("file:///c.js", ModuleType::JavaScript) .get_id("file:///c.js", AssertedModuleType::JavaScriptOrWasm)
.unwrap(); .unwrap();
let d_id = modules let d_id = modules
.get_id("file:///d.js", ModuleType::JavaScript) .get_id("file:///d.js", AssertedModuleType::JavaScriptOrWasm)
.unwrap(); .unwrap();
assert_eq!( assert_eq!(
@ -2140,11 +2208,11 @@ if (import.meta.url != 'file:///main_with_code.js') throw Error();
Some(&vec![ Some(&vec![
ModuleRequest { ModuleRequest {
specifier: resolve_url("file:///b.js").unwrap(), specifier: resolve_url("file:///b.js").unwrap(),
expected_module_type: ModuleType::JavaScript, asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
}, },
ModuleRequest { ModuleRequest {
specifier: resolve_url("file:///c.js").unwrap(), specifier: resolve_url("file:///c.js").unwrap(),
expected_module_type: ModuleType::JavaScript, asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
} }
]) ])
); );
@ -2152,14 +2220,14 @@ if (import.meta.url != 'file:///main_with_code.js') throw Error();
modules.get_requested_modules(b_id), modules.get_requested_modules(b_id),
Some(&vec![ModuleRequest { Some(&vec![ModuleRequest {
specifier: resolve_url("file:///c.js").unwrap(), specifier: resolve_url("file:///c.js").unwrap(),
expected_module_type: ModuleType::JavaScript, asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
}]) }])
); );
assert_eq!( assert_eq!(
modules.get_requested_modules(c_id), modules.get_requested_modules(c_id),
Some(&vec![ModuleRequest { Some(&vec![ModuleRequest {
specifier: resolve_url("file:///d.js").unwrap(), specifier: resolve_url("file:///d.js").unwrap(),
expected_module_type: ModuleType::JavaScript, asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
}]) }])
); );
assert_eq!(modules.get_requested_modules(d_id), Some(&vec![])); assert_eq!(modules.get_requested_modules(d_id), Some(&vec![]));