Add a callback function to retrieve "signal handler" from the bridge, if the bridge wants it to be managed by the runtime. The signal handler will be invoked after the runtime's own one, and before any other chained handler. Add a callback function to check compatibility of the bridge with the library. Add a function to expose the native bridge version. Add a test for this function. Bug: 20217701 Change-Id: Ic23a60b949f119c7d8b0e7cb27a61e6c16532a23
42 lines
1.3 KiB
C++
42 lines
1.3 KiB
C++
/*
|
|
* Copyright (C) 2014 The Android Open Source Project
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#include "NativeBridgeTest.h"
|
|
|
|
#include <signal.h>
|
|
#include <unistd.h>
|
|
|
|
namespace android {
|
|
|
|
constexpr const char* kNativeBridgeLibrary2 = "libnativebridge2-dummy.so";
|
|
|
|
TEST_F(NativeBridgeTest, V2_Signal) {
|
|
// Init
|
|
ASSERT_TRUE(LoadNativeBridge(kNativeBridgeLibrary2, nullptr));
|
|
ASSERT_TRUE(NativeBridgeAvailable());
|
|
ASSERT_TRUE(PreInitializeNativeBridge(".", "isa"));
|
|
ASSERT_TRUE(NativeBridgeAvailable());
|
|
ASSERT_TRUE(InitializeNativeBridge(nullptr, nullptr));
|
|
ASSERT_TRUE(NativeBridgeAvailable());
|
|
|
|
ASSERT_EQ(2U, NativeBridgeGetVersion());
|
|
ASSERT_NE(nullptr, NativeBridgeGetSignalHandler(SIGSEGV));
|
|
|
|
// Clean-up code_cache
|
|
ASSERT_EQ(0, rmdir(kCodeCache));
|
|
}
|
|
|
|
} // namespace android
|