| Index: runtime/vm/native_entry_test.cc
|
| ===================================================================
|
| --- runtime/vm/native_entry_test.cc (revision 15918)
|
| +++ runtime/vm/native_entry_test.cc (working copy)
|
| @@ -6,6 +6,7 @@
|
|
|
| #include "vm/assembler.h"
|
| #include "vm/code_patcher.h"
|
| +#include "vm/dart_api_impl.h"
|
| #include "vm/native_entry.h"
|
| #include "vm/object.h"
|
| #include "vm/stack_frame.h"
|
| @@ -55,6 +56,38 @@
|
| }
|
|
|
|
|
| +// Test for accepting null arguments in native function.
|
| +// Arg0-4: 5 smis or null.
|
| +// Result: a smi representing the sum of all non-null arguments.
|
| +void TestNonNullSmiSum(Dart_NativeArguments args) {
|
| + Dart_EnterScope();
|
| + Isolate* isolate = Isolate::Current();
|
| + int64_t result = 0;
|
| + int arg_count = Dart_GetNativeArgumentCount(args);
|
| + // Test the lower level macro GET_NATIVE_ARGUMENT.
|
| + NativeArguments* arguments = reinterpret_cast<NativeArguments*>(args);
|
| + for (int i = 0; i < arg_count; i++) {
|
| + Dart_Handle arg = Dart_GetNativeArgument(args, i);
|
| + GET_NATIVE_ARGUMENT(Integer, argument, arguments->NativeArgAt(i));
|
| + EXPECT(argument.IsInteger()); // May be null.
|
| + EXPECT_EQ(Api::UnwrapHandle(arg), argument.raw()); // May be null.
|
| + int64_t arg_value = -1;
|
| + if (argument.IsNull()) {
|
| + EXPECT_ERROR(Dart_IntegerToInt64(arg, &arg_value),
|
| + "Dart_IntegerToInt64 expects argument 'integer' "
|
| + "to be non-null.");
|
| + } else {
|
| + EXPECT_VALID(Dart_IntegerToInt64(arg, &arg_value));
|
| + EXPECT_EQ(arg_value, argument.AsInt64Value());
|
| + // Ignoring overflow in the addition below.
|
| + result += arg_value;
|
| + }
|
| + }
|
| + Dart_SetReturnValue(args, Dart_NewInteger(result));
|
| + Dart_ExitScope();
|
| +}
|
| +
|
| +
|
| // Test code patching.
|
| void TestStaticCallPatching(Dart_NativeArguments args) {
|
| Dart_EnterScope();
|
|
|