| Index: test/cctest/test-code-stub-assembler.cc | 
| diff --git a/test/cctest/test-code-stub-assembler.cc b/test/cctest/test-code-stub-assembler.cc | 
| index 068ef9c3d169205ba7a38bb7ffb807f2c88a0c9e..61c6b7bf7ed33c673e20b6945bc21e06e67700ec 100644 | 
| --- a/test/cctest/test-code-stub-assembler.cc | 
| +++ b/test/cctest/test-code-stub-assembler.cc | 
| @@ -180,47 +180,6 @@ TEST(ToString) { | 
| } | 
| } | 
|  | 
| -TEST(FlattenString) { | 
| -  Isolate* isolate(CcTest::InitIsolateOnce()); | 
| -  const int kNumParams = 1; | 
| -  CodeAssemblerTester data(isolate, kNumParams); | 
| -  CodeStubAssembler m(data.state()); | 
| -  m.Return(m.FlattenString(m.Parameter(0))); | 
| - | 
| -  Handle<Code> code = data.GenerateCode(); | 
| -  FunctionTester ft(code, kNumParams); | 
| - | 
| -  Handle<FixedArray> test_cases(isolate->factory()->NewFixedArray(4)); | 
| -  Handle<String> expected( | 
| -      isolate->factory()->InternalizeUtf8String("hello, world!")); | 
| -  test_cases->set(0, *expected); | 
| - | 
| -  Handle<String> string( | 
| -      isolate->factory()->InternalizeUtf8String("filler hello, world! filler")); | 
| -  Handle<String> sub_string( | 
| -      isolate->factory()->NewProperSubString(string, 7, 20)); | 
| -  test_cases->set(1, *sub_string); | 
| - | 
| -  Handle<String> hello(isolate->factory()->InternalizeUtf8String("hello,")); | 
| -  Handle<String> world(isolate->factory()->InternalizeUtf8String(" world!")); | 
| -  Handle<String> cons_str( | 
| -      isolate->factory()->NewConsString(hello, world).ToHandleChecked()); | 
| -  test_cases->set(2, *cons_str); | 
| - | 
| -  Handle<String> empty(isolate->factory()->InternalizeUtf8String("")); | 
| -  Handle<String> fake_cons_str( | 
| -      isolate->factory()->NewConsString(expected, empty).ToHandleChecked()); | 
| -  test_cases->set(3, *fake_cons_str); | 
| - | 
| -  for (int i = 0; i < 4; ++i) { | 
| -    Handle<String> test = handle(String::cast(test_cases->get(i))); | 
| -    Handle<Object> result = ft.Call(test).ToHandleChecked(); | 
| -    CHECK(result->IsString()); | 
| -    CHECK(Handle<String>::cast(result)->IsFlat()); | 
| -    CHECK(String::Equals(Handle<String>::cast(result), expected)); | 
| -  } | 
| -} | 
| - | 
| TEST(TryToName) { | 
| typedef CodeAssemblerLabel Label; | 
| typedef CodeAssemblerVariable Variable; | 
| @@ -238,22 +197,26 @@ TEST(TryToName) { | 
|  | 
| Label passed(&m), failed(&m); | 
| Label if_keyisindex(&m), if_keyisunique(&m), if_bailout(&m); | 
| -    Variable var_index(&m, MachineType::PointerRepresentation()); | 
| - | 
| -    m.TryToName(key, &if_keyisindex, &var_index, &if_keyisunique, &if_bailout); | 
| - | 
| -    m.Bind(&if_keyisindex); | 
| -    m.GotoUnless( | 
| -        m.WordEqual(expected_result, m.SmiConstant(Smi::FromInt(kKeyIsIndex))), | 
| -        &failed); | 
| -    m.Branch(m.WordEqual(m.SmiUntag(expected_arg), var_index.value()), &passed, | 
| -             &failed); | 
| - | 
| -    m.Bind(&if_keyisunique); | 
| -    m.GotoUnless( | 
| -        m.WordEqual(expected_result, m.SmiConstant(Smi::FromInt(kKeyIsUnique))), | 
| -        &failed); | 
| -    m.Branch(m.WordEqual(expected_arg, key), &passed, &failed); | 
| +    { | 
| +      Variable var_index(&m, MachineType::PointerRepresentation()); | 
| +      Variable var_unique(&m, MachineRepresentation::kTagged); | 
| + | 
| +      m.TryToName(key, &if_keyisindex, &var_index, &if_keyisunique, &var_unique, | 
| +                  &if_bailout); | 
| + | 
| +      m.Bind(&if_keyisindex); | 
| +      m.GotoUnless(m.WordEqual(expected_result, | 
| +                               m.SmiConstant(Smi::FromInt(kKeyIsIndex))), | 
| +                   &failed); | 
| +      m.Branch(m.WordEqual(m.SmiUntag(expected_arg), var_index.value()), | 
| +               &passed, &failed); | 
| + | 
| +      m.Bind(&if_keyisunique); | 
| +      m.GotoUnless(m.WordEqual(expected_result, | 
| +                               m.SmiConstant(Smi::FromInt(kKeyIsUnique))), | 
| +                   &failed); | 
| +      m.Branch(m.WordEqual(expected_arg, var_unique.value()), &passed, &failed); | 
| +    } | 
|  | 
| m.Bind(&if_bailout); | 
| m.Branch( | 
| @@ -349,6 +312,23 @@ TEST(TryToName) { | 
| Handle<Object> key = isolate->factory()->NewStringFromAsciiChecked("test"); | 
| ft.CheckTrue(key, expect_bailout); | 
| } | 
| + | 
| +  { | 
| +    // TryToName(<thin string>) => internalized version. | 
| +    Handle<String> s = isolate->factory()->NewStringFromAsciiChecked("foo"); | 
| +    Handle<String> internalized = isolate->factory()->InternalizeString(s); | 
| +    ft.CheckTrue(s, expect_unique, internalized); | 
| +  } | 
| + | 
| +  { | 
| +    // TryToName(<thin two-byte string>) => internalized version. | 
| +    uc16 array1[] = {2001, 2002, 2003}; | 
| +    Vector<const uc16> str1(array1); | 
| +    Handle<String> s = | 
| +        isolate->factory()->NewStringFromTwoByte(str1).ToHandleChecked(); | 
| +    Handle<String> internalized = isolate->factory()->InternalizeString(s); | 
| +    ft.CheckTrue(s, expect_unique, internalized); | 
| +  } | 
| } | 
|  | 
| namespace { | 
|  |