diff options
Diffstat (limited to 'test')
-rw-r--r-- | test/compress/drop-unused.js | 12 | ||||
-rw-r--r-- | test/compress/reduce_vars.js | 39 | ||||
-rw-r--r-- | test/sandbox.js | 4 |
3 files changed, 43 insertions, 12 deletions
diff --git a/test/compress/drop-unused.js b/test/compress/drop-unused.js index 2ef6f796..af792bfa 100644 --- a/test/compress/drop-unused.js +++ b/test/compress/drop-unused.js @@ -751,12 +751,12 @@ issue_1583: { expect: { function m(t) { (function(e) { - t = (function() { - return (function(a) { - return a; - })(function(a) {}); - })(); - })(); + t = e(); + })(function() { + return (function(a) { + return a; + })(function(a) {}); + }); } } } diff --git a/test/compress/reduce_vars.js b/test/compress/reduce_vars.js index 2a44492a..078de82d 100644 --- a/test/compress/reduce_vars.js +++ b/test/compress/reduce_vars.js @@ -1311,19 +1311,48 @@ iife_func_side_effects: { unused: true, } input: { + function x() { + console.log("x"); + } + function y() { + console.log("y"); + } + function z() { + console.log("z"); + } (function(a, b, c) { - return b(); + function y() { + console.log("FAIL"); + } + return y + b(); })(x(), function() { return y(); }, z()); } expect: { + function x() { + console.log("x"); + } + function y() { + console.log("y"); + } + function z() { + console.log("z"); + } (function(a, b, c) { - return function() { - return y(); - }(); - })(x(), 0, z()); + function y() { + console.log("FAIL"); + } + return y + b(); + })(x(), function() { + return y(); + }, z()); } + expect_stdout: [ + "x", + "z", + "y", + ] } issue_1595_1: { diff --git a/test/sandbox.js b/test/sandbox.js index 974f5211..ca1781c6 100644 --- a/test/sandbox.js +++ b/test/sandbox.js @@ -26,16 +26,18 @@ var FUNC_TOSTRING = [ " var i = this.name;", ' if (typeof i != "number") {', " i = ++id;", +].concat(Object.getOwnPropertyDescriptor(Function.prototype, "name").configurable ? [ ' Object.defineProperty(this, "name", {', " get: function() {", " return i;", " }", " });", +] : [], [ " }", ' return "[Function: " + i + "]";', " }", "}();", -].join("\n"); +]).join("\n"); exports.run_code = function(code) { var stdout = ""; var original_write = process.stdout.write; |