Files
snapclient/components/esp_peripherals/test/esp_peripherals_test.c
Carlos 30d2e54dab - completely drop ADF but copy necessary parts
o copy component audio_board from ADF and create custom component from it
  o copy component audio_hal from ADF and create custom component from it
  o copy component audio_sal from ADF and create custom component from it
  o copy component esp_peripherals from ADF and create custom component from it
- add fLaC support through xiph's original repository as a git module
2021-09-05 20:20:36 +02:00

756 lines
24 KiB
C

/*
* ESPRESSIF MIT License
*
* Copyright (c) 2018 <ESPRESSIF SYSTEMS (SHANGHAI) PTE LTD>
*
* Permission is hereby granted for use on all ESPRESSIF SYSTEMS products, in
* which case, it is free of charge, to any person obtaining a copy of this
* software and associated documentation files (the "Software"), to deal in the
* Software without restriction, including without limitation the rights to
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
* IN THE SOFTWARE.
*
*/
#include "audio_event_iface.h"
#include "esp_err.h"
#include "esp_log.h"
#include "freertos/FreeRTOS.h"
#include "freertos/task.h"
#include <string.h>
#include <unistd.h>
#include "audio_mem.h"
#include "board.h"
#include "esp_peripherals.h"
#include "nvs_flash.h"
#include "periph_adc_button.h"
#include "periph_button.h"
#include "periph_console.h"
#include "periph_gpio_isr.h"
#include "periph_is31fl3216.h"
#include "periph_led.h"
#include "periph_sdcard.h"
#include "periph_spiffs.h"
#include "periph_touch.h"
#include "periph_wifi.h"
#include "periph_ws2812.h"
#include "tcpip_adapter.h"
#include "unity.h"
static const char *TAG = "ESP_PERIPH_TEST";
#define TEST_PERIPHERALS_MEMORY_LEAK_TIMES 1000
static void
periph_adc_button_test (void)
{
ESP_LOGI (TAG, "Set up peripherals handle");
esp_periph_config_t periph_cfg = DEFAULT_ESP_PERIPH_SET_CONFIG ();
esp_periph_set_handle_t set = esp_periph_set_init (&periph_cfg);
TEST_ASSERT_NOT_NULL (set);
ESP_LOGI (TAG, "Register ADC button to peripherals");
periph_adc_button_cfg_t adc_btn_cfg = PERIPH_ADC_BUTTON_DEFAULT_CONFIG ();
adc_arr_t adc_btn_tag = ADC_DEFAULT_ARR ();
adc_btn_tag.total_steps = 6;
int btn_array[7] = { 190, 600, 1000, 1375, 1775, 2195, 3100 };
adc_btn_tag.adc_level_step = btn_array;
adc_btn_cfg.arr = &adc_btn_tag;
adc_btn_cfg.arr_size = 1;
esp_periph_handle_t adc_btn_handle = periph_adc_button_init (&adc_btn_cfg);
TEST_ASSERT_NOT_NULL (adc_btn_handle);
TEST_ASSERT_FALSE (esp_periph_start (set, adc_btn_handle));
ESP_LOGI (TAG, "Set up event listener");
audio_event_iface_cfg_t evt_cfg = AUDIO_EVENT_IFACE_DEFAULT_CFG ();
audio_event_iface_handle_t evt = audio_event_iface_init (&evt_cfg);
TEST_ASSERT_NOT_NULL (evt);
ESP_LOGI (TAG, "Listening event from peripherals");
TEST_ASSERT_FALSE (audio_event_iface_set_listener (
esp_periph_set_get_event_iface (set), evt));
ESP_LOGI (TAG, "Test start, please press buttons on the board ... ");
while (1)
{
audio_event_iface_msg_t msg;
TEST_ASSERT_FALSE (audio_event_iface_listen (evt, &msg, portMAX_DELAY));
ESP_LOGI (TAG, "action: %d, act id: %d", msg.cmd, (int)msg.data);
if ((int)msg.data == 0)
{
ESP_LOGW (TAG, "press id 0, quit test");
break;
}
}
ESP_LOGI (TAG, "Quit test, release all resources");
TEST_ASSERT_FALSE (esp_periph_set_stop_all (set));
TEST_ASSERT_FALSE (audio_event_iface_remove_listener (
esp_periph_set_get_event_iface (set), evt));
TEST_ASSERT_FALSE (audio_event_iface_destroy (evt));
TEST_ASSERT_FALSE (esp_periph_set_destroy (set));
}
TEST_CASE ("adc button test", "[peripherals]") { periph_adc_button_test (); }
static void
periph_gpio_button_test (void)
{
ESP_LOGI (TAG, "Set up peripherals handle");
esp_periph_config_t periph_cfg = DEFAULT_ESP_PERIPH_SET_CONFIG ();
esp_periph_set_handle_t set = esp_periph_set_init (&periph_cfg);
TEST_ASSERT_NOT_NULL (set);
ESP_LOGI (TAG, "Register gpio button to peripherals");
periph_button_cfg_t btn_cfg = {
.gpio_mask = (1ULL << get_input_rec_id ())
| (1ULL << get_input_mode_id ()), // REC BTN & MODE BTN
};
esp_periph_handle_t button_handle = periph_button_init (&btn_cfg);
TEST_ASSERT_NOT_NULL (button_handle);
TEST_ASSERT_FALSE (esp_periph_start (set, button_handle));
ESP_LOGI (TAG, "Set up event listener");
audio_event_iface_cfg_t evt_cfg = AUDIO_EVENT_IFACE_DEFAULT_CFG ();
audio_event_iface_handle_t evt = audio_event_iface_init (&evt_cfg);
TEST_ASSERT_NOT_NULL (evt);
ESP_LOGI (TAG, "Listening event from peripherals");
TEST_ASSERT_FALSE (audio_event_iface_set_listener (
esp_periph_set_get_event_iface (set), evt));
ESP_LOGI (TAG, "Test start, please press buttons on the board ... ");
while (1)
{
audio_event_iface_msg_t msg;
TEST_ASSERT_FALSE (audio_event_iface_listen (evt, &msg, portMAX_DELAY));
ESP_LOGI (TAG, "action: %d, act id: %d", msg.cmd, (int)msg.data);
if ((int)msg.data == get_input_mode_id ())
{
ESP_LOGW (TAG, "press [mode] button, quit test");
break;
}
}
ESP_LOGI (TAG, "Quit test, release all resources");
TEST_ASSERT_FALSE (esp_periph_set_stop_all (set));
TEST_ASSERT_FALSE (audio_event_iface_remove_listener (
esp_periph_set_get_event_iface (set), evt));
TEST_ASSERT_FALSE (audio_event_iface_destroy (evt));
TEST_ASSERT_FALSE (esp_periph_set_destroy (set));
}
TEST_CASE ("gpio button test", "[peripherals]") { periph_gpio_button_test (); }
static esp_err_t
play_func (esp_periph_handle_t periph, int argc, char *argv[])
{
if (argc == 1)
{
ESP_LOGI (TAG, "play muisc, url:%s", argv[0]);
}
else if (argc == 0)
{
ESP_LOGI (TAG, "play");
}
else
{
ESP_LOGE (TAG, "error input");
}
return ESP_OK;
}
static esp_err_t
pause_func (esp_periph_handle_t periph, int argc, char *argv[])
{
if (argc == 0)
{
ESP_LOGI (TAG, "pause");
}
else
{
ESP_LOGE (TAG, "error input");
}
return ESP_OK;
}
static bool task_flag;
static esp_err_t
quit_func (esp_periph_handle_t periph, int argc, char *argv[])
{
if (argc == 0)
{
ESP_LOGI (TAG, "quit console");
task_flag = false;
}
else
{
ESP_LOGE (TAG, "error input");
}
return ESP_OK;
}
const periph_console_cmd_t cli_cmd[] = {
{
.cmd = "play",
.id = 0,
.help = "play music",
.func = play_func,
},
{
.cmd = "pause",
.id = 1,
.help = "pause music",
.func = pause_func,
},
{ .cmd = "quit", .id = 2, .help = "quit command line", .func = quit_func }
};
static void
periph_console_test (void)
{
ESP_LOGI (TAG, "Set up peripherals handle");
esp_periph_config_t periph_cfg = DEFAULT_ESP_PERIPH_SET_CONFIG ();
esp_periph_set_handle_t set = esp_periph_set_init (&periph_cfg);
TEST_ASSERT_NOT_NULL (set);
ESP_LOGI (TAG, "Register console to peripherals");
periph_console_cfg_t console_cfg = {
.command_num = sizeof (cli_cmd) / sizeof (periph_console_cmd_t),
.commands = cli_cmd,
};
esp_periph_handle_t console_handle = periph_console_init (&console_cfg);
TEST_ASSERT_NOT_NULL (console_handle);
task_flag = true;
ESP_LOGI (TAG, "Start console, please input ...");
TEST_ASSERT_FALSE (esp_periph_start (set, console_handle));
while (task_flag)
{
vTaskDelay (10 / portTICK_RATE_MS);
}
ESP_LOGI (TAG, "Quit test, release all resources");
TEST_ASSERT_FALSE (esp_periph_set_stop_all (set));
TEST_ASSERT_FALSE (esp_periph_set_destroy (set));
}
TEST_CASE ("console test", "[peripherals]") { periph_console_test (); }
static void
periph_gpio_isr_test (void)
{
ESP_LOGI (TAG, "Set up peripherals handle");
esp_periph_config_t periph_cfg = DEFAULT_ESP_PERIPH_SET_CONFIG ();
esp_periph_set_handle_t set = esp_periph_set_init (&periph_cfg);
TEST_ASSERT_NOT_NULL (set);
ESP_LOGI (TAG, "Register gpio isr to peripherals");
gpio_isr_info_t gpio_isr_info
= { .gpio_num = SDCARD_INTR_GPIO, .type = GPIO_INTR_ANYEDGE };
periph_gpio_isr_cfg_t gpio_isr_cfg
= { .info_size = 1, .gpio_isr_info = &gpio_isr_info };
esp_periph_handle_t gpio_isr_handle = periph_gpio_isr_init (&gpio_isr_cfg);
TEST_ASSERT_NOT_NULL (gpio_isr_handle);
TEST_ASSERT_FALSE (esp_periph_start (set, gpio_isr_handle));
ESP_LOGI (TAG, "Set up event listener");
audio_event_iface_cfg_t evt_cfg = AUDIO_EVENT_IFACE_DEFAULT_CFG ();
audio_event_iface_handle_t evt = audio_event_iface_init (&evt_cfg);
TEST_ASSERT_NOT_NULL (evt);
ESP_LOGI (TAG, "Listening event from peripherals, please insert a sdcard to "
"the board ...");
TEST_ASSERT_FALSE (audio_event_iface_set_listener (
esp_periph_set_get_event_iface (set), evt));
while (1)
{
audio_event_iface_msg_t msg;
TEST_ASSERT_FALSE (audio_event_iface_listen (evt, &msg, portMAX_DELAY));
if ((int)msg.data == SDCARD_INTR_GPIO)
{
ESP_LOGW (TAG, "Detect sdcard insertion, quit test");
break;
}
}
ESP_LOGI (TAG, "Quit test, release all resources");
TEST_ASSERT_FALSE (esp_periph_set_stop_all (set));
TEST_ASSERT_FALSE (audio_event_iface_remove_listener (
esp_periph_set_get_event_iface (set), evt));
TEST_ASSERT_FALSE (audio_event_iface_destroy (evt));
TEST_ASSERT_FALSE (esp_periph_set_destroy (set));
}
TEST_CASE ("gpio isr test", "[peripherals]") { periph_gpio_isr_test (); }
static void
periph_is31fl3216_test (void)
{
ESP_LOGI (TAG, "Set up peripherals handle");
esp_periph_config_t periph_cfg = DEFAULT_ESP_PERIPH_SET_CONFIG ();
esp_periph_set_handle_t set = esp_periph_set_init (&periph_cfg);
TEST_ASSERT_NOT_NULL (set);
periph_is31fl3216_cfg_t is31fl3216_cfg = { .state = IS31FL3216_STATE_ON };
ESP_LOGI (TAG, "Register gpio isr to peripherals");
esp_periph_handle_t is31fl3216_handle
= periph_is31fl3216_init (&is31fl3216_cfg);
TEST_ASSERT_FALSE (esp_periph_start (set, is31fl3216_handle));
for (int i = 0; i < BLUE_LED_MAX_NUM; i++)
{
TEST_ASSERT_FALSE (
periph_is31fl3216_set_duty (is31fl3216_handle, i, 255));
}
TEST_ASSERT_FALSE (periph_is31fl3216_set_light_on_num (is31fl3216_handle, 1,
BLUE_LED_MAX_NUM));
TEST_ASSERT_FALSE (periph_is31fl3216_set_interval (is31fl3216_handle, 100));
TEST_ASSERT_FALSE (periph_is31fl3216_set_shift_mode (
is31fl3216_handle, PERIPH_IS31_SHIFT_MODE_ACC));
TEST_ASSERT_FALSE (
periph_is31fl3216_set_state (is31fl3216_handle, IS31FL3216_STATE_SHIFT));
ESP_LOGI (TAG, "Start testing for 5 seconds...");
vTaskDelay (5000 / portTICK_RATE_MS);
ESP_LOGI (TAG, "Quit test, release all resources");
TEST_ASSERT_FALSE (esp_periph_set_stop_all (set));
TEST_ASSERT_FALSE (esp_periph_set_destroy (set));
}
TEST_CASE ("is31fl3216 test", "[peripherals]") { periph_is31fl3216_test (); }
static void
periph_led_test (void)
{
ESP_LOGI (TAG, "Set up peripherals handle");
esp_periph_config_t periph_cfg = DEFAULT_ESP_PERIPH_SET_CONFIG ();
esp_periph_set_handle_t set = esp_periph_set_init (&periph_cfg);
TEST_ASSERT_NOT_NULL (set);
periph_led_cfg_t led_cfg = {
.led_speed_mode = LEDC_LOW_SPEED_MODE,
.led_duty_resolution = LEDC_TIMER_10_BIT,
.led_timer_num = LEDC_TIMER_0,
.led_freq_hz = 5000,
};
esp_periph_handle_t led_handle = periph_led_init (&led_cfg);
TEST_ASSERT_FALSE (esp_periph_start (set, led_handle));
TEST_ASSERT_FALSE (periph_led_blink (led_handle, get_blue_led_gpio (), 1000,
1000, true, -1, 0));
TEST_ASSERT_FALSE (periph_led_blink (led_handle, get_green_led_gpio (), 500,
500, false, 4, 0));
ESP_LOGI (TAG, "running...");
vTaskDelay (1000 / portTICK_RATE_MS);
ESP_LOGI (TAG, "STOP BLUE LED");
TEST_ASSERT_FALSE (periph_led_stop (led_handle, get_blue_led_gpio ()));
vTaskDelay (1000 / portTICK_RATE_MS);
ESP_LOGI (TAG, "Changing blink preset...");
TEST_ASSERT_FALSE (periph_led_blink (led_handle, get_blue_led_gpio (), 500,
200, false, -1, 0));
TEST_ASSERT_FALSE (periph_led_blink (led_handle, get_green_led_gpio (), 500,
1000, true, -1, 0));
ESP_LOGI (TAG, "Quit test, release all resources");
TEST_ASSERT_FALSE (esp_periph_set_stop_all (set));
TEST_ASSERT_FALSE (esp_periph_set_destroy (set));
}
TEST_CASE ("led test", "[peripherals]") { periph_led_test (); }
static void
periph_sdcard_test (void)
{
ESP_LOGI (TAG, "Set up peripherals handle");
esp_periph_config_t periph_cfg = DEFAULT_ESP_PERIPH_SET_CONFIG ();
esp_periph_set_handle_t set = esp_periph_set_init (&periph_cfg);
TEST_ASSERT_NOT_NULL (set);
#ifdef CONFIG_ESP_LYRAT_MINI_V1_1_BOARD
gpio_config_t sdcard_pwr_pin_cfg = {
.pin_bit_mask = 1UL << SDCARD_PWR_CTRL,
.mode = GPIO_MODE_OUTPUT,
.pull_up_en = GPIO_PULLUP_DISABLE,
.pull_down_en = GPIO_PULLDOWN_DISABLE,
.intr_type = GPIO_INTR_DISABLE,
};
gpio_config (&sdcard_pwr_pin_cfg);
gpio_set_level (SDCARD_PWR_CTRL, 0);
#endif
periph_sdcard_cfg_t sdcard_cfg
= { .card_detect_pin = get_sdcard_intr_gpio (), .root = "/sdcard" };
esp_periph_handle_t sdcard_handle = periph_sdcard_init (&sdcard_cfg);
TEST_ASSERT_NOT_NULL (sdcard_handle);
TEST_ASSERT_FALSE (esp_periph_start (set, sdcard_handle));
while (!periph_sdcard_is_mounted (sdcard_handle))
{
vTaskDelay (500 / portTICK_PERIOD_MS);
}
ESP_LOGI (TAG, "Write a string to sdcard");
FILE *fp = fopen ("/sdcard/test", "w+");
TEST_ASSERT_NOT_NULL (fp);
char test_str[] = "hello, this is sdcard test";
TEST_ASSERT_EQUAL_INT (strlen (test_str),
fwrite (test_str, 1, strlen (test_str), fp));
TEST_ASSERT_FALSE (fsync (fileno (fp)));
TEST_ASSERT_FALSE (fclose (fp));
ESP_LOGI (TAG, "Read a string from sdcard");
fp = fopen ("/sdcard/test", "r");
TEST_ASSERT_NOT_NULL (fp);
char *read_str = audio_calloc (1, strlen (test_str) + 1);
TEST_ASSERT_NOT_NULL (read_str);
TEST_ASSERT_EQUAL_INT (strlen (test_str),
fread (read_str, 1, strlen (test_str), fp));
ESP_LOGW (TAG, "read string from sdcard file: %s", read_str);
TEST_ASSERT_EQUAL_INT (0, strncmp (read_str, test_str, strlen (test_str)));
ESP_LOGI (TAG, "Quit test, release all resources");
TEST_ASSERT_FALSE (esp_periph_set_stop_all (set));
TEST_ASSERT_FALSE (esp_periph_set_destroy (set));
free (read_str);
fclose (fp);
}
TEST_CASE ("sdcard test", "[peripherals]") { periph_sdcard_test (); }
static void
periph_spiffs_test (void)
{
ESP_LOGI (TAG, "Set up peripherals handle");
esp_periph_config_t periph_cfg = DEFAULT_ESP_PERIPH_SET_CONFIG ();
esp_periph_set_handle_t set = esp_periph_set_init (&periph_cfg);
TEST_ASSERT_NOT_NULL (set);
periph_spiffs_cfg_t spiffs_cfg = { .root = "/spiffs",
.max_files = 5,
.format_if_mount_failed = true,
.partition_label = NULL };
esp_periph_handle_t spiffs_handle = periph_spiffs_init (&spiffs_cfg);
TEST_ASSERT_NOT_NULL (spiffs_handle);
TEST_ASSERT_FALSE (esp_periph_start (set, spiffs_handle));
while (!periph_spiffs_is_mounted (spiffs_handle))
{
vTaskDelay (500 / portTICK_PERIOD_MS);
}
FILE *fp = fopen ("/spiffs/test", "w+");
TEST_ASSERT_NOT_NULL (fp);
char test_str[] = "hello, this is spiffs test";
TEST_ASSERT_EQUAL_INT (strlen (test_str),
fwrite (test_str, 1, strlen (test_str), fp));
TEST_ASSERT_FALSE (fclose (fp));
ESP_LOGI (TAG, "Read a string from spiffs");
fp = fopen ("/spiffs/test", "r");
TEST_ASSERT_NOT_NULL (fp);
char *read_str = audio_calloc (1, strlen (test_str) + 1);
TEST_ASSERT_NOT_NULL (read_str);
TEST_ASSERT_EQUAL_INT (strlen (test_str),
fread (read_str, 1, strlen (test_str), fp));
ESP_LOGW (TAG, "read string from spiffs file: %s", read_str);
TEST_ASSERT_EQUAL_INT (0, strncmp (read_str, test_str, strlen (test_str)));
fclose (fp);
ESP_LOGI (TAG, "Quit test, release all resources");
TEST_ASSERT_FALSE (esp_periph_set_stop_all (set));
TEST_ASSERT_FALSE (esp_periph_set_destroy (set));
free (read_str);
}
TEST_CASE ("spiffs test", "[peripherals]") { periph_spiffs_test (); }
static void
periph_touch_pad_test (void)
{
ESP_LOGI (TAG, "Set up peripherals handle");
esp_periph_config_t periph_cfg = DEFAULT_ESP_PERIPH_SET_CONFIG ();
esp_periph_set_handle_t set = esp_periph_set_init (&periph_cfg);
TEST_ASSERT_NOT_NULL (set);
ESP_LOGI (TAG, "Register touch pad to peripherals");
periph_touch_cfg_t touch_cfg = {
.touch_mask
= TOUCH_PAD_SEL4 | TOUCH_PAD_SEL7 | TOUCH_PAD_SEL8 | TOUCH_PAD_SEL9,
.tap_threshold_percent = 70,
};
esp_periph_handle_t touch_handle = periph_touch_init (&touch_cfg);
TEST_ASSERT_NOT_NULL (touch_handle);
TEST_ASSERT_FALSE (esp_periph_start (set, touch_handle));
ESP_LOGI (TAG, "Set up event listener");
audio_event_iface_cfg_t evt_cfg = AUDIO_EVENT_IFACE_DEFAULT_CFG ();
audio_event_iface_handle_t evt = audio_event_iface_init (&evt_cfg);
TEST_ASSERT_NOT_NULL (evt);
ESP_LOGI (TAG,
"Listening event from peripherals, please press the touch pad");
TEST_ASSERT_FALSE (audio_event_iface_set_listener (
esp_periph_set_get_event_iface (set), evt));
while (1)
{
audio_event_iface_msg_t msg;
TEST_ASSERT_FALSE (audio_event_iface_listen (evt, &msg, portMAX_DELAY));
if ((int)msg.data == get_input_set_id ())
{
ESP_LOGI (TAG, "[set] touched, quit test");
break;
}
if (msg.cmd == PERIPH_TOUCH_TAP)
{
if ((int)msg.data == get_input_play_id ())
{
ESP_LOGI (TAG, "[play] touched");
}
if ((int)msg.data == get_input_volup_id ())
{
ESP_LOGI (TAG, "[vol+] touched");
}
if ((int)msg.data == get_input_voldown_id ())
{
ESP_LOGI (TAG, "[vol-] touched");
}
}
if (msg.cmd == PERIPH_TOUCH_RELEASE)
{
if ((int)msg.data == get_input_play_id ())
{
ESP_LOGI (TAG, "[play] released");
}
if ((int)msg.data == get_input_volup_id ())
{
ESP_LOGI (TAG, "[vol+] released");
}
if ((int)msg.data == get_input_voldown_id ())
{
ESP_LOGI (TAG, "[vol-] released");
}
}
}
ESP_LOGI (TAG, "Quit test, release all resources");
TEST_ASSERT_FALSE (esp_periph_set_stop_all (set));
TEST_ASSERT_FALSE (audio_event_iface_remove_listener (
esp_periph_set_get_event_iface (set), evt));
TEST_ASSERT_FALSE (audio_event_iface_destroy (evt));
TEST_ASSERT_FALSE (esp_periph_set_destroy (set));
}
static void
periph_ws2812_test (void)
{
ESP_LOGI (TAG, "Set up peripherals handle");
esp_periph_config_t periph_cfg = DEFAULT_ESP_PERIPH_SET_CONFIG ();
esp_periph_set_handle_t set = esp_periph_set_init (&periph_cfg);
TEST_ASSERT_NOT_NULL (set);
periph_ws2812_cfg_t cfg = {
.gpio_num = GPIO_NUM_3,
.led_num = 2,
};
esp_periph_handle_t handle = periph_ws2812_init (&cfg);
TEST_ASSERT_FALSE (esp_periph_start (set, handle));
periph_ws2812_ctrl_cfg_t *control_cfg
= malloc (sizeof (periph_ws2812_ctrl_cfg_t) * cfg.led_num);
control_cfg[0].color = LED2812_COLOR_RED;
control_cfg[0].mode = PERIPH_WS2812_BLINK;
control_cfg[0].loop = 50;
control_cfg[0].time_off_ms = 100;
control_cfg[0].time_on_ms = 1000;
control_cfg[1].color = LED2812_COLOR_BLUE;
control_cfg[1].mode = PERIPH_WS2812_ONE;
control_cfg[1].loop = 50;
control_cfg[1].time_off_ms = 2000;
control_cfg[1].time_on_ms = 2000;
TEST_ASSERT_FALSE (periph_ws2812_control (handle, control_cfg, NULL));
vTaskDelay (5000 / portTICK_PERIOD_MS);
ESP_LOGI (TAG, "Quit test, release all resources");
TEST_ASSERT_FALSE (esp_periph_set_stop_all (set));
TEST_ASSERT_FALSE (esp_periph_set_destroy (set));
free (control_cfg);
}
TEST_CASE ("touch pad test", "[peripherals]") { periph_touch_pad_test (); }
static void
periph_wifi_test (void)
{
ESP_LOGI (TAG, "Set up peripherals handle");
esp_periph_config_t periph_cfg = DEFAULT_ESP_PERIPH_SET_CONFIG ();
esp_periph_set_handle_t set = esp_periph_set_init (&periph_cfg);
TEST_ASSERT_NOT_NULL (set);
ESP_LOGI (TAG, "Initialize wifi environment");
esp_err_t ret = nvs_flash_init ();
if (ret == ESP_ERR_NVS_NO_FREE_PAGES || ret == ESP_ERR_NVS_NEW_VERSION_FOUND)
{
ESP_ERROR_CHECK (nvs_flash_erase ());
ret = nvs_flash_init ();
}
ESP_ERROR_CHECK (ret);
tcpip_adapter_init ();
periph_wifi_cfg_t wifi_cfg = { 0 };
wifi_cfg.ssid = "ESP-Audio";
wifi_cfg.password = "esp123456";
esp_periph_handle_t wifi_handle = periph_wifi_init (&wifi_cfg);
esp_periph_start (set, wifi_handle);
periph_wifi_wait_for_connected (wifi_handle, portMAX_DELAY);
vTaskDelay (100 / portTICK_PERIOD_MS);
ESP_LOGI (TAG, "Quit test, release all resources");
TEST_ASSERT_FALSE (esp_periph_set_stop_all (set));
TEST_ASSERT_FALSE (esp_periph_set_destroy (set));
TEST_ASSERT_FALSE (nvs_flash_deinit ());
}
TEST_CASE ("wifi test", "[peripherals]") { periph_wifi_test (); }
TEST_CASE ("[memory leak test] [gpio isr]", "[peripherals]")
{
int test_count = TEST_PERIPHERALS_MEMORY_LEAK_TIMES;
while (test_count--)
{
printf ("-------Residual times: %d -------\n", test_count);
periph_gpio_isr_test ();
}
}
TEST_CASE ("[memory leak test] [adc button]", "[peripherals]")
{
int test_count = TEST_PERIPHERALS_MEMORY_LEAK_TIMES;
while (test_count--)
{
printf ("-------Residual times: %d -------\n", test_count);
periph_adc_button_test ();
}
}
TEST_CASE ("[memory leak test] [console]", "[peripherals]")
{
int test_count = TEST_PERIPHERALS_MEMORY_LEAK_TIMES;
while (test_count--)
{
printf ("-------Residual times: %d -------\n", test_count);
periph_console_test ();
}
}
TEST_CASE ("[memory leak test] [led]", "[peripherals]")
{
int test_count = TEST_PERIPHERALS_MEMORY_LEAK_TIMES;
while (test_count--)
{
printf ("-------Residual times: %d -------\n", test_count);
periph_led_test ();
}
}
TEST_CASE ("[memory leak test] [spiffs]", "[peripherals]")
{
int test_count = TEST_PERIPHERALS_MEMORY_LEAK_TIMES;
while (test_count--)
{
printf ("-------Residual times: %d -------\n", test_count);
periph_spiffs_test ();
}
}
TEST_CASE ("[memory leak test] [wifi]", "[peripherals]")
{
int test_count = TEST_PERIPHERALS_MEMORY_LEAK_TIMES;
while (test_count--)
{
printf ("-------Residual times: %d -------\n", test_count);
periph_wifi_test ();
}
}
TEST_CASE ("[memory leak test] [gpio button]", "[peripherals]")
{
int test_count = TEST_PERIPHERALS_MEMORY_LEAK_TIMES;
while (test_count--)
{
printf ("-------Residual times: %d -------\n", test_count);
periph_gpio_button_test ();
}
}
TEST_CASE ("[memory leak test] [is31fl3216]", "[peripherals]")
{
int test_count = TEST_PERIPHERALS_MEMORY_LEAK_TIMES;
while (test_count--)
{
printf ("-------Residual times: %d -------\n", test_count);
periph_is31fl3216_test ();
}
}
TEST_CASE ("[memory leak test] [sdcard]", "[peripherals]")
{
int test_count = TEST_PERIPHERALS_MEMORY_LEAK_TIMES;
while (test_count--)
{
printf ("-------Residual times: %d -------\n", test_count);
periph_sdcard_test ();
}
}
TEST_CASE ("[memory leak test] [touch]", "[peripherals]")
{
int test_count = TEST_PERIPHERALS_MEMORY_LEAK_TIMES;
while (test_count--)
{
printf ("-------Residual times: %d -------\n", test_count);
periph_touch_pad_test ();
}
}
TEST_CASE ("[memory leak test] [ws2812]", "[peripherals]")
{
int test_count = TEST_PERIPHERALS_MEMORY_LEAK_TIMES;
while (test_count--)
{
printf ("-------Residual times: %d -------\n", test_count);
periph_ws2812_test ();
}
}