| Index: test/webkit/dfg-cfg-simplify-eliminate-set-local-type-check-then-typeof.js
|
| diff --git a/test/webkit/concat-while-having-a-bad-time.js b/test/webkit/dfg-cfg-simplify-eliminate-set-local-type-check-then-typeof.js
|
| similarity index 66%
|
| copy from test/webkit/concat-while-having-a-bad-time.js
|
| copy to test/webkit/dfg-cfg-simplify-eliminate-set-local-type-check-then-typeof.js
|
| index dfda1e08a0b36194b787a44ee12a9693acd8aeaf..bb4fee926139fecc1a727397ac8b2df54d8a3dd9 100644
|
| --- a/test/webkit/concat-while-having-a-bad-time.js
|
| +++ b/test/webkit/dfg-cfg-simplify-eliminate-set-local-type-check-then-typeof.js
|
| @@ -22,10 +22,33 @@
|
| // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
| description(
|
| -"Tests the behavior of Array.prototype.concat while the array is having a bad time due to one of the elements we are concatenating."
|
| +"Tests what happens when CFG simplification leads to the elimination of a set local that had a type check, and then we do a typeof on the value, which can be constant folded if the type check stays."
|
| );
|
|
|
| -Object.defineProperty(Array.prototype, 0, { writable: false });
|
| -shouldBe("[42].concat()", "[42]");
|
| +function foo(o) {
|
| + var x;
|
| + if (o.f)
|
| + x = o.g;
|
| + else
|
| + x = o.h;
|
| + return [typeof x, x - 1];
|
| +}
|
|
|
| +for (var i = 0; i < 500; ++i) {
|
| + var o = {f:foo};
|
| + var expectedFirst;
|
| + var expectedSecond;
|
| + if (i < 450) {
|
| + o.g = i;
|
| + expectedFirst = "\"number\"";
|
| + expectedSecond = "" + (i - 1);
|
| + } else {
|
| + o.g = "42";
|
| + expectedFirst = "\"string\"";
|
| + expectedSecond = "41";
|
| + }
|
| + var result = foo(o);
|
| + shouldBe("result[0]", expectedFirst);
|
| + shouldBe("result[1]", expectedSecond);
|
| +}
|
|
|
|
|