Commit cd5ee626 authored by yangguo@chromium.org's avatar yangguo@chromium.org

Allow multiple lines of custom flags in javascript tests.

R=ulan@chromium.org
BUG=

Review URL: https://chromiumcodereview.appspot.com/10855099

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@12289 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 8d30a964
...@@ -81,9 +81,9 @@ class MessageTestCase(test.TestCase): ...@@ -81,9 +81,9 @@ class MessageTestCase(test.TestCase):
def GetCommand(self): def GetCommand(self):
result = self.config.context.GetVmCommand(self, self.mode) result = self.config.context.GetVmCommand(self, self.mode)
source = open(self.file).read() source = open(self.file).read()
flags_match = FLAGS_PATTERN.search(source) flags_match = re.findall(FLAGS_PATTERN, source)
if flags_match: for match in flags_match:
result += flags_match.group(1).strip().split() result += match.strip().split()
result.append(self.file) result.append(self.file)
return result return result
......
...@@ -25,7 +25,9 @@ ...@@ -25,7 +25,9 @@
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
// Flags: --allow-natives-syntax --smi-only-arrays --expose-gc --noparallel-recompilation // Flags: --allow-natives-syntax --smi-only-arrays --expose-gc
// Flags: --noparallel-recompilation
// Test element kind of objects. // Test element kind of objects.
// Since --smi-only-arrays affects builtins, its default setting at compile // Since --smi-only-arrays affects builtins, its default setting at compile
// time sticks if built with snapshot. If --smi-only-arrays is deactivated // time sticks if built with snapshot. If --smi-only-arrays is deactivated
......
...@@ -25,7 +25,9 @@ ...@@ -25,7 +25,9 @@
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
// Flags: --allow-natives-syntax --inline-construct --max-inlined-source-size=999999 --max-inlined-nodes=999999 --max-inlined-nodes-cumulative=999999 // Flags: --allow-natives-syntax --inline-construct
// Flags: --max-inlined-source-size=999999 --max-inlined-nodes=999999
// Flags: --max-inlined-nodes-cumulative=999999
// Test that huge constructors (more than 256 this assignments) are // Test that huge constructors (more than 256 this assignments) are
// handled correctly. // handled correctly.
......
...@@ -25,7 +25,8 @@ ...@@ -25,7 +25,8 @@
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
// Flags: --count-based-interrupts --interrupt-budget=10 --weighted-back-edges --allow-natives-syntax --noparallel-recompilation // Flags: --count-based-interrupts --interrupt-budget=10 --weighted-back-edges
// Flags: --allow-natives-syntax --noparallel-recompilation
// Test that OSR works properly when using count-based interrupting/profiling. // Test that OSR works properly when using count-based interrupting/profiling.
......
...@@ -25,7 +25,8 @@ ...@@ -25,7 +25,8 @@
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
// Flags: --expose-debug-as debug --allow-natives-syntax --noparallel-recompilation // Flags: --expose-debug-as debug --allow-natives-syntax
// Flags: --noparallel-recompilation
// This test tests that deoptimization due to debug breaks works for // This test tests that deoptimization due to debug breaks works for
// inlined functions where the full-code is generated before the // inlined functions where the full-code is generated before the
......
...@@ -25,7 +25,9 @@ ...@@ -25,7 +25,9 @@
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
// Flags: --expose-debug-as debug --expose-gc --allow-natives-syntax --inline-construct // Flags: --expose-debug-as debug --expose-gc --allow-natives-syntax
// Flags: --inline-construct
// Get the Debug object exposed from the debug context global object. // Get the Debug object exposed from the debug context global object.
Debug = debug.Debug Debug = debug.Debug
...@@ -43,13 +45,17 @@ var input = [ ...@@ -43,13 +45,17 @@ var input = [
]; ];
var expected = [ var expected = [
{ locals: {a0: 1.01, b0: 2.02}, args: { names: ["i", "x0", "y0"], values: [0, 3.03, 4.04] } }, { locals: {a0: 1.01, b0: 2.02},
{ locals: {a1: 3.03, b1: 4.04}, args: { names: ["i", "x1", "y1"], values: [1, 5.05, 6.06] } }, args: { names: ["i", "x0", "y0"], values: [0, 3.03, 4.04] } },
{ locals: {a2: 5.05, b2: 6.06}, args: { names: ["i"], values: [2] } }, { locals: {a1: 3.03, b1: 4.04},
{ locals: {a3: 7.07, b3: 8.08}, args: { names: ["i", "x3", "y3", "z3"], args: { names: ["i", "x1", "y1"], values: [1, 5.05, 6.06] } },
values: [3, 9.09, 10.10, undefined] } { locals: {a2: 5.05, b2: 6.06},
}, args: { names: ["i"], values: [2] } },
{ locals: {a4: 9.09, b4: 10.10}, args: { names: ["i", "x4", "y4"], values: [4, 11.11, 12.12] } } { locals: {a3: 7.07, b3: 8.08},
args: { names: ["i", "x3", "y3", "z3"],
values: [3, 9.09, 10.10, undefined] } },
{ locals: {a4: 9.09, b4: 10.10},
args: { names: ["i", "x4", "y4"], values: [4, 11.11, 12.12] } }
]; ];
function arraySum(arr) { function arraySum(arr) {
...@@ -78,7 +84,8 @@ function listener(event, exec_state, event_data, data) { ...@@ -78,7 +84,8 @@ function listener(event, exec_state, event_data, data) {
// All frames except the bottom one have expected arguments. // All frames except the bottom one have expected arguments.
for (var j = 0; j < expected_args.names.length; j++) { for (var j = 0; j < expected_args.names.length; j++) {
assertEquals(expected_args.names[j], frame.argumentName(j)); assertEquals(expected_args.names[j], frame.argumentName(j));
assertEquals(expected_args.values[j], frame.argumentValue(j).value()); assertEquals(expected_args.values[j],
frame.argumentValue(j).value());
} }
// All frames except the bottom one have two scopes. // All frames except the bottom one have two scopes.
...@@ -87,13 +94,15 @@ function listener(event, exec_state, event_data, data) { ...@@ -87,13 +94,15 @@ function listener(event, exec_state, event_data, data) {
assertEquals(debug.ScopeType.Global, frame.scope(1).scopeType()); assertEquals(debug.ScopeType.Global, frame.scope(1).scopeType());
Object.keys(expected_locals).forEach(function (name) { Object.keys(expected_locals).forEach(function (name) {
assertEquals(expected_locals[name], frame.scope(0).scopeObject().value()[name]); assertEquals(expected_locals[name],
frame.scope(0).scopeObject().value()[name]);
}); });
for (var j = 0; j < expected_args.names.length; j++) { for (var j = 0; j < expected_args.names.length; j++) {
var arg_name = expected_args.names[j]; var arg_name = expected_args.names[j];
var arg_value = expected_args.values[j]; var arg_value = expected_args.values[j];
assertEquals(arg_value, frame.scope(0).scopeObject().value()[arg_name]); assertEquals(arg_value,
frame.scope(0).scopeObject().value()[arg_name]);
} }
// Evaluate in the inlined frame. // Evaluate in the inlined frame.
...@@ -114,7 +123,8 @@ function listener(event, exec_state, event_data, data) { ...@@ -114,7 +123,8 @@ function listener(event, exec_state, event_data, data) {
map(function (k) { return expected_locals[k]; })); map(function (k) { return expected_locals[k]; }));
assertEquals(expected_locals_sum + expected_args_sum, assertEquals(expected_locals_sum + expected_args_sum,
frame.evaluate(Object.keys(expected_locals).join('+') + ' + ' + frame.evaluate(Object.keys(expected_locals).join('+') +
' + ' +
expected_args.names.join('+')).value()); expected_args.names.join('+')).value());
var arguments_sum = expected_args.names.map(function(_, idx) { var arguments_sum = expected_args.names.map(function(_, idx) {
......
...@@ -25,7 +25,9 @@ ...@@ -25,7 +25,9 @@
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
// Flags: --expose-debug-as debug --expose-gc --allow-natives-syntax --inline-construct // Flags: --expose-debug-as debug --expose-gc --allow-natives-syntax
// Flags: --inline-construct
// Get the Debug object exposed from the debug context global object. // Get the Debug object exposed from the debug context global object.
Debug = debug.Debug Debug = debug.Debug
...@@ -35,11 +37,16 @@ var exception = false; ...@@ -35,11 +37,16 @@ var exception = false;
var testingConstructCall = false; var testingConstructCall = false;
var expected = [ var expected = [
{ locals: {a0: 1, b0: 2}, args: { names: ["i", "x0", "y0"], values: [0, 3, 4] } }, { locals: {a0: 1, b0: 2},
{ locals: {a1: 3, b1: 4}, args: { names: ["i", "x1", "y1"], values: [1, 5, 6] } }, args: { names: ["i", "x0", "y0"], values: [0, 3, 4] } },
{ locals: {a2: 5, b2: 6}, args: { names: ["i"], values: [2] } }, { locals: {a1: 3, b1: 4},
{ locals: {a3: 7, b3: 8}, args: { names: ["i", "x3", "y3", "z3"], values: [3, 9, 10, undefined] } }, args: { names: ["i", "x1", "y1"], values: [1, 5, 6] } },
{ locals: {a4: 9, b4: 10}, args: { names: ["i", "x4", "y4"], values: [4, 11, 12] } } { locals: {a2: 5, b2: 6},
args: { names: ["i"], values: [2] } },
{ locals: {a3: 7, b3: 8},
args: { names: ["i", "x3", "y3", "z3"], values: [3, 9, 10, undefined] } },
{ locals: {a4: 9, b4: 10},
args: { names: ["i", "x4", "y4"], values: [4, 11, 12] } }
]; ];
function arraySum(arr) { function arraySum(arr) {
...@@ -68,7 +75,8 @@ function listener(event, exec_state, event_data, data) { ...@@ -68,7 +75,8 @@ function listener(event, exec_state, event_data, data) {
// All frames except the bottom one have expected arguments. // All frames except the bottom one have expected arguments.
for (var j = 0; j < expected_args.names.length; j++) { for (var j = 0; j < expected_args.names.length; j++) {
assertEquals(expected_args.names[j], frame.argumentName(j)); assertEquals(expected_args.names[j], frame.argumentName(j));
assertEquals(expected_args.values[j], frame.argumentValue(j).value()); assertEquals(expected_args.values[j],
frame.argumentValue(j).value());
} }
// All frames except the bottom one have two scopes. // All frames except the bottom one have two scopes.
...@@ -77,13 +85,15 @@ function listener(event, exec_state, event_data, data) { ...@@ -77,13 +85,15 @@ function listener(event, exec_state, event_data, data) {
assertEquals(debug.ScopeType.Global, frame.scope(1).scopeType()); assertEquals(debug.ScopeType.Global, frame.scope(1).scopeType());
Object.keys(expected_locals).forEach(function (name) { Object.keys(expected_locals).forEach(function (name) {
assertEquals(expected_locals[name], frame.scope(0).scopeObject().value()[name]); assertEquals(expected_locals[name],
frame.scope(0).scopeObject().value()[name]);
}); });
for (var j = 0; j < expected_args.names.length; j++) { for (var j = 0; j < expected_args.names.length; j++) {
var arg_name = expected_args.names[j]; var arg_name = expected_args.names[j];
var arg_value = expected_args.values[j]; var arg_value = expected_args.values[j];
assertEquals(arg_value, frame.scope(0).scopeObject().value()[arg_name]); assertEquals(arg_value,
frame.scope(0).scopeObject().value()[arg_name]);
} }
// Evaluate in the inlined frame. // Evaluate in the inlined frame.
...@@ -104,7 +114,8 @@ function listener(event, exec_state, event_data, data) { ...@@ -104,7 +114,8 @@ function listener(event, exec_state, event_data, data) {
map(function (k) { return expected_locals[k]; })); map(function (k) { return expected_locals[k]; }));
assertEquals(expected_locals_sum + expected_args_sum, assertEquals(expected_locals_sum + expected_args_sum,
frame.evaluate(Object.keys(expected_locals).join('+') + ' + ' + frame.evaluate(Object.keys(expected_locals).join('+') +
' + ' +
expected_args.names.join('+')).value()); expected_args.names.join('+')).value());
var arguments_sum = expected_args.names.map(function(_, idx) { var arguments_sum = expected_args.names.map(function(_, idx) {
......
...@@ -25,7 +25,8 @@ ...@@ -25,7 +25,8 @@
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
// Flags: --allow-natives-syntax --smi-only-arrays --expose-gc --noparallel-recompilation // Flags: --allow-natives-syntax --smi-only-arrays --expose-gc
// Flags: --noparallel-recompilation
// Ensure that ElementsKind transitions in various situations are hoisted (or // Ensure that ElementsKind transitions in various situations are hoisted (or
// not hoisted) correctly, don't change the semantics programs and don't trigger // not hoisted) correctly, don't change the semantics programs and don't trigger
......
...@@ -25,7 +25,8 @@ ...@@ -25,7 +25,8 @@
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
// Flags: --allow-natives-syntax --hydrogen-filter=Debug.setBreakPoint --expose-debug-as debug // Flags: --allow-natives-syntax --hydrogen-filter=Debug.setBreakPoint
// Flags: --expose-debug-as debug
Debug = debug.Debug Debug = debug.Debug
......
...@@ -56,9 +56,9 @@ class MjsunitTestCase(test.TestCase): ...@@ -56,9 +56,9 @@ class MjsunitTestCase(test.TestCase):
def GetVmCommand(self, source): def GetVmCommand(self, source):
result = self.config.context.GetVmCommand(self, self.mode) result = self.config.context.GetVmCommand(self, self.mode)
flags_match = FLAGS_PATTERN.search(source) flags_match = re.findall(FLAGS_PATTERN, source);
if flags_match: for match in flags_match:
result += flags_match.group(1).strip().split() result += match.strip().split()
return result return result
def GetVmArguments(self, source): def GetVmArguments(self, source):
......
...@@ -27,7 +27,9 @@ ...@@ -27,7 +27,9 @@
// Test dictionary -> double elements -> dictionary elements round trip // Test dictionary -> double elements -> dictionary elements round trip
// Flags: --allow-natives-syntax --unbox-double-arrays --expose-gc --noparallel-recompilation // Flags: --allow-natives-syntax --unbox-double-arrays --expose-gc
// Flags: --noparallel-recompilation
var large_array_size = 100000; var large_array_size = 100000;
var approx_dict_to_elements_threshold = 70000; var approx_dict_to_elements_threshold = 70000;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment