| Index: test/webkit/toString-prefix-postfix-preserve-parens.js | 
| diff --git a/test/webkit/toString-prefix-postfix-preserve-parens.js b/test/webkit/toString-prefix-postfix-preserve-parens.js | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..192f278a11657b2a12db7f5e7734f3d1790dac68 | 
| --- /dev/null | 
| +++ b/test/webkit/toString-prefix-postfix-preserve-parens.js | 
| @@ -0,0 +1,154 @@ | 
| +// Copyright 2013 the V8 project authors. All rights reserved. | 
| +// Copyright (C) 2005, 2006, 2007, 2008, 2009 Apple Inc. All rights reserved. | 
| +// | 
| +// Redistribution and use in source and binary forms, with or without | 
| +// modification, are permitted provided that the following conditions | 
| +// are met: | 
| +// 1.  Redistributions of source code must retain the above copyright | 
| +//     notice, this list of conditions and the following disclaimer. | 
| +// 2.  Redistributions in binary form must reproduce the above copyright | 
| +//     notice, this list of conditions and the following disclaimer in the | 
| +//     documentation and/or other materials provided with the distribution. | 
| +// | 
| +// THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS'' AND ANY | 
| +// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | 
| +// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | 
| +// DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS BE LIABLE FOR ANY | 
| +// DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | 
| +// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | 
| +// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON | 
| +// ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 
| +// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | 
| +// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 
| + | 
| +description( | 
| +"This test checks that toString() round-trip on a function that has prefix, postfix and typeof operators applied to group expression will not remove the grouping. Also checks that evaluation of such a expression produces run-time exception" | 
| +); | 
| + | 
| +function postfix_should_preserve_parens(x, y, z) { | 
| +    (x, y)++; | 
| +    return y; | 
| +} | 
| + | 
| +function prefix_should_preserve_parens(x, y, z) { | 
| +    ++(x, y); | 
| +    return x; | 
| + | 
| +} | 
| + | 
| +function both_should_preserve_parens(x, y, z) { | 
| +    ++(x, y)--; | 
| +    return x; | 
| + | 
| +} | 
| + | 
| +function postfix_should_preserve_parens_multi(x, y, z) { | 
| +    (((x, y)))--; | 
| +    return x; | 
| +} | 
| + | 
| +function prefix_should_preserve_parens_multi(x, y, z) { | 
| +    --(((x, y))); | 
| +    return x; | 
| +} | 
| + | 
| +function both_should_preserve_parens_multi(x, y, z) { | 
| +    ++(((x, y)))--; | 
| +    return x; | 
| +} | 
| + | 
| +function postfix_should_preserve_parens_multi1(x, y, z) { | 
| +    (((x)), y)--; | 
| +    return x; | 
| +} | 
| + | 
| +function prefix_should_preserve_parens_multi1(x, y, z) { | 
| +    --(((x)), y); | 
| +    return x; | 
| +} | 
| + | 
| +function prefix_should_preserve_parens_multi2(x, y, z) { | 
| +    var z = 0; | 
| +    --(((x), y), z); | 
| +    return x; | 
| +} | 
| + | 
| +function postfix_should_preserve_parens_multi2(x, y, z) { | 
| +    var z = 0; | 
| +    (((x), y) ,z)++; | 
| +    return x; | 
| +} | 
| + | 
| +// if these return a variable (such as y) instead of | 
| +// the result of typeof, this means that the parenthesis | 
| +// got lost somewhere. | 
| +function typeof_should_preserve_parens(x, y, z) { | 
| +    return typeof (x, y); | 
| +} | 
| + | 
| +function typeof_should_preserve_parens1(x, y, z) { | 
| +    return typeof ((x, y)); | 
| +} | 
| + | 
| +function typeof_should_preserve_parens2(x, y, z) { | 
| +    var z = 33; | 
| +    return typeof (z, (x, y)); | 
| +} | 
| + | 
| +function typeof_should_preserve_parens_multi(x, y, z) { | 
| +    var z = 33; | 
| +    return typeof ((z,(((x, y))))); | 
| +} | 
| + | 
| +unevalf = function(x) { return '(' + x.toString() + ')'; }; | 
| + | 
| +function testToString(fn) { | 
| +    // check that toString result evaluates to code that can be evaluated | 
| +    // this doesn't actually reveal the bug that this test is testing | 
| +    shouldBe("unevalf(eval(unevalf("+fn+")))", "unevalf(" + fn + ")"); | 
| + | 
| +    // check that grouping operator is still there (this test reveals the bug | 
| +    // but will create possible false negative if toString output changes in | 
| +    // the future) | 
| +    shouldBeTrue("/.*\\(+x\\)*, y\\)/.test(unevalf("+fn+"))"); | 
| + | 
| +} | 
| + | 
| +function testToStringAndRTFailure(fn) | 
| +{ | 
| +    testToString(fn); | 
| + | 
| +    // check that function call produces run-time exception | 
| +    shouldThrow(""+fn+ "(1, 2, 3);"); | 
| + | 
| +    // check that function call produces run-time exception after eval(unevalf) | 
| +    shouldThrow("eval(unevalf("+fn+ "))(1, 2, 3);"); | 
| +} | 
| + | 
| +function testToStringAndReturn(fn, p1, p2, retval) | 
| +{ | 
| + | 
| +    testToString(fn); | 
| + | 
| +    // check that function call produces correct result | 
| +    shouldBe("" + fn + "(" + p1 + ", " + p2 +");", retval); | 
| + | 
| +    // check that function call produces correct result after eval(unevalf) | 
| +    shouldBe("eval(unevalf("+fn+ "))" + "(" + p1 + ", " + p2 +");", retval); | 
| +} | 
| + | 
| + | 
| +testToStringAndRTFailure("prefix_should_preserve_parens"); | 
| +testToStringAndRTFailure("postfix_should_preserve_parens"); | 
| +testToStringAndRTFailure("both_should_preserve_parens"); | 
| +testToStringAndRTFailure("prefix_should_preserve_parens_multi"); | 
| +testToStringAndRTFailure("postfix_should_preserve_parens_multi"); | 
| +testToStringAndRTFailure("prefix_should_preserve_parens_multi1"); | 
| +testToStringAndRTFailure("postfix_should_preserve_parens_multi1"); | 
| +testToStringAndRTFailure("prefix_should_preserve_parens_multi2"); | 
| +testToStringAndRTFailure("postfix_should_preserve_parens_multi2"); | 
| + | 
| +testToStringAndReturn("typeof_should_preserve_parens", "'a'", 1, "'number'"); | 
| +testToStringAndReturn("typeof_should_preserve_parens1", "'a'", 1, "'number'"); | 
| +testToStringAndReturn("typeof_should_preserve_parens2", "'a'", 1, "'number'"); | 
| +testToStringAndReturn("typeof_should_preserve_parens_multi", "'a'", 1, "'number'"); | 
|  |