/* * Copyright (C) 2016 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. */ #ifndef _GTS_NANOAPPS_GENERAL_TEST_TEST_H_ #define _GTS_NANOAPPS_GENERAL_TEST_TEST_H_ #include <shared/send_message.h> #include <chre.h> namespace general_test { /** * Abstract base for all test cases. */ class Test { public: Test(uint32_t minSupportedVersion); virtual ~Test() {} void testHandleEvent(uint32_t senderInstanceId, uint16_t eventType, const void *eventData); void testSetUp(uint32_t messageSize, const void *message); protected: /** * Report a test-ending error due to an unexpectedEvent. * * @param eventType The event type * @returns Never. This method aborts execution. */ static void unexpectedEvent(uint16_t eventType); /** * Wrapper structure to store the current async request. */ struct chreAsyncRequest { //! An opaque value that will be included in the chreAsyncResult //! sent in relation to a chre async request. const void *cookie; //! A type of request. Same field as that in {@link #chreAsyncResult} uint8_t requestType; //! Timestamp when mading the request. uint64_t requestTimeNs; //! Timeout to receive the chre async result. uint64_t timeoutNs; }; /** * Reports a test-ending error due to failure in chreAsyncResult. * * 1. chre async result is not success. * 2. chre async result success, but errorCode is not CHRE_ERROR_NONE. * 3. request cookie mismatch. * 4. requestType mismatch. * 5. result timeout. * * @param result chreAsyncResult of an async request. * @param request lastest chre async request. */ static void validateChreAsyncResult(const chreAsyncResult *result, const chreAsyncRequest& request); /** * Get the message data sent from the host, after performing sanity checks. * * The method centralizes a number of common sanity checks that tests * will perform in taking the given CHRE event data and extracting out * the raw data payload sent by the host. This method is still useful * when no message data is expected from the host, as we'll still * perform the sanity checks. * * This method will end the test in failure if any of the following happen: * o 'senderInstanceId' != CHRE_INSTANCE_ID * o 'eventType' != CHRE_EVENT_MESSAGE_FROM_HOST * o 'eventData'->reservedMessageType != expectedMessageType * o 'eventData'->messageSize != expectedMessageSize * * @param senderInstanceId From handleEvent() * @param eventType From handleEvent() * @param eventData From handleEvent() * @param expectedMessageType The expected 'reservedMessageType' field * when 'eventData' is seen as a chreMessageFromHostData. * @param expectedMessageSize The expected 'messageSize' field * when 'eventData' is seen as a chreMessageFromHostData. * @returns 'eventData'->message, assuming all the sanity checks pass. */ static const void *getMessageDataFromHostEvent( uint32_t senderInstanceId, uint16_t eventType, const void* eventData, nanoapp_testing::MessageType expectedMessageType, uint32_t expectedMessageSize); virtual void handleEvent(uint32_t senderInstanceId, uint16_t eventType, const void* eventData) = 0; virtual void setUp(uint32_t messageSize, const void *message) = 0; /** * The platform reported CHRE API version. * * Nanoapps may use this to determine what version they are running * on and perform any version specific behaviours. */ const uint32_t mApiVersion; private: /** * Is the nanoapp supported by the platform reported CHRE API version. * * Nanoapps specify the minimum CHRE API version required during * construction. If it is at least the version that is being reported * by the platform then mIsSupported will be true. Else, the nanoapp * will skip the test. */ const bool mIsSupported; }; } // namespace general_test #endif // _GTS_NANOAPPS_GENERAL_TEST_TEST_H_