| // Copyright 2015 the V8 project authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| // Flags: --use-osr |
| |
| function foo(a) { |
| var sum = 0; |
| var inc = a ? 100 : 200; |
| for (var i = 0; i < 100000; i++) { |
| sum += inc; |
| } |
| return sum + inc; |
| } |
| |
| function bar(a) { |
| var sum = 0; |
| var inc = a ? 100 : 200; |
| var x = a ? 5 : 6; |
| var y = a ? 7 : 8; |
| for (var i = 0; i < 100000; i++) { |
| sum += inc; |
| } |
| return sum ? x : y; |
| } |
| |
| function baz(a) { |
| var limit = a ? 100001 : 100002; |
| var r = 1; |
| var x = a ? 1 : 2; |
| var y = a ? 3 : 4; |
| for (var i = 0; i < limit; i++) { |
| r = r * -1; |
| } |
| return r > 0 ? x == y : x != y; |
| } |
| |
| function qux(a) { |
| var limit = a ? 100001 : 100002; |
| var r = 1; |
| var x = a ? 1 : 2; |
| var y = a ? 3 : 4; |
| for (var i = 0; i < limit; i++) { |
| r = r * -1; |
| } |
| var w = r > 0 ? x : y; |
| var z = r > 0 ? y : x; |
| return w === z; |
| } |
| |
| function test(func, tv, fv) { |
| assertEquals(tv, func(true)); |
| assertEquals(fv, func(false)); |
| assertEquals(tv, func(true)); |
| assertEquals(fv, func(false)); |
| } |
| |
| test(foo, 10000100, 20000200); |
| test(bar, 5, 6); |
| test(baz, true, false); |
| test(qux, false, false); |