test_touch_slider.c 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  1. #include <stdio.h>
  2. #include <string.h>
  3. #include <stdlib.h>
  4. #include <time.h>
  5. #include "freertos/FreeRTOS.h"
  6. #include "freertos/task.h"
  7. #include "freertos/queue.h"
  8. #include "freertos/semphr.h"
  9. #include "unity.h"
  10. #include "touch_element/touch_element_private.h"
  11. #include "touch_element/touch_slider.h"
  12. static const touch_pad_t slider_channel_array[5] = {
  13. TOUCH_PAD_NUM1,
  14. TOUCH_PAD_NUM2,
  15. TOUCH_PAD_NUM3,
  16. TOUCH_PAD_NUM4,
  17. TOUCH_PAD_NUM5
  18. };
  19. static const float slider_sens_array[5] = {
  20. 0.1F,
  21. 0.1F,
  22. 0.1F,
  23. 0.1F,
  24. 0.1F
  25. };
  26. const uint8_t SLIDER_CHANNEL_NUM = sizeof(slider_channel_array) / sizeof(touch_pad_t);
  27. typedef struct {
  28. QueueHandle_t valid_msg_handle;
  29. SemaphoreHandle_t response_sig_handle;
  30. } test_monitor_t;
  31. /* ------------------------------------------------------------------------------------------------------------------ */
  32. void test_slider_event_simulator(touch_slider_handle_t slider_handle, touch_slider_event_t slider_event, uint32_t random);
  33. void test_slider_event_check(touch_elem_message_t *valid_message, touch_elem_message_t *current_message);
  34. static void test_slider_callback_check(touch_slider_handle_t current_handle, touch_slider_message_t *current_message, touch_elem_message_t *valid_message);
  35. void test_slider_event_trigger_and_check(touch_slider_handle_t handle, touch_slider_event_t slider_event, uint32_t random_channel);
  36. void test_slider_callback_trigger_and_check(touch_slider_handle_t handle, touch_slider_event_t slider_event, bool should_trigger, test_monitor_t *monitor, uint32_t random_channel);
  37. /* ------------------------------------------------ Dispatch method test -------------------------------------------- */
  38. static void test_slider_disp_event(void);
  39. static void test_slider_disp_callback(void);
  40. static void test_slider_handler(touch_slider_handle_t handle, touch_slider_message_t *message, void *arg);
  41. /* ------------------------------------------------------------------------------------------------------------------ */
  42. TEST_CASE("Touch slider dispatch methods test", "[slider][touch_element]")
  43. {
  44. touch_elem_global_config_t global_config = TOUCH_ELEM_GLOBAL_DEFAULT_CONFIG();
  45. TEST_ESP_OK(touch_element_install(&global_config));
  46. test_slider_disp_event();
  47. test_slider_disp_callback();
  48. touch_element_uninstall();
  49. }
  50. void test_slider_event_simulator(touch_slider_handle_t slider_handle, touch_slider_event_t slider_event, uint32_t random)
  51. {
  52. te_slider_handle_t te_slider = (te_slider_handle_t) slider_handle;
  53. touch_pad_t channel = te_slider->device[random % te_slider->channel_sum]->channel;
  54. if (slider_event == TOUCH_SLIDER_EVT_ON_PRESS) {
  55. touch_pad_set_cnt_mode(channel, TOUCH_PAD_SLOPE_3, TOUCH_PAD_TIE_OPT_DEFAULT);
  56. } else if (slider_event == TOUCH_SLIDER_EVT_ON_RELEASE) {
  57. touch_pad_set_cnt_mode(channel, TOUCH_PAD_SLOPE_7, TOUCH_PAD_TIE_OPT_DEFAULT);
  58. }
  59. }
  60. void test_slider_event_check(touch_elem_message_t *valid_message, touch_elem_message_t *current_message)
  61. {
  62. TEST_ASSERT_MESSAGE(current_message->handle == valid_message->handle, "check handle failed");
  63. TEST_ASSERT_MESSAGE(current_message->element_type == valid_message->element_type, "check element type failed");
  64. const touch_slider_message_t *valid_slider_message = touch_slider_get_message(valid_message);
  65. const touch_slider_message_t *current_slider_message = touch_slider_get_message(current_message);
  66. TEST_ASSERT_MESSAGE(current_slider_message->event == valid_slider_message->event, "check event failed");
  67. }
  68. static void test_slider_callback_check(touch_slider_handle_t current_handle, touch_slider_message_t *current_message, touch_elem_message_t *valid_message)
  69. {
  70. const touch_slider_message_t *valid_slider_message = touch_slider_get_message(valid_message);
  71. TEST_ASSERT_MESSAGE(valid_message->handle == current_handle, "check handle failed");
  72. TEST_ASSERT_MESSAGE(valid_message->element_type == TOUCH_ELEM_TYPE_SLIDER, "check element type failed");
  73. TEST_ASSERT_MESSAGE(valid_slider_message->event == current_message->event, "check event failed");
  74. }
  75. void test_slider_event_trigger_and_check(touch_slider_handle_t handle, touch_slider_event_t slider_event, uint32_t random_channel)
  76. {
  77. touch_elem_message_t valid_message, current_message;
  78. touch_slider_message_t slider_message;
  79. valid_message.handle = handle;
  80. valid_message.element_type = TOUCH_ELEM_TYPE_SLIDER;
  81. slider_message.event = slider_event;
  82. memcpy(valid_message.child_msg, &slider_message, sizeof(touch_slider_message_t));
  83. test_slider_event_simulator(handle, slider_event, random_channel);
  84. esp_err_t ret = touch_element_message_receive(&current_message, 300);
  85. TEST_ASSERT_MESSAGE(ret == ESP_OK, "slider event receive timeout");
  86. test_slider_event_check(&valid_message, &current_message);
  87. }
  88. void test_slider_callback_trigger_and_check(touch_slider_handle_t handle, touch_slider_event_t slider_event, bool should_trigger, test_monitor_t *monitor, uint32_t random_channel)
  89. {
  90. if (should_trigger) {
  91. touch_elem_message_t valid_message = {
  92. .handle = handle,
  93. .element_type = TOUCH_ELEM_TYPE_SLIDER,
  94. .arg = NULL
  95. };
  96. touch_slider_message_t slider_message = {
  97. .event = slider_event,
  98. .position = 0 //No use
  99. };
  100. memcpy(valid_message.child_msg, &slider_message, sizeof(touch_slider_message_t)); //Construct valid_message
  101. xQueueSend(monitor->valid_msg_handle, &valid_message, portMAX_DELAY);
  102. }
  103. test_slider_event_simulator(handle, slider_event, random_channel); //Trigger signal
  104. BaseType_t os_ret = xSemaphoreTake(monitor->response_sig_handle, pdMS_TO_TICKS(300));
  105. if (should_trigger) {
  106. TEST_ASSERT_MESSAGE(os_ret == pdPASS, "Button queue timeout");
  107. } else {
  108. TEST_ASSERT_MESSAGE(os_ret == pdFALSE, "Button invalid trigger");
  109. }
  110. }
  111. static void test_slider_disp_event(void)
  112. {
  113. touch_slider_handle_t slider_handle;
  114. touch_slider_global_config_t global_config = TOUCH_SLIDER_GLOBAL_DEFAULT_CONFIG();
  115. TEST_ESP_OK(touch_slider_install(&global_config));
  116. /*< Create Touch Slider */
  117. touch_slider_config_t slider_config = {
  118. .channel_array = slider_channel_array,
  119. .sensitivity_array = slider_sens_array,
  120. .channel_num = SLIDER_CHANNEL_NUM,
  121. .position_range = 101
  122. };
  123. TEST_ESP_OK(touch_slider_create(&slider_config, &slider_handle));
  124. TEST_ESP_OK(touch_slider_subscribe_event(slider_handle, TOUCH_ELEM_EVENT_ON_PRESS | TOUCH_ELEM_EVENT_ON_RELEASE, (void *) slider_handle));
  125. TEST_ESP_OK(touch_slider_set_dispatch_method(slider_handle, TOUCH_ELEM_DISP_EVENT));
  126. TEST_ESP_OK(touch_element_start());
  127. vTaskDelay(pdMS_TO_TICKS(500)); //Mention in README, code-block-1
  128. srandom((unsigned int)time(NULL));
  129. //10 times random (x channels) press/release test
  130. printf("Touch slider event test start\n");
  131. for (int i = 0; i < 10; i++) {
  132. printf("Touch slider event test... (%d/10)\n", i + 1);
  133. uint32_t random_channel = random() % SLIDER_CHANNEL_NUM;
  134. test_slider_event_trigger_and_check(slider_handle, TOUCH_SLIDER_EVT_ON_PRESS, random_channel);
  135. test_slider_event_trigger_and_check(slider_handle, TOUCH_SLIDER_EVT_ON_RELEASE, random_channel);
  136. }
  137. printf("Touch slider event test finish\n");
  138. TEST_ESP_OK(touch_element_stop());
  139. TEST_ESP_OK(touch_slider_delete(slider_handle));
  140. touch_slider_uninstall();
  141. }
  142. static void test_slider_disp_callback(void)
  143. {
  144. test_monitor_t monitor;
  145. monitor.valid_msg_handle = xQueueCreate(10, sizeof(touch_elem_message_t));
  146. monitor.response_sig_handle = xSemaphoreCreateBinary();
  147. TEST_ASSERT(monitor.valid_msg_handle != NULL || monitor.response_sig_handle != NULL);
  148. touch_slider_handle_t slider_handle;
  149. touch_slider_global_config_t global_config = TOUCH_SLIDER_GLOBAL_DEFAULT_CONFIG();
  150. TEST_ESP_OK(touch_slider_install(&global_config));
  151. touch_slider_config_t slider_config = {
  152. .channel_array = slider_channel_array,
  153. .sensitivity_array = slider_sens_array,
  154. .channel_num = SLIDER_CHANNEL_NUM,
  155. .position_range = 101
  156. };
  157. TEST_ESP_OK(touch_slider_create(&slider_config, &slider_handle));
  158. TEST_ESP_OK(touch_slider_subscribe_event(slider_handle, TOUCH_ELEM_EVENT_ON_PRESS | TOUCH_ELEM_EVENT_ON_RELEASE, (void *) &monitor));
  159. TEST_ESP_OK(touch_slider_set_dispatch_method(slider_handle, TOUCH_ELEM_DISP_CALLBACK));
  160. TEST_ESP_OK(touch_slider_set_callback(slider_handle, test_slider_handler));
  161. TEST_ESP_OK(touch_element_start());
  162. vTaskDelay(pdMS_TO_TICKS(500)); //Mention in README, code-block-1
  163. srandom((unsigned int)time(NULL));
  164. printf("Touch slider callback test start\n");
  165. for (int i = 0; i < 10; i++) {
  166. printf("Touch slider callback test... (%d/10)\n", i + 1);
  167. uint32_t random_channel = random() % SLIDER_CHANNEL_NUM;
  168. test_slider_callback_trigger_and_check(slider_handle, TOUCH_SLIDER_EVT_ON_PRESS, true, &monitor, random_channel);
  169. test_slider_callback_trigger_and_check(slider_handle, TOUCH_SLIDER_EVT_ON_RELEASE, true, &monitor, random_channel);
  170. }
  171. printf("Touch slider callback test finish\n");
  172. TEST_ESP_OK(touch_element_stop());
  173. TEST_ESP_OK(touch_slider_delete(slider_handle));
  174. touch_slider_uninstall();
  175. vQueueDelete(monitor.valid_msg_handle);
  176. vSemaphoreDelete(monitor.response_sig_handle);
  177. }
  178. static void test_slider_handler(touch_slider_handle_t handle, touch_slider_message_t *message, void *arg)
  179. {
  180. test_monitor_t *monitor = (test_monitor_t *)arg;
  181. touch_elem_message_t valid_message;
  182. BaseType_t os_ret = xQueueReceive(monitor->valid_msg_handle, &valid_message, pdMS_TO_TICKS(200)); //Get the valid message for verification, 200ms timeout
  183. TEST_ASSERT_MESSAGE(os_ret == pdPASS, "test_slider_handler: queue timeout");
  184. test_slider_callback_check(handle, message, &valid_message); //Verification
  185. xSemaphoreGive(monitor->response_sig_handle);
  186. }