mirror of
https://github.com/dart-lang/sdk
synced 2024-11-02 12:24:24 +00:00
5278383736
Changes Dart_NewWeakPersistentHandle to no longer auto delete the weak persistent handle. Changes the signatures of WeakPersistentHandleFinalizers to no longer have access to the handle. Flutter PR: https://github.com/flutter/engine/pull/19843 g3 presubmit: cl/318028238 Issue: https://github.com/dart-lang/sdk/issues/42312 TEST=runtime/vm/dart_api_impl_test.cc Change-Id: I3f77db9954d9486759f903b78c03a494f73c68ba Cq-Include-Trybots:dart/try:vm-ffi-android-debug-arm-try,vm-ffi-android-debug-arm64-try,app-kernel-linux-debug-x64-try,vm-kernel-linux-debug-ia32-try,vm-kernel-win-debug-x64-try,vm-kernel-win-debug-ia32-try,vm-kernel-precomp-linux-debug-x64-try,vm-kernel-precomp-android-release-arm64-try,vm-kernel-asan-linux-release-x64-try,vm-kernel-msan-linux-release-x64-try,vm-kernel-precomp-msan-linux-release-x64-try,vm-kernel-linux-release-simarm-try,vm-kernel-linux-release-simarm64-try,vm-kernel-precomp-android-release-arm_x64-try,vm-kernel-precomp-obfuscate-linux-release-x64-try,dart-sdk-linux-try,analyzer-analysis-server-linux-try,analyzer-linux-release-try,front-end-linux-release-x64-try,vm-kernel-precomp-win-release-x64-try,vm-kernel-mac-debug-x64-try,vm-precomp-ffi-qemu-linux-release-arm-try,vm-kernel-nnbd-linux-debug-x64-try,analyzer-nnbd-linux-release-try,front-end-nnbd-linux-release-x64-try Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/151525 Commit-Queue: Daco Harkes <dacoharkes@google.com> Reviewed-by: Ryan Macnak <rmacnak@google.com> Reviewed-by: Martin Kustermann <kustermann@google.com>
141 lines
4.3 KiB
C++
141 lines
4.3 KiB
C++
// Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
|
|
// for details. All rights reserved. Use of this source code is governed by a
|
|
// BSD-style license that can be found in the LICENSE file.
|
|
|
|
#include "vm/handles.h"
|
|
#include "platform/assert.h"
|
|
#include "vm/dart_api_state.h"
|
|
#include "vm/flags.h"
|
|
#include "vm/heap/heap.h"
|
|
#include "vm/object.h"
|
|
#include "vm/unit_test.h"
|
|
#include "vm/zone.h"
|
|
|
|
namespace dart {
|
|
|
|
// Unit test for Zone handle allocation.
|
|
ISOLATE_UNIT_TEST_CASE(AllocateZoneHandle) {
|
|
#if defined(DEBUG)
|
|
FLAG_trace_handles = true;
|
|
#endif
|
|
// The previously run stub code generation may have created zone handles.
|
|
int initial_count = VMHandles::ZoneHandleCount();
|
|
static const int kNumHandles = 65;
|
|
// Create some zone handles.
|
|
for (int i = 0; i < kNumHandles; i++) {
|
|
const Smi& handle = Smi::ZoneHandle(Smi::New(i));
|
|
EXPECT(handle.IsSmi());
|
|
EXPECT_EQ(i, handle.Value());
|
|
}
|
|
EXPECT_EQ(kNumHandles + initial_count, VMHandles::ZoneHandleCount());
|
|
// Create some more zone handles.
|
|
for (int i = kNumHandles; i < (2 * kNumHandles); i++) {
|
|
const Smi& handle = Smi::ZoneHandle(Smi::New(i));
|
|
EXPECT(handle.IsSmi());
|
|
EXPECT_EQ(i, handle.Value());
|
|
}
|
|
EXPECT_EQ((2 * kNumHandles) + initial_count, VMHandles::ZoneHandleCount());
|
|
}
|
|
|
|
// Unit test for Scope handle allocation.
|
|
ISOLATE_UNIT_TEST_CASE(AllocateScopeHandle) {
|
|
#if defined(DEBUG)
|
|
FLAG_trace_handles = true;
|
|
#endif
|
|
int32_t handle_count = VMHandles::ScopedHandleCount();
|
|
static const int kNumHandles = 65;
|
|
// Create some scoped handles.
|
|
{
|
|
Thread* thread = Thread::Current();
|
|
HANDLESCOPE(thread);
|
|
for (int i = 0; i < kNumHandles; i++) {
|
|
const Smi& handle = Smi::Handle(Smi::New(i));
|
|
EXPECT(handle.IsSmi());
|
|
EXPECT_EQ(i, handle.Value());
|
|
}
|
|
EXPECT_EQ((handle_count + kNumHandles), VMHandles::ScopedHandleCount());
|
|
// Create lots of scoped handles in a loop with a nested scope.
|
|
for (int loop = 0; loop < 1000; loop++) {
|
|
HANDLESCOPE(thread);
|
|
for (int i = 0; i < 2; i++) {
|
|
const Smi& handle = Smi::Handle(Smi::New(i + loop));
|
|
EXPECT(handle.IsSmi());
|
|
EXPECT_EQ(i + loop, handle.Value());
|
|
}
|
|
EXPECT_EQ((handle_count + kNumHandles + 2),
|
|
VMHandles::ScopedHandleCount());
|
|
}
|
|
EXPECT_EQ((handle_count + kNumHandles), VMHandles::ScopedHandleCount());
|
|
for (int i = 0; i < kNumHandles; i++) {
|
|
const Smi& handle = Smi::Handle(Smi::New(i));
|
|
EXPECT(handle.IsSmi());
|
|
EXPECT_EQ(i, handle.Value());
|
|
}
|
|
EXPECT_EQ((handle_count + (2 * kNumHandles)),
|
|
VMHandles::ScopedHandleCount());
|
|
}
|
|
EXPECT_EQ(handle_count, VMHandles::ScopedHandleCount());
|
|
}
|
|
|
|
static void NoopCallback(void* isolate_callback_data, void* peer) {}
|
|
|
|
// Unit test for handle validity checks.
|
|
TEST_CASE(CheckHandleValidity) {
|
|
#if defined(DEBUG)
|
|
FLAG_trace_handles = true;
|
|
#endif
|
|
Dart_Handle handle = NULL;
|
|
// Check validity using zone handles.
|
|
{
|
|
TransitionNativeToVM transition(thread);
|
|
StackZone sz(thread);
|
|
handle = reinterpret_cast<Dart_Handle>(&Smi::ZoneHandle(Smi::New(1)));
|
|
{
|
|
TransitionVMToNative to_native(thread);
|
|
EXPECT_VALID(handle);
|
|
}
|
|
}
|
|
EXPECT(!Api::IsValid(handle));
|
|
|
|
// Check validity using scoped handles.
|
|
{
|
|
Dart_EnterScope();
|
|
{
|
|
TransitionNativeToVM transition(thread);
|
|
HANDLESCOPE(thread);
|
|
handle = reinterpret_cast<Dart_Handle>(&Smi::Handle(Smi::New(1)));
|
|
{
|
|
TransitionVMToNative to_native(thread);
|
|
EXPECT_VALID(handle);
|
|
}
|
|
}
|
|
Dart_ExitScope();
|
|
}
|
|
EXPECT(!Api::IsValid(handle));
|
|
|
|
// Check validity using persistent handle.
|
|
Dart_Handle scoped_handle;
|
|
{
|
|
TransitionNativeToVM transition(thread);
|
|
scoped_handle = Api::NewHandle(thread, Smi::New(1));
|
|
}
|
|
Dart_PersistentHandle persistent_handle =
|
|
Dart_NewPersistentHandle(scoped_handle);
|
|
EXPECT_VALID(persistent_handle);
|
|
|
|
Dart_DeletePersistentHandle(persistent_handle);
|
|
EXPECT(!Api::IsValid(persistent_handle));
|
|
|
|
// Check validity using weak persistent handle.
|
|
handle = reinterpret_cast<Dart_Handle>(Dart_NewWeakPersistentHandle(
|
|
Dart_NewStringFromCString("foo"), NULL, 0, NoopCallback));
|
|
|
|
EXPECT_NOTNULL(handle);
|
|
EXPECT_VALID(handle);
|
|
|
|
Dart_DeleteWeakPersistentHandle(
|
|
reinterpret_cast<Dart_WeakPersistentHandle>(handle));
|
|
EXPECT(!Api::IsValid(handle));
|
|
}
|
|
|
|
} // namespace dart
|