• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (C) 2016 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 
17 #include <general_test/test.h>
18 
19 #include <shared/abort.h>
20 #include <shared/macros.h>
21 #include <shared/send_message.h>
22 #include <shared/time_util.h>
23 #include <cinttypes>
24 
25 #include <chre/util/nanoapp/log.h>
26 
27 #include "chre_api/chre.h"
28 
29 #define LOG_TAG "[Test]"
30 
31 using nanoapp_testing::sendInternalFailureToHost;
32 
33 namespace general_test {
34 
Test(uint32_t minSupportedVersion)35 Test::Test(uint32_t minSupportedVersion)
36     : mApiVersion(chreGetApiVersion()),
37       mIsSupported(mApiVersion >= minSupportedVersion) {}
38 
testSetUp(uint32_t messageSize,const void * message)39 void Test::testSetUp(uint32_t messageSize, const void *message) {
40   if (mIsSupported) {
41     setUp(messageSize, message);
42   } else {
43     sendMessageToHost(nanoapp_testing::MessageType::kSkipped);
44   }
45 }
46 
testHandleEvent(uint32_t senderInstanceId,uint16_t eventType,const void * eventData)47 void Test::testHandleEvent(uint32_t senderInstanceId, uint16_t eventType,
48                            const void *eventData) {
49   if (mIsSupported) {
50     handleEvent(senderInstanceId, eventType, eventData);
51   }
52 }
53 
unexpectedEvent(uint16_t eventType)54 void Test::unexpectedEvent(uint16_t eventType) {
55   uint32_t localEvent = eventType;
56   EXPECT_FAIL_RETURN("Test received unexpected event:", &localEvent);
57 }
58 
validateChreAsyncResult(const chreAsyncResult * result,const chreAsyncRequest & request)59 void Test::validateChreAsyncResult(const chreAsyncResult *result,
60                                    const chreAsyncRequest &request) {
61   if (!result->success) {
62     EXPECT_FAIL_RETURN_UINT8("chre async result error: ", result->errorCode);
63   }
64   if (result->success && result->errorCode != CHRE_ERROR_NONE) {
65     EXPECT_FAIL_RETURN_UINT8(
66         "Request was successfully processed, but got errorCode: ",
67         result->errorCode);
68   }
69   if (result->reserved != 0) {
70     EXPECT_FAIL_RETURN_UINT8("reserved should be 0, got: ", result->reserved);
71   }
72   if (result->cookie != request.cookie) {
73     LOGE("Request cookie is %p, got %p", request.cookie, result->cookie);
74     EXPECT_FAIL_RETURN("Request cookie mismatch");
75   }
76   if (result->requestType != request.requestType) {
77     LOGE("Request requestType is %d, got %d", request.requestType,
78          result->requestType);
79     EXPECT_FAIL_RETURN("Request requestType mismatch");
80   }
81   if (chreGetTime() - request.requestTimeNs > request.timeoutNs) {
82     uint32_t time =
83         request.timeoutNs / nanoapp_testing::kOneSecondInNanoseconds;
84     EXPECT_FAIL_RETURN("Did not receive chreWifiAsyncEvent within time (sec): ",
85                        &time);
86   }
87 }
88 
getMessageDataFromHostEvent(uint32_t senderInstanceId,uint16_t eventType,const void * eventData,nanoapp_testing::MessageType expectedMessageType,uint32_t expectedMessageSize)89 const void *Test::getMessageDataFromHostEvent(
90     uint32_t senderInstanceId, uint16_t eventType, const void *eventData,
91     nanoapp_testing::MessageType expectedMessageType,
92     uint32_t expectedMessageSize) {
93   if (senderInstanceId != CHRE_INSTANCE_ID) {
94     sendInternalFailureToHost("Unexpected sender ID:", &senderInstanceId);
95   }
96   if (eventType != CHRE_EVENT_MESSAGE_FROM_HOST) {
97     unexpectedEvent(eventType);
98   }
99   if (eventData == nullptr) {
100     sendInternalFailureToHost("NULL eventData given");
101   }
102   auto data = static_cast<const chreMessageFromHostData *>(eventData);
103   if (data->reservedMessageType != uint32_t(expectedMessageType)) {
104     sendInternalFailureToHost("Unexpected reservedMessageType:",
105                               &(data->reservedMessageType));
106   }
107   if (data->messageSize != expectedMessageSize) {
108     sendInternalFailureToHost("Unexpected messageSize:", &(data->messageSize));
109   }
110   return data->message;
111 }
112 
113 }  // namespace general_test
114