- rename `screw_ie8` to `ie8` - rename `mangle.except` to `mangle.reserved` - rename `mangle.properties.ignore_quoted` to `mangle.properties.keep_quoted` - compact `sourceMap` options - more stringent verification on input `options` - toplevel shorthands - `ie8` - `keep_fnames` - `toplevel` - `warnings` - support arrays and unquoted string values on CLI - drop `fromString` from `minify()` - `minify()` no longer handles any `fs` operations - unify order of operations for `mangle_properties()` on CLI & API - `bin/uglifyjs` used to `mangle_properties()` before even `Compressor` - `minify()` used to `mangle_properties()` after `Compressor` but before `mangle_names()` - both will now do `Compressor`, `mangle_names()` then `mangle_properties()` - `options.parse` / `--parse` for parser options beyond `bare_returns` - add `mangle.properties.builtins` to disable built-in reserved list - disable with `--mangle-props builtins` on CLI - `warnings` now off by default - add `--warn` and `--verbose` on CLI - drop `--enclose` - drop `--export-all` - drop `--reserved-file` - use `--mangle reserved` instead - drop `--reserve-domprops` - enabled by default, disable with `--mangle-props domprops` - drop `--prefix` - use `--source-map base` instead - drop `--lint` - remove `bin/extract-props.js` - limit exposure of internal APIs - update documentations closes #96 closes #102 closes #136 closes #166 closes #243 closes #254 closes #261 closes #311 closes #700 closes #748 closes #912 closes #1072 closes #1366 fixes #101 fixes #123 fixes #124 fixes #263 fixes #379 fixes #419 fixes #423 fixes #461 fixes #465 fixes #576 fixes #737 fixes #772 fixes #958 fixes #1036 fixes #1142 fixes #1175 fixes #1220 fixes #1223 fixes #1280 fixes #1359 fixes #1368
125 lines
4.0 KiB
JavaScript
125 lines
4.0 KiB
JavaScript
var assert = require("assert");
|
|
var exec = require("child_process").exec;
|
|
var uglify = require("../../");
|
|
|
|
describe("spidermonkey export/import sanity test", function() {
|
|
it("should produce a functional build when using --self with spidermonkey", function(done) {
|
|
this.timeout(20000);
|
|
|
|
var uglifyjs = '"' + process.argv[0] + '" bin/uglifyjs';
|
|
var command = uglifyjs + " --self -cm --wrap SpiderUglify -o spidermonkey | " +
|
|
uglifyjs + " -p spidermonkey -cm";
|
|
|
|
exec(command, function(err, stdout) {
|
|
if (err) throw err;
|
|
|
|
eval(stdout);
|
|
assert.strictEqual(typeof SpiderUglify, "object");
|
|
|
|
var ast = SpiderUglify.parse("foo([true,,2+3]);");
|
|
assert.strictEqual(true, ast instanceof SpiderUglify.AST_Node);
|
|
|
|
ast.figure_out_scope();
|
|
ast = SpiderUglify.Compressor({}).compress(ast);
|
|
assert.strictEqual(true, ast instanceof SpiderUglify.AST_Node);
|
|
|
|
var stream = SpiderUglify.OutputStream({});
|
|
ast.print(stream);
|
|
var code = stream.toString();
|
|
assert.strictEqual(code, "foo([!0,,5]);");
|
|
|
|
done();
|
|
});
|
|
});
|
|
|
|
it("Should judge between directives and strings correctly on import", function() {
|
|
var tests = [
|
|
{
|
|
input: '"use strict";;"use sloppy"',
|
|
directives: 1,
|
|
strings: 1
|
|
},
|
|
{
|
|
input: ';"use strict"',
|
|
directives: 0,
|
|
strings: 1
|
|
},
|
|
{
|
|
input: '"use strict"; "use something else";',
|
|
directives: 2,
|
|
strings: 0
|
|
},
|
|
{
|
|
input: 'function foo() {"use strict";;"use sloppy" }',
|
|
directives: 1,
|
|
strings: 1
|
|
},
|
|
{
|
|
input: 'function foo() {;"use strict" }',
|
|
directives: 0,
|
|
strings: 1
|
|
},
|
|
{
|
|
input: 'function foo() {"use strict"; "use something else"; }',
|
|
directives: 2,
|
|
strings: 0
|
|
},
|
|
{
|
|
input: 'var foo = function() {"use strict";;"use sloppy" }',
|
|
directives: 1,
|
|
strings: 1
|
|
},
|
|
{
|
|
input: 'var foo = function() {;"use strict" }',
|
|
directives: 0,
|
|
strings: 1
|
|
},
|
|
{
|
|
input: 'var foo = function() {"use strict"; "use something else"; }',
|
|
directives: 2,
|
|
strings: 0
|
|
},
|
|
{
|
|
input: '{"use strict";;"use sloppy" }',
|
|
directives: 0,
|
|
strings: 2
|
|
},
|
|
{
|
|
input: '{;"use strict" }',
|
|
directives: 0,
|
|
strings: 1
|
|
},
|
|
{
|
|
input: '{"use strict"; "use something else"; }',
|
|
directives: 0,
|
|
strings: 2
|
|
}
|
|
];
|
|
|
|
var counter_directives;
|
|
var counter_strings;
|
|
|
|
var checkWalker = new uglify.TreeWalker(function(node, descend) {
|
|
if (node instanceof uglify.AST_String) {
|
|
counter_strings++;
|
|
} else if (node instanceof uglify.AST_Directive) {
|
|
counter_directives++;
|
|
}
|
|
});
|
|
|
|
for (var i = 0; i < tests.length; i++) {
|
|
counter_directives = 0;
|
|
counter_strings = 0;
|
|
|
|
var ast = uglify.parse(tests[i].input);
|
|
var moz_ast = ast.to_mozilla_ast();
|
|
var from_moz_ast = uglify.AST_Node.from_mozilla_ast(moz_ast);
|
|
|
|
from_moz_ast.walk(checkWalker);
|
|
|
|
assert.strictEqual(counter_directives, tests[i].directives, "Directives count mismatch for test " + tests[i].input);
|
|
assert.strictEqual(counter_strings, tests[i].strings, "String count mismatch for test " + tests[i].input);
|
|
}
|
|
});
|
|
});
|