Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
| 2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
| 3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
| 4 // met: | 4 // met: |
| 5 // | 5 // |
| 6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
| 7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
| 8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
| 9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
| 10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
| (...skipping 21609 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 21620 } | 21620 } |
| 21621 for (int i = 0; i < runs; i++) { | 21621 for (int i = 0; i < runs; i++) { |
| 21622 Local<String> expected; | 21622 Local<String> expected; |
| 21623 if (i != 0) { | 21623 if (i != 0) { |
| 21624 CHECK_EQ(v8_str("escape value"), values[i]); | 21624 CHECK_EQ(v8_str("escape value"), values[i]); |
| 21625 } else { | 21625 } else { |
| 21626 CHECK(values[i].IsEmpty()); | 21626 CHECK(values[i].IsEmpty()); |
| 21627 } | 21627 } |
| 21628 } | 21628 } |
| 21629 } | 21629 } |
| 21630 | |
| 21631 | |
| 21632 static void SetterWhichExpectsThisAndHolderToDiffer( | |
| 21633 Local<String>, Local<Value>, const v8::PropertyCallbackInfo<void>& info) { | |
| 21634 CHECK(info.Holder() != info.This()); | |
| 21635 } | |
| 21636 | |
| 21637 | |
| 21638 TEST(Regress239669) { | |
|
dcarney
2014/01/16 07:44:13
this test doesn't test the stub you changed
please
sof
2014/01/16 08:00:16
Thanks, will do.
(But what's there exercises that
sof
2014/01/16 08:44:11
Done.
| |
| 21639 // Regress618 triggers the StoreCallbackProperty() code path | |
| 21640 // we're after; this is a reduced version of it. | |
| 21641 const char* source = "function C1() {" | |
| 21642 " this.x = 23;" | |
| 21643 "};" | |
| 21644 "C1.prototype = P;"; | |
| 21645 | |
| 21646 LocalContext context; | |
| 21647 v8::Isolate* isolate = context->GetIsolate(); | |
| 21648 v8::HandleScope scope(isolate); | |
| 21649 | |
| 21650 // Use a simple object as prototype. | |
| 21651 v8::Local<v8::Object> prototype = v8::Object::New(isolate); | |
| 21652 prototype->Set(v8_str("y"), v8_num(42)); | |
| 21653 context->Global()->Set(v8_str("P"), prototype); | |
| 21654 | |
| 21655 CompileRun(source); | |
| 21656 v8::Local<v8::Script> script = v8::Script::Compile(v8_str("new C1();")); | |
| 21657 for (int i = 0; i < 2; i++) { | |
| 21658 v8::Handle<v8::Object>::Cast(script->Run()); | |
| 21659 } | |
| 21660 | |
| 21661 Local<ObjectTemplate> templ = ObjectTemplate::New(isolate); | |
| 21662 templ->SetAccessor(v8_str("x"), 0, SetterWhichExpectsThisAndHolderToDiffer); | |
| 21663 context->Global()->Set(v8_str("P"), templ->NewInstance()); | |
| 21664 | |
| 21665 CompileRun(source); | |
| 21666 script = v8::Script::Compile(v8_str("new C1();")); | |
| 21667 for (int i = 0; i < 2; i++) { | |
| 21668 v8::Handle<v8::Object>::Cast(script->Run()); | |
| 21669 } | |
| 21670 } | |
| OLD | NEW |