/* * SPDX-FileCopyrightText: 2022 Espressif Systems (Shanghai) CO LTD * * SPDX-License-Identifier: Apache-2.0 */ #pragma once #include #ifdef __cplusplus extern "C" { #endif /** * @brief Adjust the allowed memory leak thresholds for unit tests. * * Usually, unit tests will check if memory is leaked. Some functionality used by unit tests may unavoidably * leak memory. This function allows to adjust that memory leak threshold. * * @param leak_level Maximum allowed memory leak which will not trigger a unit test failure. */ void unity_utils_set_leak_level(size_t leak_level); /** * @brief Start/Restart memory leak checking. * * Records the current free memory values at time of calling. After the test case, it may be checked with * \c unity_utils_finish_and_evaluate_leaks. * * If this function is called repeatedly, only the free memory values at the last time of calling will prevail * as reference. */ void unity_utils_record_free_mem(void); /** * @brief Calculate leaks and check they are below against a threshold * * This function is for internal use, users shouldn't have a reason to call this. * * Calculates the leak from \c before_free and \c after_free and checks that the difference does not exceed * \c threshold. It uses a unity assert to to the check and report in case of failure. * A summary of the leaked data will be printed in all cases. */ void unity_utils_check_leak(unsigned int before_free, unsigned int after_free, const char *type, unsigned int threshold); /** * @brief Evaluate memory leak checking according to the provided thresholds. * * If the current memory leak level (counted from the last time calling \c unity_utils_record_free_mem() ) exceeds * \c threshold, a unit test failure will be triggered. */ void unity_utils_evaluate_leaks_direct(size_t threshold); /** * @brief Evaluate memory leaks. * * If the current memory leak level (counted from the last time calling \c unity_utils_record_free_mem() ) exceeds * the threshold set before via \c unity_utils_set_leak_level(), a unit test failure will be triggered. * * @note The user MUST set the allowed leak threshold before via \c unity_utils_set_leak_level(), otherwise the * allowed leak threshold is undefined. */ void unity_utils_evaluate_leaks(void); /** * @brief Helper function to setup and initialize heap tracing. * * @param num_heap_records the size of the heap record buffer, * counted in number of heap record elements (heap_trace_record_t). * Use a default value of 80 if no special requirements need to be met. */ void unity_utils_setup_heap_record(size_t num_heap_records); #ifdef __cplusplus } #endif