| Index: test/cctest/test-parsing.cc
 | 
| diff --git a/test/cctest/test-parsing.cc b/test/cctest/test-parsing.cc
 | 
| index 1f880c53ce4b285264679e073a8141bd8c9c27ad..33e2d3940708f4c10f46ffebf8ccd695c4908ff4 100644
 | 
| --- a/test/cctest/test-parsing.cc
 | 
| +++ b/test/cctest/test-parsing.cc
 | 
| @@ -1380,7 +1380,8 @@ enum ParserFlag {
 | 
|    kAllowHarmonySloppy,
 | 
|    kAllowHarmonyUnicode,
 | 
|    kAllowHarmonyComputedPropertyNames,
 | 
| -  kAllowStrongMode
 | 
| +  kAllowStrongMode,
 | 
| +  kAllowHarmonySpreadCalls
 | 
|  };
 | 
|  
 | 
|  
 | 
| @@ -1403,6 +1404,8 @@ void SetParserFlags(i::ParserBase<Traits>* parser,
 | 
|    parser->set_allow_harmony_classes(flags.Contains(kAllowHarmonyClasses));
 | 
|    parser->set_allow_harmony_rest_params(
 | 
|        flags.Contains(kAllowHarmonyRestParameters));
 | 
| +  parser->set_allow_harmony_spreadcalls(
 | 
| +      flags.Contains(kAllowHarmonySpreadCalls));
 | 
|    parser->set_allow_harmony_sloppy(flags.Contains(kAllowHarmonySloppy));
 | 
|    parser->set_allow_harmony_unicode(flags.Contains(kAllowHarmonyUnicode));
 | 
|    parser->set_allow_harmony_computed_property_names(
 | 
| @@ -5104,6 +5107,52 @@ TEST(RestParametersDuplicateEvalArguments) {
 | 
|  }
 | 
|  
 | 
|  
 | 
| +TEST(SpreadCall) {
 | 
| +  const char* context_data[][2] = {{"function fn() { 'use strict';} fn(", ");"},
 | 
| +                                   {"function fn() {} fn(", ");"},
 | 
| +                                   {NULL, NULL}};
 | 
| +
 | 
| +  const char* data[] = {
 | 
| +      "...([1, 2, 3])", "...'123', ...'456'", "...new Set([1, 2, 3]), 4",
 | 
| +      "1, ...[2, 3], 4", "...Array(...[1,2,3,4])", "...NaN",
 | 
| +      "0, 1, ...[2, 3, 4], 5, 6, 7, ...'89'",
 | 
| +      "0, 1, ...[2, 3, 4], 5, 6, 7, ...'89', 10",
 | 
| +      "...[0, 1, 2], 3, 4, 5, 6, ...'7', 8, 9",
 | 
| +      "...[0, 1, 2], 3, 4, 5, 6, ...'7', 8, 9, ...[10]", NULL};
 | 
| +
 | 
| +  static const ParserFlag always_flags[] = {kAllowHarmonySpreadCalls};
 | 
| +
 | 
| +  RunParserSyncTest(context_data, data, kSuccess, NULL, 0, always_flags,
 | 
| +                    arraysize(always_flags));
 | 
| +}
 | 
| +
 | 
| +
 | 
| +TEST(SpreadCallErrors) {
 | 
| +  const char* context_data[][2] = {{"function fn() { 'use strict';} fn(", ");"},
 | 
| +                                   {"function fn() {} fn(", ");"},
 | 
| +                                   {NULL, NULL}};
 | 
| +
 | 
| +  const char* data[] = {"(...[1, 2, 3])", "......[1,2,3]", NULL};
 | 
| +
 | 
| +  static const ParserFlag always_flags[] = {kAllowHarmonySpreadCalls};
 | 
| +
 | 
| +  RunParserSyncTest(context_data, data, kError, NULL, 0, always_flags,
 | 
| +                    arraysize(always_flags));
 | 
| +}
 | 
| +
 | 
| +
 | 
| +TEST(BadRestSpread) {
 | 
| +  const char* context_data[][2] = {{"function fn() { 'use strict';", "} fn();"},
 | 
| +                                   {"function fn() { ", "} fn();"},
 | 
| +                                   {NULL, NULL}};
 | 
| +  const char* data[] = {"return ...[1,2,3];",     "var ...x = [1,2,3];",
 | 
| +                        "var [...x,] = [1,2,3];", "var [...x, y] = [1,2,3];",
 | 
| +                        "var {...x} = [1,2,3];",  "var { x } = {x: ...[1,2,3]}",
 | 
| +                        NULL};
 | 
| +  RunParserSyncTest(context_data, data, kError, NULL, 0, NULL, 0);
 | 
| +}
 | 
| +
 | 
| +
 | 
|  TEST(LexicalScopingSloppyMode) {
 | 
|    const char* context_data[][2] = {
 | 
|        {"", ""},
 | 
| 
 |