/*
* 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_SHARED_SEND_MESSAGE_H_
#define _GTS_NANOAPPS_SHARED_SEND_MESSAGE_H_
#include <cstddef>
#include <cstdint>
#include <shared/abort.h>
/**
* NOTE: The MessageType values are manually synced in the GTS Java's
* ContextHubTestConstants.java. If you make a change here, be sure
* to update ContextHubTestContants.java as well.
*/
namespace nanoapp_testing {
/**
* Messages types which are sent between Nanoapps and the Java Host testing
* code.
*/
enum class MessageType : uint32_t {
/**
* Value which should never be used.
*
* This value starts at CONTEXT_HUB_TYPE_PRIVATE_MSG_BASE.
*
* This type should never be sent by Host or Nanoapp code.
*/
kInvalidMessageType = 0x0400,
/**
* Test has completed in success.
*
* This type should only be sent by the Nanoapp code.
*/
kSuccess = 0x0401,
/**
* Indicates a failure in the CHRE implementation.
*
* This should be followed by null-terminated string
* giving details of failure.
*
* This type should only be sent by the Nanoapp code.
*/
kFailure = 0x0402,
/**
* Indicate a failure within the testing infrastructure.
*
* This should be followed by null-terminated string
* giving details of failure.
*
* This type should only be sent by the Nanoapp code.
*/
kInternalFailure = 0x0403,
/**
* Indicate a test is being skipped.
*
* This should be followed by null-terminated string
* giving an explanation of why this test was skipped.
*
* This type should only be sent by the Nanoapp code.
*/
kSkipped = 0x0404,
/**
* A generic message indicating that the test should continue.
*
* The meaning of this generic message depends on the specific test.
* In general, it means something along the lines of "The test is
* successful thus far, please proceed to the next stage."
*
* This type can be sent by the Host or Nanoapp code.
*/
kContinue = 0x0405,
// Tests wanting to add custom message types for their protocols should
// add them below. Remember to update ContextHubTestConstants.java as
// well (see NOTE at the top of this header).
};
/**
* Sends a message to the host with the given data.
*
* This method will make a copy of 'data', so there's no need for the
* caller to keep that alive after this call.
*
* Note it may often be more convenient to use one the other methods
* when sending a text string.
*
* @param messageType The type of the message.
* @param data The data to send. This can be nullptr, but then 'dataSize'
* must be 0.
* @param dataSize The number of bytes of 'data' to send. If 'data' is
* not 'nullptr', then this must be non-zero.
*/
void sendMessageToHost(MessageType messageType, const void *data = nullptr,
size_t dataSize = 0);
/**
* Sends a message to the host, optionally with the 'value' appended as in
* hex.
*
* This method will make a copy of 'message' and 'value', so there's no
* need for the caller to keep those alive after this call.
*
* Note it may often be more convenient to use one of the other methods
* below.
*
* @param messageType The type of the message.
* @param message The text of the message. This cannot be nullptr.
* @param value Optional, defaults to nullptr. If non-null, this value will
* be output as hexadecimal at the end of the message to the host.
*/
void sendStringToHost(MessageType messageType, const char *message,
const uint32_t *value = nullptr);
/**
* Same as sendStringToHost(), but using MessageType::kFailure for the 'status'.
*/
inline void sendFailureToHost(const char *message,
const uint32_t *value = nullptr) {
sendStringToHost(MessageType::kFailure, message, value);
}
/**
* Same as sendFailureToHost(), but aborts the test with the given 'reason',
* and never returns.
*/
void sendFatalFailureToHost(const char *message,
const uint32_t *value = nullptr,
AbortBlame reason = AbortBlame::kChre);
/**
* Helper function to invoke sendFatalFailureToHost() with uint8_t type.
* It is needed since sendFatalFailureToHost() only accepts uint32_t type.
*
* TODO: Deprecate this function and redesign sendFatalFailureToHost()
* so that a generic string message is accepted.
*
* @param message a text message to be sent to host.
* @param value a value output into the message.
*/
void sendFatalFailureToHostUint8(const char *message, const uint8_t value);
/**
* Same as sendStringToHost(), but uses MessageType::kInternalFailure for the
* 'status', and aborts the test with the given 'reason' and never returns.
*/
void sendInternalFailureToHost(const char *message,
const uint32_t *value = nullptr,
AbortBlame reason = AbortBlame::kTestFramework);
/**
* Invoke sendMessageToHost with MessageType::kSuccess and no other information.
*/
inline void sendSuccessToHost() {
sendMessageToHost(MessageType::kSuccess);
}
} // namespace nanoapp_testing
#endif // _GTS_NANOAPPS_SHARED_SEND_MESSAGE_H_