node/deps/v8/test/mjsunit/compiler/string-concat-deopt.js
Michaël Zasso 352a525eb9
deps: update V8 to 6.7.288.43
PR-URL: https://github.com/nodejs/node/pull/19989
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Matheus Marchini <matheus@sthima.com>
Reviewed-By: Gus Caplan <me@gus.host>
Reviewed-By: Myles Borins <myles.borins@gmail.com>
2018-06-01 09:58:27 +02:00

103 lines
2.0 KiB
JavaScript

// Copyright 2018 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: --allow-natives-syntax
(() => {
function f(a) {
return "abc".concat();
}
assertEquals("abc", f());
assertEquals("abc", f());
%OptimizeFunctionOnNextCall(f);
assertEquals("abc", f());
})();
(() => {
function f(a) {
return "abc".concat(a);
}
assertEquals("abcde", f("de"));
assertEquals("abcde", f("de"));
%OptimizeFunctionOnNextCall(f);
assertEquals("abcde", f("de"));
})();
(() => {
function f(a) {
return "abc".concat(a);
}
assertEquals("abcde", f("de"));
assertEquals("abcde", f("de"));
%OptimizeFunctionOnNextCall(f);
assertEquals("abc1", f(1));
})();
(() => {
function f(a) {
return "abc".concat(a);
}
assertEquals("abcde", f("de"));
assertEquals("abcde", f("de"));
%OptimizeFunctionOnNextCall(f);
var s = "x".repeat((1 << 28) - 16);
try {
s = "x".repeat((1 << 30) - 1 - 24);
} catch (e) {
}
assertThrows(() => f(s), RangeError);
})();
(() => {
function f(a) {
return "ab".concat("c");
}
assertEquals("abc", f());
assertEquals("abc", f());
%OptimizeFunctionOnNextCall(f);
assertEquals("abc", f());
})();
(() => {
function f(a) {
return "ab".concat("c", a);
}
assertEquals("abcde", f("de"));
assertEquals("abcde", f("de"));
%OptimizeFunctionOnNextCall(f);
assertEquals("abcde", f("de"));
})();
(() => {
function f(a) {
return "ab".concat("c", a);
}
assertEquals("abcde", f("de"));
assertEquals("abcde", f("de"));
%OptimizeFunctionOnNextCall(f);
assertEquals("abc1", f(1));
})();
(() => {
function f(a) {
return "ab".concat("c", a);
}
assertEquals("abcde", f("de"));
assertEquals("abcde", f("de"));
%OptimizeFunctionOnNextCall(f);
var s = "x".repeat((1 << 28) - 16);
try {
s = "x".repeat((1 << 30) - 1 - 24);
} catch (e) {
}
assertThrows(() => f(s), RangeError);
})();