Chromium Code Reviews| Index: test/cctest/test-api.cc |
| =================================================================== |
| --- test/cctest/test-api.cc (revision 6680) |
| +++ test/cctest/test-api.cc (working copy) |
| @@ -7525,6 +7525,7 @@ |
| "garbage = undefined;"); |
| } |
| + |
| v8::Handle<v8::Value> DirectApiCallback(const v8::Arguments& args) { |
| static int count = 0; |
| if (count++ % 3 == 0) { |
| @@ -7580,6 +7581,54 @@ |
| } |
| +v8::Handle<v8::Value> DirectLoadCallback(Local<String> name, |
| + const v8::AccessorInfo& info) { |
| + if (++p_getter_count % 3 == 0) { |
| + v8::V8::LowMemoryNotification(); |
|
antonm
2011/02/17 16:13:44
you can probably directly force GC as v8::internal
Zaheer
2011/02/21 10:25:35
Done.
|
| + GenerateSomeGarbage(); |
| + } |
| + return v8::Handle<v8::Value>(); |
| +} |
| + |
| + |
| +THREADED_TEST(LoadICFastApi_DirectCall_GCMoveStub) { |
| + v8::HandleScope scope; |
| + LocalContext context; |
| + v8::Handle<v8::ObjectTemplate> obj = v8::ObjectTemplate::New(); |
| + obj->SetAccessor(v8_str("p1"), DirectLoadCallback); |
| + context->Global()->Set(v8_str("o1"), obj->NewInstance()); |
| + p_getter_count = 0; |
| + CompileRun( |
| + "function f() {" |
| + " for (var i = 0; i < 30; i++) o1.p1;" |
| + "}" |
| + "f();"); |
| + CHECK_EQ(30, p_getter_count); |
| +} |
| + |
| + |
| +v8::Handle<v8::Value> ThrowingDirectLoadCallback(Local<String> name, |
| + const v8::AccessorInfo& info) { |
| + return v8::ThrowException(v8_str("g")); |
| +} |
| + |
| + |
| +THREADED_TEST(LoadICFastApi_DirectCall_Throw) { |
| + v8::HandleScope scope; |
| + LocalContext context; |
| + v8::Handle<v8::ObjectTemplate> obj = v8::ObjectTemplate::New(); |
| + obj->SetAccessor(v8_str("p1"), ThrowingDirectLoadCallback); |
| + context->Global()->Set(v8_str("o1"), obj->NewInstance()); |
| + v8::Handle<Value> result = CompileRun( |
| + "var result = '';" |
| + "for (var i = 0; i < 5; i++) {" |
| + " try { o1.p1; } catch (e) { result += e; }" |
| + "}" |
| + "result;"); |
| + CHECK_EQ(v8_str("ggggg"), result); |
|
antonm
2011/02/17 16:13:44
Thank you very much for the tests!
|
| +} |
| + |
| + |
| THREADED_TEST(InterceptorCallICFastApi_TrivialSignature) { |
| int interceptor_call_count = 0; |
| v8::HandleScope scope; |