Tests failing with latest Closure Compiler snapshot
Description
Environment
Activity
data:image/s3,"s3://crabby-images/feb14/feb144667b530d4e2b9ae7459292881fa45bda54" alt=""
Mike Fikes July 4, 2018 at 12:05 PM
Fixed with upstream Closure Compiler patch https://github.com/google/closure-compiler/commit/79eac91661edabd48220ff54e24a0684f6120128
data:image/s3,"s3://crabby-images/feb14/feb144667b530d4e2b9ae7459292881fa45bda54" alt=""
Mike Fikes July 2, 2018 at 12:23 PM
Confirmed that this PR causes the ClojureScript compiler unit tests to pass https://github.com/google/closure-compiler/pull/3000
data:image/s3,"s3://crabby-images/feb14/feb144667b530d4e2b9ae7459292881fa45bda54" alt=""
Mike Fikes July 1, 2018 at 11:48 PM
Closure Compiler issue submitted: https://github.com/google/closure-compiler/issues/2999
data:image/s3,"s3://crabby-images/feb14/feb144667b530d4e2b9ae7459292881fa45bda54" alt=""
Mike Fikes July 1, 2018 at 11:17 PM
Perhaps this is a regression in Closure Compiler:
node_modules/lodash/isBuffer.js
contains this bit of code:
Previously this would be rewritten as (when copied to builds/out-adv/node_modules/lodash/isBuffer.js
):
but with the change in Closure Compiler this is now rewritten as the following:
In particular note that the sub-expression
becomes simply
with a dangling un-rewritten module
reference.
A theory is that Closure Compiler is looking for expressions involving module
to rewrite and misses or mishandles the bit of code in Lodash.
data:image/s3,"s3://crabby-images/feb14/feb144667b530d4e2b9ae7459292881fa45bda54" alt=""
Mike Fikes July 1, 2018 at 10:43 PM
Bisected to this upstream commit https://github.com/google/closure-compiler/commit/3edafa4c1168d29894ad2ca6021eb72be6e73af5
Details
Details
Assignee
data:image/s3,"s3://crabby-images/feb14/feb144667b530d4e2b9ae7459292881fa45bda54" alt=""
Reporter
data:image/s3,"s3://crabby-images/feb14/feb144667b530d4e2b9ae7459292881fa45bda54" alt=""
Priority
data:image/s3,"s3://crabby-images/679c7/679c72b42e22905499f551722581d6911fc73eb2" alt=""
If you use the latest Closure Compiler, tests will break with
ReferenceError: module is not defined
.Repro:
script/bootstrap --closure-compiler-snapshot
script/test
Note that this broke as of
closure-compiler-1.0-20180629.155739-322.jar
.