Commit 119f630b authored by whesse@chromium.org's avatar whesse@chromium.org

Add test for calls to native runtime functions in extensions.

Review URL: http://codereview.chromium.org/3356007

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@5415 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent ece887da
...@@ -3605,6 +3605,29 @@ THREADED_TEST(ExceptionExtensions) { ...@@ -3605,6 +3605,29 @@ THREADED_TEST(ExceptionExtensions) {
} }
static const char* kNativeCallInExtensionSource =
"function call_runtime_last_index_of(x) {"
" return %StringLastIndexOf(x, 'bob', 10);"
"}";
static const char* kNativeCallTest =
"call_runtime_last_index_of('bobbobboellebobboellebobbob');";
// Test that a native runtime calls are supported in extensions.
THREADED_TEST(NativeCallInExtensions) {
v8::HandleScope handle_scope;
v8::RegisterExtension(new Extension("nativecall",
kNativeCallInExtensionSource));
const char* extension_names[] = { "nativecall" };
v8::ExtensionConfiguration extensions(1, extension_names);
v8::Handle<Context> context = Context::New(&extensions);
Context::Scope lock(context);
v8::Handle<Value> result = Script::Compile(v8_str(kNativeCallTest))->Run();
CHECK_EQ(result, v8::Integer::New(3));
}
static void CheckDependencies(const char* name, const char* expected) { static void CheckDependencies(const char* name, const char* expected) {
v8::HandleScope handle_scope; v8::HandleScope handle_scope;
v8::ExtensionConfiguration config(1, &name); v8::ExtensionConfiguration config(1, &name);
......
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