use std::{ env::current_dir, path::{Path, PathBuf}, }; use indexmap::IndexMap; use serde::Deserialize; use swc_common::FileName; use swc_ecma_loader::resolvers::{node::NodeModulesResolver, tsc::TsConfigResolver}; use swc_ecma_parser::Syntax; use swc_ecma_transforms_module::{ path::{ImportResolver, NodeImportResolver}, rewriter::import_rewriter, }; use swc_ecma_transforms_testing::test_fixture; use testing::run_test2; type TestProvider = NodeImportResolver; #[test] fn node_modules() { let provider = TestProvider::default(); run_test2(false, |cm, _| { let fm = cm.new_source_file(FileName::Real("foo".into()), "".into()); let resolved = provider .resolve_import(&fm.name, "core-js") .expect("should success"); assert_eq!(&*resolved, "core-js"); Ok(()) }) .unwrap(); } #[test] fn issue_4730() { let dir = Path::new("tests/fixture-manual/issue-4730"); let input_dir = dir.join("input"); let output_dir = dir.join("output"); test_fixture( Syntax::default(), &|_| { let mut paths = IndexMap::new(); paths.insert( "@print/a".into(), vec![current_dir() .unwrap() .join("tests") .join("fixture-manual") .join("issue-4730") .join("input") .join("packages") .join("a") .join("src") .join("index.ts") .display() .to_string()], ); paths.insert( "@print/b".into(), vec![current_dir() .unwrap() .join("tests") .join("fixture-manual") .join("issue-4730") .join("input") .join("packages") .join("b") .join("src") .join("index.ts") .display() .to_string()], ); let rules = paths.into_iter().collect(); let resolver = paths_resolver(&input_dir, rules); import_rewriter( FileName::Real(input_dir.join("src").join("index.js")), resolver, ) }, &input_dir.join("src").join("index.js"), &output_dir.join("index.js"), Default::default(), ); } type JscPathsProvider = NodeImportResolver>; fn paths_resolver( base_url: impl AsRef, rules: Vec<(String, Vec)>, ) -> JscPathsProvider { let base_url = base_url.as_ref().to_path_buf(); dbg!(&base_url); NodeImportResolver::new(TsConfigResolver::new( NodeModulesResolver::new(swc_ecma_loader::TargetEnv::Node, Default::default(), true), base_url, rules, )) } #[derive(Deserialize)] #[serde(rename_all = "camelCase")] struct TestConfig { #[serde(default)] base_url: Option, #[serde(default)] input_file: Option, #[serde(default)] paths: IndexMap>, } #[testing::fixture("tests/paths/**/input")] fn fixture(input_dir: PathBuf) { let output_dir = input_dir.parent().unwrap().join("output"); let paths_json_path = input_dir.join("config.json"); let paths_json = std::fs::read_to_string(paths_json_path).unwrap(); let config = serde_json::from_str::(&paths_json).unwrap(); let index_path = input_dir.join(config.input_file.as_deref().unwrap_or("index.ts")); test_fixture( Syntax::default(), &|_| { let rules = config.paths.clone().into_iter().collect(); let resolver = paths_resolver(config.base_url.clone().unwrap_or(input_dir.clone()), rules); import_rewriter(FileName::Real(index_path.clone()), resolver) }, &index_path, &output_dir.join("index.ts"), Default::default(), ); }