| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 1 | /* | 
|  | 2 | * Copyright (C) 2019 The Android Open Source Project | 
|  | 3 | * | 
|  | 4 | * Licensed under the Apache License, Version 2.0 (the "License"); | 
|  | 5 | * you may not use this file except in compliance with the License. | 
|  | 6 | * You may obtain a copy of the License at | 
|  | 7 | * | 
|  | 8 | *      http://www.apache.org/licenses/LICENSE-2.0 | 
|  | 9 | * | 
|  | 10 | * Unless required by applicable law or agreed to in writing, software | 
|  | 11 | * distributed under the License is distributed on an "AS IS" BASIS, | 
|  | 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
|  | 13 | * See the License for the specific language governing permissions and | 
|  | 14 | * limitations under the License. | 
|  | 15 | */ | 
|  | 16 |  | 
| Steven Moreland | 12300a0 | 2019-08-02 13:27:15 -0700 | [diff] [blame] | 17 | #include <android/binder_manager.h> | 
|  | 18 | #include <android/binder_stability.h> | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 19 | #include <binder/Binder.h> | 
|  | 20 | #include <binder/IBinder.h> | 
|  | 21 | #include <binder/IPCThreadState.h> | 
|  | 22 | #include <binder/IServiceManager.h> | 
|  | 23 | #include <binder/Parcel.h> | 
|  | 24 | #include <binder/Stability.h> | 
|  | 25 | #include <gtest/gtest.h> | 
|  | 26 |  | 
|  | 27 | #include <sys/prctl.h> | 
|  | 28 |  | 
| Steven Moreland | 12300a0 | 2019-08-02 13:27:15 -0700 | [diff] [blame] | 29 | #include "aidl/BnBinderStabilityTest.h" | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 30 | #include "BnBinderStabilityTest.h" | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 31 |  | 
|  | 32 | using namespace android; | 
| Steven Moreland | 12300a0 | 2019-08-02 13:27:15 -0700 | [diff] [blame] | 33 | using namespace ndk; | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 34 | using android::binder::Status; | 
| Steven Moreland | 12300a0 | 2019-08-02 13:27:15 -0700 | [diff] [blame] | 35 | using android::internal::Stability; // for testing only! | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 36 |  | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 37 | const String16 kSystemStabilityServer = String16("binder_stability_test_service_system"); | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 38 |  | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 39 | // This is handwritten so that we can test different stability levels w/o having the AIDL | 
|  | 40 | // compiler assign them. Hand-writing binder interfaces is considered a bad practice | 
|  | 41 | // sanity reasons. YOU SHOULD DEFINE AN AIDL INTERFACE INSTEAD! | 
|  | 42 | class BadStableBinder : public BBinder { | 
| Steven Moreland | 12300a0 | 2019-08-02 13:27:15 -0700 | [diff] [blame] | 43 | public: | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 44 | static constexpr uint32_t USER_TRANSACTION = IBinder::FIRST_CALL_TRANSACTION; | 
|  | 45 | static String16 kDescriptor; | 
|  | 46 |  | 
|  | 47 | bool gotUserTransaction = false; | 
|  | 48 |  | 
|  | 49 | static status_t doUserTransaction(const sp<IBinder>& binder) { | 
|  | 50 | Parcel data, reply; | 
|  | 51 | data.writeInterfaceToken(kDescriptor); | 
|  | 52 | return binder->transact(USER_TRANSACTION, data, &reply, 0/*flags*/); | 
| Steven Moreland | c709dd8 | 2019-08-05 20:30:14 -0700 | [diff] [blame] | 53 | } | 
| Steven Moreland | 12300a0 | 2019-08-02 13:27:15 -0700 | [diff] [blame] | 54 |  | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 55 | status_t onTransact(uint32_t code, | 
|  | 56 | const Parcel& data, Parcel* reply, uint32_t flags) override { | 
|  | 57 | if (code == USER_TRANSACTION) { | 
|  | 58 | // not interested in this kind of stability. Make sure | 
|  | 59 | // we have a test failure | 
|  | 60 | LOG_ALWAYS_FATAL_IF(!data.enforceInterface(kDescriptor)); | 
|  | 61 |  | 
|  | 62 | gotUserTransaction = true; | 
|  | 63 |  | 
|  | 64 | ALOGE("binder stability: Got user transaction"); | 
|  | 65 | return OK; | 
|  | 66 | } | 
|  | 67 | return BBinder::onTransact(code, data, reply, flags); | 
|  | 68 | } | 
|  | 69 |  | 
|  | 70 | static sp<BadStableBinder> undef() { | 
|  | 71 | sp<BadStableBinder> iface = new BadStableBinder(); | 
| Steven Moreland | 12300a0 | 2019-08-02 13:27:15 -0700 | [diff] [blame] | 72 | return iface; | 
|  | 73 | } | 
|  | 74 |  | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 75 | static sp<BadStableBinder> system() { | 
|  | 76 | sp<BadStableBinder> iface = new BadStableBinder(); | 
|  | 77 | Stability::markCompilationUnit(iface.get()); // <- for test only | 
| Steven Moreland | 12300a0 | 2019-08-02 13:27:15 -0700 | [diff] [blame] | 78 | return iface; | 
|  | 79 | } | 
|  | 80 |  | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 81 | static sp<BadStableBinder> vintf() { | 
|  | 82 | sp<BadStableBinder> iface = new BadStableBinder(); | 
|  | 83 | Stability::markVintf(iface.get()); // <- for test only | 
|  | 84 | return iface; | 
|  | 85 | } | 
|  | 86 |  | 
|  | 87 | static sp<BadStableBinder> vendor() { | 
|  | 88 | sp<BadStableBinder> iface = new BadStableBinder(); | 
|  | 89 | Stability::markVndk(iface.get()); // <- for test only | 
| Steven Moreland | 12300a0 | 2019-08-02 13:27:15 -0700 | [diff] [blame] | 90 | return iface; | 
|  | 91 | } | 
| Steven Moreland | c709dd8 | 2019-08-05 20:30:14 -0700 | [diff] [blame] | 92 | }; | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 93 | String16 BadStableBinder::kDescriptor = String16("BadStableBinder.test"); | 
| Steven Moreland | c709dd8 | 2019-08-05 20:30:14 -0700 | [diff] [blame] | 94 |  | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 95 | // NO! NO! NO! Do not even think of doing something like this! | 
|  | 96 | // This is for testing! If a class like this was actually used in production, | 
|  | 97 | // it would ruin everything! | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 98 | class MyBinderStabilityTest : public BnBinderStabilityTest { | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 99 | public: | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 100 | Status sendBinder(const sp<IBinder>& /*binder*/) override { | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 101 | return Status::ok(); | 
|  | 102 | } | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 103 | Status sendAndCallBinder(const sp<IBinder>& binder) override { | 
|  | 104 | Stability::debugLogStability("sendAndCallBinder got binder", binder); | 
|  | 105 | return Status::fromExceptionCode(BadStableBinder::doUserTransaction(binder)); | 
| Steven Moreland | c709dd8 | 2019-08-05 20:30:14 -0700 | [diff] [blame] | 106 | } | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 107 | Status returnNoStabilityBinder(sp<IBinder>* _aidl_return) override { | 
|  | 108 | *_aidl_return = BadStableBinder::undef(); | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 109 | return Status::ok(); | 
|  | 110 | } | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 111 | Status returnLocalStabilityBinder(sp<IBinder>* _aidl_return) override { | 
|  | 112 | *_aidl_return = BadStableBinder::system(); | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 113 | return Status::ok(); | 
|  | 114 | } | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 115 | Status returnVintfStabilityBinder(sp<IBinder>* _aidl_return) override { | 
|  | 116 | *_aidl_return = BadStableBinder::vintf(); | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 117 | return Status::ok(); | 
|  | 118 | } | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 119 | Status returnVendorStabilityBinder(sp<IBinder>* _aidl_return) override { | 
|  | 120 | *_aidl_return = BadStableBinder::vendor(); | 
| Steven Moreland | c709dd8 | 2019-08-05 20:30:14 -0700 | [diff] [blame] | 121 | return Status::ok(); | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 122 | } | 
|  | 123 | }; | 
|  | 124 |  | 
| Steven Moreland | 86a17f8 | 2019-09-10 10:18:00 -0700 | [diff] [blame] | 125 | TEST(BinderStability, OnlyVintfStabilityBinderNeedsVintfDeclaration) { | 
|  | 126 | EXPECT_FALSE(Stability::requiresVintfDeclaration(nullptr)); | 
|  | 127 | EXPECT_FALSE(Stability::requiresVintfDeclaration(BadStableBinder::undef())); | 
|  | 128 | EXPECT_FALSE(Stability::requiresVintfDeclaration(BadStableBinder::system())); | 
|  | 129 | EXPECT_FALSE(Stability::requiresVintfDeclaration(BadStableBinder::vendor())); | 
|  | 130 |  | 
|  | 131 | EXPECT_TRUE(Stability::requiresVintfDeclaration(BadStableBinder::vintf())); | 
|  | 132 | } | 
|  | 133 |  | 
| Steven Moreland | e35fef3 | 2021-03-23 01:38:24 +0000 | [diff] [blame] | 134 | TEST(BinderStability, ForceDowngradeStability) { | 
|  | 135 | sp<IBinder> someBinder = BadStableBinder::vintf(); | 
|  | 136 |  | 
|  | 137 | EXPECT_TRUE(Stability::requiresVintfDeclaration(someBinder)); | 
|  | 138 |  | 
|  | 139 | // silly to do this after already using the binder, but it's for the test | 
|  | 140 | Stability::forceDowngradeCompilationUnit(someBinder); | 
|  | 141 |  | 
|  | 142 | EXPECT_FALSE(Stability::requiresVintfDeclaration(someBinder)); | 
|  | 143 | } | 
|  | 144 |  | 
| Steven Moreland | 86a17f8 | 2019-09-10 10:18:00 -0700 | [diff] [blame] | 145 | TEST(BinderStability, VintfStabilityServerMustBeDeclaredInManifest) { | 
|  | 146 | sp<IBinder> vintfServer = BadStableBinder::vintf(); | 
|  | 147 |  | 
| Steven Moreland | b82b8f8 | 2019-10-28 10:52:34 -0700 | [diff] [blame] | 148 | for (const char* instance8 : { | 
|  | 149 | ".", "/", "/.", "a.d.IFoo", "foo", "a.d.IFoo/foo" | 
|  | 150 | }) { | 
|  | 151 | String16 instance (instance8); | 
|  | 152 |  | 
|  | 153 | EXPECT_EQ(Status::EX_ILLEGAL_ARGUMENT, | 
|  | 154 | android::defaultServiceManager()->addService(String16("."), vintfServer)) << instance8; | 
|  | 155 | EXPECT_FALSE(android::defaultServiceManager()->isDeclared(instance)) << instance8; | 
|  | 156 | } | 
| Steven Moreland | 86a17f8 | 2019-09-10 10:18:00 -0700 | [diff] [blame] | 157 | } | 
|  | 158 |  | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 159 | TEST(BinderStability, CantCallVendorBinderInSystemContext) { | 
|  | 160 | sp<IBinder> serverBinder = android::defaultServiceManager()->getService(kSystemStabilityServer); | 
|  | 161 | auto server = interface_cast<IBinderStabilityTest>(serverBinder); | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 162 |  | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 163 | ASSERT_NE(nullptr, server.get()); | 
|  | 164 | ASSERT_NE(nullptr, IInterface::asBinder(server)->remoteBinder()); | 
| Steven Moreland | c709dd8 | 2019-08-05 20:30:14 -0700 | [diff] [blame] | 165 |  | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 166 | EXPECT_TRUE(server->sendBinder(BadStableBinder::undef()).isOk()); | 
|  | 167 | EXPECT_TRUE(server->sendBinder(BadStableBinder::system()).isOk()); | 
|  | 168 | EXPECT_TRUE(server->sendBinder(BadStableBinder::vintf()).isOk()); | 
|  | 169 | EXPECT_TRUE(server->sendBinder(BadStableBinder::vendor()).isOk()); | 
| Steven Moreland | c709dd8 | 2019-08-05 20:30:14 -0700 | [diff] [blame] | 170 |  | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 171 | { | 
|  | 172 | sp<BadStableBinder> binder = BadStableBinder::undef(); | 
|  | 173 | EXPECT_TRUE(server->sendAndCallBinder(binder).isOk()); | 
|  | 174 | EXPECT_TRUE(binder->gotUserTransaction); | 
|  | 175 | } | 
|  | 176 | { | 
|  | 177 | sp<BadStableBinder> binder = BadStableBinder::system(); | 
|  | 178 | EXPECT_TRUE(server->sendAndCallBinder(binder).isOk()); | 
|  | 179 | EXPECT_TRUE(binder->gotUserTransaction); | 
|  | 180 | } | 
|  | 181 | { | 
|  | 182 | sp<BadStableBinder> binder = BadStableBinder::vintf(); | 
|  | 183 | EXPECT_TRUE(server->sendAndCallBinder(binder).isOk()); | 
|  | 184 | EXPECT_TRUE(binder->gotUserTransaction); | 
|  | 185 | } | 
|  | 186 | { | 
|  | 187 | // !!! user-defined transaction may not be stable for remote server !!! | 
|  | 188 | // !!! so, it does not work !!! | 
|  | 189 | sp<BadStableBinder> binder = BadStableBinder::vendor(); | 
|  | 190 | EXPECT_EQ(BAD_TYPE, server->sendAndCallBinder(binder).exceptionCode()); | 
|  | 191 | EXPECT_FALSE(binder->gotUserTransaction); | 
|  | 192 | } | 
|  | 193 |  | 
|  | 194 | sp<IBinder> out; | 
|  | 195 | EXPECT_TRUE(server->returnNoStabilityBinder(&out).isOk()); | 
| Steven Moreland | c709dd8 | 2019-08-05 20:30:14 -0700 | [diff] [blame] | 196 | ASSERT_NE(nullptr, out.get()); | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 197 | EXPECT_EQ(OK, out->pingBinder()); | 
|  | 198 | EXPECT_EQ(OK, BadStableBinder::doUserTransaction(out)); | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 199 |  | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 200 | EXPECT_TRUE(server->returnLocalStabilityBinder(&out).isOk()); | 
| Steven Moreland | c709dd8 | 2019-08-05 20:30:14 -0700 | [diff] [blame] | 201 | ASSERT_NE(nullptr, out.get()); | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 202 | EXPECT_EQ(OK, out->pingBinder()); | 
|  | 203 | EXPECT_EQ(OK, BadStableBinder::doUserTransaction(out)); | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 204 |  | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 205 | EXPECT_TRUE(server->returnVintfStabilityBinder(&out).isOk()); | 
| Steven Moreland | c709dd8 | 2019-08-05 20:30:14 -0700 | [diff] [blame] | 206 | ASSERT_NE(nullptr, out.get()); | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 207 | EXPECT_EQ(OK, out->pingBinder()); | 
|  | 208 | EXPECT_EQ(OK, BadStableBinder::doUserTransaction(out)); | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 209 |  | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 210 | EXPECT_TRUE(server->returnVendorStabilityBinder(&out).isOk()); | 
| Steven Moreland | c709dd8 | 2019-08-05 20:30:14 -0700 | [diff] [blame] | 211 | ASSERT_NE(nullptr, out.get()); | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 212 |  | 
| Steven Moreland | c709dd8 | 2019-08-05 20:30:14 -0700 | [diff] [blame] | 213 | // !!! libbinder-defined transaction works !!! | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 214 | EXPECT_EQ(OK, out->pingBinder()); | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 215 |  | 
| Steven Moreland | c709dd8 | 2019-08-05 20:30:14 -0700 | [diff] [blame] | 216 | // !!! user-defined transaction may not be stable !!! | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 217 | // !!! so, it does not work !!! | 
|  | 218 | EXPECT_EQ(BAD_TYPE, BadStableBinder::doUserTransaction(out)); | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 219 | } | 
|  | 220 |  | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 221 | // This is handwritten so that we can test different stability levels w/o having the AIDL | 
|  | 222 | // compiler assign them. Hand-writing binder interfaces is considered a bad practice | 
|  | 223 | // sanity reasons. YOU SHOULD DEFINE AN AIDL INTERFACE INSTEAD! | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 224 |  | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 225 | struct NdkBinderStable_DataClass { | 
|  | 226 | bool gotUserTransaction = false; | 
| Steven Moreland | 12300a0 | 2019-08-02 13:27:15 -0700 | [diff] [blame] | 227 | }; | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 228 | void* NdkBadStableBinder_Class_onCreate(void* args) { | 
|  | 229 | LOG_ALWAYS_FATAL_IF(args != nullptr, "Takes no args"); | 
|  | 230 | return static_cast<void*>(new NdkBinderStable_DataClass); | 
|  | 231 | } | 
|  | 232 | void NdkBadStableBinder_Class_onDestroy(void* userData) { | 
|  | 233 | delete static_cast<NdkBinderStable_DataClass*>(userData); | 
|  | 234 | } | 
|  | 235 | NdkBinderStable_DataClass* NdkBadStableBinder_getUserData(AIBinder* binder) { | 
|  | 236 | LOG_ALWAYS_FATAL_IF(binder == nullptr); | 
|  | 237 | void* userData = AIBinder_getUserData(binder); | 
|  | 238 | LOG_ALWAYS_FATAL_IF(userData == nullptr, "null data - binder is remote?"); | 
|  | 239 |  | 
|  | 240 | return static_cast<NdkBinderStable_DataClass*>(userData); | 
|  | 241 | } | 
|  | 242 | binder_status_t NdkBadStableBinder_Class_onTransact( | 
|  | 243 | AIBinder* binder, transaction_code_t code, const AParcel* /*in*/, AParcel* /*out*/) { | 
|  | 244 |  | 
|  | 245 | if (code == BadStableBinder::USER_TRANSACTION) { | 
|  | 246 | ALOGE("ndk binder stability: Got user transaction"); | 
|  | 247 | NdkBadStableBinder_getUserData(binder)->gotUserTransaction = true; | 
|  | 248 | return STATUS_OK; | 
|  | 249 | } | 
|  | 250 |  | 
|  | 251 | return STATUS_UNKNOWN_TRANSACTION; | 
|  | 252 | } | 
|  | 253 |  | 
|  | 254 | static AIBinder_Class* kNdkBadStableBinder = | 
|  | 255 | AIBinder_Class_define(String8(BadStableBinder::kDescriptor).c_str(), | 
|  | 256 | NdkBadStableBinder_Class_onCreate, | 
|  | 257 | NdkBadStableBinder_Class_onDestroy, | 
|  | 258 | NdkBadStableBinder_Class_onTransact); | 
|  | 259 |  | 
| Steven Moreland | 12300a0 | 2019-08-02 13:27:15 -0700 | [diff] [blame] | 260 | // for testing only to get around __ANDROID_VNDK__ guard. | 
|  | 261 | extern "C" void AIBinder_markVendorStability(AIBinder* binder); // <- BAD DO NOT COPY | 
|  | 262 |  | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 263 | TEST(BinderStability, NdkCantCallVendorBinderInSystemContext) { | 
| Steven Moreland | 12300a0 | 2019-08-02 13:27:15 -0700 | [diff] [blame] | 264 | SpAIBinder binder = SpAIBinder(AServiceManager_getService( | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 265 | String8(kSystemStabilityServer).c_str())); | 
| Steven Moreland | 12300a0 | 2019-08-02 13:27:15 -0700 | [diff] [blame] | 266 |  | 
|  | 267 | std::shared_ptr<aidl::IBinderStabilityTest> remoteServer = | 
|  | 268 | aidl::IBinderStabilityTest::fromBinder(binder); | 
|  | 269 |  | 
|  | 270 | ASSERT_NE(nullptr, remoteServer.get()); | 
|  | 271 |  | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 272 | SpAIBinder comp = SpAIBinder(AIBinder_new(kNdkBadStableBinder, nullptr /*args*/)); | 
|  | 273 | EXPECT_TRUE(remoteServer->sendBinder(comp).isOk()); | 
|  | 274 | EXPECT_TRUE(remoteServer->sendAndCallBinder(comp).isOk()); | 
|  | 275 | EXPECT_TRUE(NdkBadStableBinder_getUserData(comp.get())->gotUserTransaction); | 
| Steven Moreland | 12300a0 | 2019-08-02 13:27:15 -0700 | [diff] [blame] | 276 |  | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 277 | SpAIBinder vendor = SpAIBinder(AIBinder_new(kNdkBadStableBinder, nullptr /*args*/)); | 
|  | 278 | AIBinder_markVendorStability(vendor.get()); | 
| Steven Moreland | 12300a0 | 2019-08-02 13:27:15 -0700 | [diff] [blame] | 279 | EXPECT_TRUE(remoteServer->sendBinder(vendor).isOk()); | 
|  | 280 | EXPECT_FALSE(remoteServer->sendAndCallBinder(vendor).isOk()); | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 281 | EXPECT_FALSE(NdkBadStableBinder_getUserData(vendor.get())->gotUserTransaction); | 
| Steven Moreland | 12300a0 | 2019-08-02 13:27:15 -0700 | [diff] [blame] | 282 | } | 
|  | 283 |  | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 284 | class MarksStabilityInConstructor : public BBinder { | 
|  | 285 | public: | 
|  | 286 | static bool gDestructed; | 
|  | 287 |  | 
|  | 288 | MarksStabilityInConstructor() { | 
| Steven Moreland | 12300a0 | 2019-08-02 13:27:15 -0700 | [diff] [blame] | 289 | Stability::markCompilationUnit(this); | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 290 | } | 
|  | 291 | ~MarksStabilityInConstructor() { | 
|  | 292 | gDestructed = true; | 
|  | 293 | } | 
|  | 294 | }; | 
|  | 295 | bool MarksStabilityInConstructor::gDestructed = false; | 
|  | 296 |  | 
|  | 297 | TEST(BinderStability, MarkingObjectNoDestructTest) { | 
|  | 298 | ASSERT_FALSE(MarksStabilityInConstructor::gDestructed); | 
|  | 299 |  | 
|  | 300 | // best practice is to put this directly in an sp, but for this test, we | 
|  | 301 | // want to explicitly check what happens before that happens | 
|  | 302 | MarksStabilityInConstructor* binder = new MarksStabilityInConstructor(); | 
|  | 303 | ASSERT_FALSE(MarksStabilityInConstructor::gDestructed); | 
|  | 304 |  | 
|  | 305 | sp<MarksStabilityInConstructor> binderSp = binder; | 
|  | 306 | ASSERT_FALSE(MarksStabilityInConstructor::gDestructed); | 
|  | 307 |  | 
|  | 308 | binderSp = nullptr; | 
|  | 309 | ASSERT_TRUE(MarksStabilityInConstructor::gDestructed); | 
|  | 310 | } | 
|  | 311 |  | 
| Steven Moreland | cfdeaf1 | 2019-08-08 15:41:01 -0700 | [diff] [blame] | 312 | TEST(BinderStability, RemarkDies) { | 
|  | 313 | ASSERT_DEATH({ | 
|  | 314 | sp<IBinder> binder = new BBinder(); | 
|  | 315 | Stability::markCompilationUnit(binder.get()); // <-- only called for tests | 
|  | 316 | Stability::markVndk(binder.get()); // <-- only called for tests | 
|  | 317 | }, "Should only mark known object."); | 
|  | 318 | } | 
|  | 319 |  | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 320 | int main(int argc, char** argv) { | 
|  | 321 | ::testing::InitGoogleTest(&argc, argv); | 
|  | 322 |  | 
|  | 323 | if (fork() == 0) { | 
|  | 324 | // child process | 
|  | 325 | prctl(PR_SET_PDEATHSIG, SIGHUP); | 
|  | 326 |  | 
| Steven Moreland | 43564fd | 2019-08-08 17:27:12 -0700 | [diff] [blame] | 327 | sp<IBinder> server = new MyBinderStabilityTest; | 
|  | 328 | android::defaultServiceManager()->addService(kSystemStabilityServer, server); | 
| Steven Moreland | dea3cf9 | 2019-07-16 18:06:55 -0700 | [diff] [blame] | 329 |  | 
|  | 330 | IPCThreadState::self()->joinThreadPool(true); | 
|  | 331 | exit(1);  // should not reach | 
|  | 332 | } | 
|  | 333 |  | 
|  | 334 | // This is not racey. Just giving these services some time to register before we call | 
|  | 335 | // getService which sleeps for much longer... | 
|  | 336 | usleep(10000); | 
|  | 337 |  | 
|  | 338 | return RUN_ALL_TESTS(); | 
|  | 339 | } |