Don't assert while a callback is registered

If an assert fails while a callback is registered and some data
is delivered that attempts to invoke the callback, it'll cause a
segfault since the callback is allocated on a part of the stack
that's no longer valid.

Bug: 183362725
Change-Id: I3a1f8fbf15c24e344fde8e5b44bb93681ef47d38
Test: Run VTS
This commit is contained in:
Anthony Stange 2021-03-25 16:35:37 +00:00
parent c0f1cc2aba
commit 0b72e2e105

View file

@ -462,6 +462,7 @@ TEST_P(SensorsHidlTest, InjectSensorEventData) {
// Wait for events to be written back to the Event FMQ
callback.waitForEvents(sensors, milliseconds(1000) /* timeout */);
getEnvironment()->unregisterCallback();
for (const auto& s : sensors) {
auto events = callback.getEvents(s.sensorHandle);
@ -485,7 +486,6 @@ TEST_P(SensorsHidlTest, InjectSensorEventData) {
ASSERT_EQ(lastEvent.u.vec3.status, injectedEvent.u.vec3.status);
}
getEnvironment()->unregisterCallback();
ASSERT_EQ(Result::OK, getSensors()->setOperationMode(OperationMode::NORMAL));
}
@ -603,7 +603,7 @@ void SensorsHidlTest::runFlushTest(const std::vector<SensorInfoType>& sensors, b
<< " type=" << static_cast<int>(sensor.type) << " name=" << sensor.name);
Result flushResult = flush(sensor.sensorHandle);
ASSERT_EQ(flushResult, expectedResponse);
EXPECT_EQ(flushResult, expectedResponse);
}
}