2022-03-31 18:16:19 +08:00
|
|
|
/*
|
|
|
|
* SPDX-FileCopyrightText: 2022 Espressif Systems (Shanghai) CO LTD
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <stddef.h>
|
|
|
|
|
|
|
|
#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.
|
|
|
|
*
|
2022-11-28 11:51:20 +01:00
|
|
|
* @param num_heap_records the size of the heap record buffer,
|
2022-03-31 18:16:19 +08:00
|
|
|
* 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
|