swc/crates/swc_ecma_transforms_module/tests/path_node.rs
Donny/강동윤 7e8d72d03b
feat(es/module): Add an option to make resolver fully resolve index.js (#7945)
**Description:**

 - `jsc.module.resolveFully` is added to support resolving as `.js`.

**Related issue:**

 - Closes #7861
 - Closes #7898
2023-09-14 07:17:23 +00:00

145 lines
4.0 KiB
Rust

use std::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<NodeModulesResolver>;
#[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")
.canonicalize()
.unwrap();
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![dir
.join("input")
.join("packages")
.join("a")
.join("src")
.join("index.ts")
.display()
.to_string()],
);
paths.insert(
"@print/b".into(),
vec![dir
.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<TsConfigResolver<NodeModulesResolver>>;
fn paths_resolver(base_dir: &Path, rules: Vec<(String, Vec<String>)>) -> JscPathsProvider {
let base_dir = base_dir
.to_path_buf()
.canonicalize()
.expect("failed to canonicalize");
dbg!(&base_dir);
NodeImportResolver::with_config(
TsConfigResolver::new(
NodeModulesResolver::new(swc_ecma_loader::TargetEnv::Node, Default::default(), true),
base_dir.clone(),
rules,
),
swc_ecma_transforms_module::path::Config {
base_dir: Some(base_dir),
resolve_fully: false,
},
)
}
#[derive(Deserialize)]
#[serde(rename_all = "camelCase")]
struct TestConfig {
#[serde(default)]
base_url: Option<PathBuf>,
#[serde(default)]
input_file: Option<String>,
#[serde(default)]
paths: IndexMap<String, Vec<String>>,
}
#[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::<TestConfig>(&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(),
);
}