diff --git a/scripts/closure-test.sh b/scripts/closure-test.sh index e23db8f5fa6..6eee4f02280 100755 --- a/scripts/closure-test.sh +++ b/scripts/closure-test.sh @@ -24,7 +24,6 @@ function log() { CLOSURE_TMP=.closure-tmp CLOSURE_PKGDIR=$CLOSURE_TMP/packages -JS_SRCS=$CLOSURE_PKGDIR/**/*.js CLOSURIZED_PKGS=$(node -e "console.log(require('./package.json').closureWhitelist.join(' '))") if [ -z "$CLOSURIZED_PKGS" ]; then @@ -42,7 +41,7 @@ done rm -fr $CLOSURE_PKGDIR/**/{node_modules,dist} log "Rewriting all import statements to be closure compatible" -node scripts/rewrite-import-statements-for-closure-test.js $CLOSURE_PKGDIR +node scripts/rewrite-decl-statements-for-closure-test.js $CLOSURE_PKGDIR log "Testing packages" echo '' @@ -56,7 +55,7 @@ for pkg in $CLOSURIZED_PKGS; do CMD="java -jar node_modules/google-closure-compiler/compiler.jar \ --externs closure_externs.js \ --compilation_level ADVANCED \ - --js $JS_SRCS \ + --js $(find $CLOSURE_PKGDIR -type f -name "*.js") \ --language_out ECMASCRIPT5_STRICT \ --dependency_mode STRICT \ --module_resolution LEGACY \ diff --git a/scripts/rewrite-import-statements-for-closure-test.js b/scripts/rewrite-decl-statements-for-closure-test.js similarity index 77% rename from scripts/rewrite-import-statements-for-closure-test.js rename to scripts/rewrite-decl-statements-for-closure-test.js index bbc141ffe93..de57e1d87e3 100644 --- a/scripts/rewrite-import-statements-for-closure-test.js +++ b/scripts/rewrite-decl-statements-for-closure-test.js @@ -58,6 +58,7 @@ * - https://github.com/google/closure-compiler/issues/2386 * * Note that for third-party modules, they must be defined in closure_externs.js. See that file for more info. + * Also note that this works on `export .... from ...` as well. */ const assert = require('assert'); @@ -94,8 +95,10 @@ function transform(srcFile, rootDir) { }); traverse(ast, { - 'ImportDeclaration'({node}) { - rewriteImportDeclaration(node, srcFile, rootDir); + 'ImportDeclaration|ExportNamedDeclaration'({node}) { + if (node.source) { + rewriteDeclarationSource(node, srcFile, rootDir); + } }, }); @@ -113,38 +116,39 @@ function transform(srcFile, rootDir) { console.log(`[rewrite] ${srcFile}`); } -function rewriteImportDeclaration(node, srcFile, rootDir) { - let importSource = node.source.value; - const pathParts = importSource.split('/'); +function rewriteDeclarationSource(node, srcFile, rootDir) { + let source = node.source.value; + const pathParts = source.split('/'); const isMDCImport = pathParts[0] === '@material'; if (isMDCImport) { const modName = pathParts[1]; // @material/ const atMaterialReplacementPath = `${rootDir}/mdc-${modName}`; - const rewrittenImportSource = [atMaterialReplacementPath].concat(pathParts.slice(2)).join('/'); - importSource = rewrittenImportSource; + const rewrittenSource = [atMaterialReplacementPath].concat(pathParts.slice(2)).join('/'); + source = rewrittenSource; } - patchNodeForImportSource(importSource, srcFile, node); + patchNodeForDeclarationSource(source, srcFile, rootDir, node); } -function patchNodeForImportSource(importSource, srcFile, node) { - let resolvedImportSource = importSource; +function patchNodeForDeclarationSource(source, srcFile, rootDir, node) { + let resolvedSource = source; // See: https://nodejs.org/api/modules.html#modules_all_together (step 3) - const wouldLoadAsFileOrDir = ['./', '/', '../'].some((s) => importSource.indexOf(s) === 0); + const wouldLoadAsFileOrDir = ['./', '/', '../'].some((s) => source.indexOf(s) === 0); const isThirdPartyModule = !wouldLoadAsFileOrDir; if (isThirdPartyModule) { - assert(importSource.indexOf('@material') < 0, '@material/* import sources should have already been rewritten'); + assert(source.indexOf('@material') < 0, '@material/* import sources should have already been rewritten'); patchDefaultImportIfNeeded(node); - resolvedImportSource = `goog:mdc.thirdparty.${camelCase(importSource)}`; + resolvedSource = `goog:mdc.thirdparty.${camelCase(source)}`; } else { - const needsClosureModuleRootResolution = path.isAbsolute(importSource); + const normPath = path.normalize(path.dirname(srcFile), source); + const needsClosureModuleRootResolution = path.isAbsolute(source) || fs.statSync(normPath).isDirectory(); if (needsClosureModuleRootResolution) { - resolvedImportSource = path.relative(rootDir, resolve.sync(importSource, { + resolvedSource = path.relative(rootDir, resolve.sync(source, { basedir: path.dirname(srcFile), })); } } - node.source = t.stringLiteral(resolvedImportSource); + node.source = t.stringLiteral(resolvedSource); } function patchDefaultImportIfNeeded(node) {