| Index: test/webkit/array-filter.js | 
| diff --git a/test/webkit/array-filter.js b/test/webkit/array-filter.js | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..d0640c23e6bf78a439444c1628eadd8893b39a8f | 
| --- /dev/null | 
| +++ b/test/webkit/array-filter.js | 
| @@ -0,0 +1,100 @@ | 
| +// 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("Tests for Array.prototype.filter"); | 
| + | 
| +function passUndefined(element, index, array) { | 
| +    return typeof element === "undefined"; | 
| +} | 
| +function passEven(a) { | 
| +    return !(a & 1); | 
| +} | 
| +function passAfter5(element, index) { | 
| +    return index >= 5; | 
| +} | 
| +var sparseArrayLength = 10100; | 
| +mixPartialAndFast = new Array(sparseArrayLength); | 
| +mixPartialAndFast[sparseArrayLength - 1] = sparseArrayLength - 1; | 
| +for(var i = 0; i < 10; i++) | 
| +    mixPartialAndFast[i] = i; | 
| +function toObject(array) { | 
| +    var result = {}; | 
| +    result.length = array.length; | 
| +    for (var i in array) | 
| +        result[i] = array[i]; | 
| +    result.filter=Array.prototype.filter; | 
| +    return result; | 
| +} | 
| +function reverseInsertionOrder(array) { | 
| +    var obj = toObject(array); | 
| +    var props = []; | 
| +    for (var i in obj) | 
| +        props.push(i); | 
| +    var result = {}; | 
| +    for (var i = props.length - 1; i >= 0; i--) | 
| +        result[props[i]] = obj[props[i]]; | 
| +    result.filter=Array.prototype.filter; | 
| +    return result; | 
| +} | 
| +function filterLog(f) { | 
| +    return function(i,j) { | 
| +        try { | 
| +        debug([i,j,arguments[2].toString().substring(0,20)].toString()); | 
| +        return f.apply(this, arguments); | 
| +        } catch(e) { | 
| +            console.error(e); | 
| +        } | 
| +    } | 
| +} | 
| + | 
| +shouldBe("[undefined].filter(passUndefined)", "[undefined]"); | 
| +shouldBe("(new Array(20)).filter(passUndefined)", "[]"); | 
| +shouldBe("[0,1,2,3,4,5,6,7,8,9].filter(passEven)", "[0,2,4,6,8]"); | 
| +shouldBe("[0,1,2,3,4,5,6,7,8,9].filter(passAfter5)", "[5,6,7,8,9]"); | 
| +shouldBe("mixPartialAndFast.filter(passAfter5)", "[5,6,7,8,9,sparseArrayLength-1]"); | 
| + | 
| +// Generic Object | 
| +shouldBe("toObject([undefined]).filter(passUndefined)", "[undefined]"); | 
| +shouldBe("toObject(new Array(20)).filter(passUndefined)", "[]"); | 
| +shouldBe("toObject([0,1,2,3,4,5,6,7,8,9]).filter(passEven)", "[0,2,4,6,8]"); | 
| +shouldBe("toObject([0,1,2,3,4,5,6,7,8,9]).filter(passAfter5)", "[5,6,7,8,9]"); | 
| +shouldBe("toObject(mixPartialAndFast).filter(passAfter5)", "[5,6,7,8,9,sparseArrayLength-1]"); | 
| + | 
| +// Reversed generic Object | 
| +shouldBe("reverseInsertionOrder([undefined]).filter(passUndefined)", "[undefined]"); | 
| +shouldBe("reverseInsertionOrder(new Array(20)).filter(passUndefined)", "[]"); | 
| +shouldBe("reverseInsertionOrder([0,1,2,3,4,5,6,7,8,9]).filter(passEven)", "[0,2,4,6,8]"); | 
| +shouldBe("reverseInsertionOrder([0,1,2,3,4,5,6,7,8,9]).filter(passAfter5)", "[5,6,7,8,9]"); | 
| +shouldBe("reverseInsertionOrder(mixPartialAndFast).filter(passAfter5)", "[5,6,7,8,9,sparseArrayLength-1]"); | 
| + | 
| +// Log evaluation order | 
| +shouldBe("reverseInsertionOrder([undefined]).filter(filterLog(passUndefined))", "[undefined]"); | 
| +shouldBe("reverseInsertionOrder(new Array(20)).filter(filterLog(passUndefined))", "[]"); | 
| +shouldBe("reverseInsertionOrder([0,1,2,3,4]).filter(filterLog(passEven))", "[0,2,4]"); | 
| +shouldBe("reverseInsertionOrder(mixPartialAndFast).filter(filterLog(passAfter5))", "[5,6,7,8,9,sparseArrayLength-1]"); | 
| +shouldBe("([undefined]).filter(filterLog(passUndefined))", "[undefined]"); | 
| +shouldBe("(new Array(20)).filter(filterLog(passUndefined))", "[]"); | 
| +shouldBe("([0,1,2,3,4]).filter(filterLog(passEven))", "[0,2,4]"); | 
| +shouldBe("(mixPartialAndFast).filter(filterLog(passAfter5))", "[5,6,7,8,9,sparseArrayLength-1]"); | 
| + | 
| +shouldBe("[1,2,3].filter(function(i,j,k,l,m){ return m=!m; })", "[1,2,3]") | 
|  |