test_runner.c 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  1. // Copyright 2016-2018 Espressif Systems (Shanghai) PTE LTD
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. #include <stdio.h>
  15. #include "string.h"
  16. #include "esp_heap_caps.h"
  17. #include "freertos/FreeRTOS.h"
  18. #include "freertos/task.h"
  19. #include "unity.h"
  20. #include "test_utils.h"
  21. #include "esp_newlib.h"
  22. #ifdef CONFIG_HEAP_TRACING
  23. #include "esp_heap_trace.h"
  24. #endif
  25. static size_t before_free_8bit;
  26. static size_t before_free_32bit;
  27. static size_t warn_leak_threshold;
  28. static size_t critical_leak_threshold;
  29. static void unity_task(void *pvParameters)
  30. {
  31. vTaskDelay(2); /* Delay a bit to let the main task be deleted */
  32. unity_run_menu(); /* Doesn't return */
  33. }
  34. void test_main(void)
  35. {
  36. // Note: if unpinning this task, change the way run times are calculated in
  37. // unity_port_esp32.c
  38. xTaskCreatePinnedToCore(unity_task, "unityTask", UNITY_FREERTOS_STACK_SIZE, NULL,
  39. UNITY_FREERTOS_PRIORITY, NULL, UNITY_FREERTOS_CPU);
  40. }
  41. void unity_reset_leak_checks(void)
  42. {
  43. before_free_8bit = heap_caps_get_free_size(MALLOC_CAP_8BIT);
  44. before_free_32bit = heap_caps_get_free_size(MALLOC_CAP_32BIT);
  45. #ifdef CONFIG_HEAP_TRACING
  46. heap_trace_start(HEAP_TRACE_LEAKS);
  47. #endif
  48. }
  49. /* setUp runs before every test */
  50. void setUp(void)
  51. {
  52. // If heap tracing is enabled in kconfig, leak trace the test
  53. #ifdef CONFIG_HEAP_TRACING
  54. const size_t num_heap_records = 80;
  55. static heap_trace_record_t *record_buffer;
  56. if (!record_buffer) {
  57. record_buffer = malloc(sizeof(heap_trace_record_t) * num_heap_records);
  58. assert(record_buffer);
  59. heap_trace_init_standalone(record_buffer, num_heap_records);
  60. }
  61. #endif
  62. printf("%s", ""); /* sneakily lazy-allocate the reent structure for this test task */
  63. #ifdef CONFIG_APP_BUILD_USE_FLASH_SECTIONS
  64. /* TODO: add sufficient startup code in case of building an ELF file, so that
  65. * flash cache is initialized and can work in such mode.
  66. * For now this is disabled to allow running unit tests which don't require
  67. * flash cache related operations.
  68. */
  69. get_test_data_partition(); /* allocate persistent partition table structures */
  70. #endif // CONFIG_APP_BUILD_USE_FLASH_SECTIONS
  71. unity_reset_leak_checks();
  72. test_utils_set_leak_level(CONFIG_UNITY_CRITICAL_LEAK_LEVEL_GENERAL, TYPE_LEAK_CRITICAL, COMP_LEAK_GENERAL);
  73. test_utils_set_leak_level(CONFIG_UNITY_WARN_LEAK_LEVEL_GENERAL, TYPE_LEAK_WARNING, COMP_LEAK_GENERAL);
  74. }
  75. static void check_leak(size_t before_free, size_t after_free, const char *type)
  76. {
  77. if (before_free <= after_free) {
  78. return;
  79. }
  80. size_t leaked = before_free - after_free;
  81. if (leaked <= warn_leak_threshold) {
  82. return;
  83. }
  84. printf("MALLOC_CAP_%s %s leak: Before %u bytes free, After %u bytes free (delta %u)\n",
  85. type,
  86. leaked <= critical_leak_threshold ? "potential" : "critical",
  87. before_free, after_free, leaked);
  88. fflush(stdout);
  89. TEST_ASSERT_MESSAGE(leaked <= critical_leak_threshold, "The test leaked too much memory");
  90. }
  91. static bool leak_check_required(void)
  92. {
  93. warn_leak_threshold = test_utils_get_leak_level(TYPE_LEAK_WARNING, COMP_LEAK_ALL);
  94. critical_leak_threshold = test_utils_get_leak_level(TYPE_LEAK_CRITICAL, COMP_LEAK_ALL);
  95. if (Unity.CurrentDetail1 != NULL) {
  96. const char *leaks = "[leaks";
  97. const int len_leaks = strlen(leaks);
  98. const char *sub_leaks = strstr(Unity.CurrentDetail1, leaks);
  99. if (sub_leaks != NULL) {
  100. if (sub_leaks[len_leaks] == ']') {
  101. return true;
  102. } else if (sub_leaks[len_leaks] == '=') {
  103. critical_leak_threshold = strtol(&sub_leaks[len_leaks + 1], NULL, 10);
  104. warn_leak_threshold = critical_leak_threshold;
  105. return false;
  106. }
  107. }
  108. }
  109. return false;
  110. }
  111. /* tearDown runs after every test */
  112. void tearDown(void)
  113. {
  114. /* some FreeRTOS stuff is cleaned up by idle task */
  115. vTaskDelay(5);
  116. /* clean up some of the newlib's lazy allocations */
  117. esp_reent_cleanup();
  118. size_t after_free_8bit = heap_caps_get_free_size(MALLOC_CAP_8BIT);
  119. size_t after_free_32bit = heap_caps_get_free_size(MALLOC_CAP_32BIT);
  120. /* We want the teardown to have this file in the printout if TEST_ASSERT fails */
  121. const char *real_testfile = Unity.TestFile;
  122. Unity.TestFile = __FILE__;
  123. /* check if unit test has caused heap corruption in any heap */
  124. TEST_ASSERT_MESSAGE( heap_caps_check_integrity(MALLOC_CAP_INVALID, true), "The test has corrupted the heap");
  125. /* check for leaks */
  126. #ifdef CONFIG_HEAP_TRACING
  127. heap_trace_stop();
  128. heap_trace_dump();
  129. #endif
  130. if (leak_check_required() == false) {
  131. check_leak(before_free_8bit, after_free_8bit, "8BIT");
  132. check_leak(before_free_32bit, after_free_32bit, "32BIT");
  133. }
  134. Unity.TestFile = real_testfile; // go back to the real filename
  135. }