#include #include #include "../minunit.h" #include #include #include #include #include #include #include #define TAG "SubGhz TEST" #define KEYSTORE_DIR_NAME EXT_PATH("subghz/assets/keeloq_mfcodes") #define CAME_ATOMO_DIR_NAME EXT_PATH("subghz/assets/came_atomo") #define NICE_FLOR_S_DIR_NAME EXT_PATH("subghz/assets/nice_flor_s") #define TEST_RANDOM_DIR_NAME EXT_PATH("unit_tests/subghz/test_random_raw.sub") #define TEST_RANDOM_COUNT_PARSE 253 #define TEST_TIMEOUT 10000 static SubGhzEnvironment* environment_handler; static SubGhzReceiver* receiver_handler; //static SubGhzTransmitter* transmitter_handler; static SubGhzFileEncoderWorker* file_worker_encoder_handler; static uint16_t subghz_test_decoder_count = 0; static void subghz_test_rx_callback( SubGhzReceiver* receiver, SubGhzProtocolDecoderBase* decoder_base, void* context) { UNUSED(receiver); UNUSED(context); FuriString* text; text = furi_string_alloc(); subghz_protocol_decoder_base_get_string(decoder_base, text); subghz_receiver_reset(receiver_handler); FURI_LOG_T(TAG, "\r\n%s", furi_string_get_cstr(text)); furi_string_free(text); subghz_test_decoder_count++; } static void subghz_test_init(void) { environment_handler = subghz_environment_alloc(); subghz_environment_set_came_atomo_rainbow_table_file_name( environment_handler, CAME_ATOMO_DIR_NAME); subghz_environment_set_nice_flor_s_rainbow_table_file_name( environment_handler, NICE_FLOR_S_DIR_NAME); subghz_environment_set_protocol_registry( environment_handler, (void*)&subghz_protocol_registry); receiver_handler = subghz_receiver_alloc_init(environment_handler); subghz_receiver_set_filter(receiver_handler, SubGhzProtocolFlag_Decodable); subghz_receiver_set_rx_callback(receiver_handler, subghz_test_rx_callback, NULL); } static void subghz_test_deinit(void) { subghz_receiver_free(receiver_handler); subghz_environment_free(environment_handler); } static bool subghz_decoder_test(const char* path, const char* name_decoder) { subghz_test_decoder_count = 0; uint32_t test_start = furi_get_tick(); SubGhzProtocolDecoderBase* decoder = subghz_receiver_search_decoder_base_by_name(receiver_handler, name_decoder); if(decoder) { file_worker_encoder_handler = subghz_file_encoder_worker_alloc(); if(subghz_file_encoder_worker_start(file_worker_encoder_handler, path)) { // the worker needs a file in order to open and read part of the file furi_delay_ms(100); LevelDuration level_duration; while(furi_get_tick() - test_start < TEST_TIMEOUT) { level_duration = subghz_file_encoder_worker_get_level_duration(file_worker_encoder_handler); if(!level_duration_is_reset(level_duration)) { bool level = level_duration_get_level(level_duration); uint32_t duration = level_duration_get_duration(level_duration); // Yield, to load data inside the worker furi_thread_yield(); decoder->protocol->decoder->feed(decoder, level, duration); } else { break; } } furi_delay_ms(10); } if(subghz_file_encoder_worker_is_running(file_worker_encoder_handler)) { subghz_file_encoder_worker_stop(file_worker_encoder_handler); } subghz_file_encoder_worker_free(file_worker_encoder_handler); } FURI_LOG_T(TAG, "\r\n Decoder count parse \033[0;33m%d\033[0m ", subghz_test_decoder_count); if(furi_get_tick() - test_start > TEST_TIMEOUT) { printf("\033[0;31mTest decoder %s ERROR TimeOut\033[0m\r\n", name_decoder); return false; } else { return subghz_test_decoder_count ? true : false; } } static bool subghz_decode_random_test(const char* path) { subghz_test_decoder_count = 0; subghz_receiver_reset(receiver_handler); uint32_t test_start = furi_get_tick(); file_worker_encoder_handler = subghz_file_encoder_worker_alloc(); if(subghz_file_encoder_worker_start(file_worker_encoder_handler, path)) { // the worker needs a file in order to open and read part of the file furi_delay_ms(100); LevelDuration level_duration; while(furi_get_tick() - test_start < TEST_TIMEOUT * 10) { level_duration = subghz_file_encoder_worker_get_level_duration(file_worker_encoder_handler); if(!level_duration_is_reset(level_duration)) { bool level = level_duration_get_level(level_duration); uint32_t duration = level_duration_get_duration(level_duration); // Yield, to load data inside the worker furi_thread_yield(); subghz_receiver_decode(receiver_handler, level, duration); } else { break; } } furi_delay_ms(10); if(subghz_file_encoder_worker_is_running(file_worker_encoder_handler)) { subghz_file_encoder_worker_stop(file_worker_encoder_handler); } subghz_file_encoder_worker_free(file_worker_encoder_handler); } FURI_LOG_D(TAG, "\r\n Decoder count parse \033[0;33m%d\033[0m ", subghz_test_decoder_count); if(furi_get_tick() - test_start > TEST_TIMEOUT * 10) { printf("\033[0;31mRandom test ERROR TimeOut\033[0m\r\n"); return false; } else if(subghz_test_decoder_count == TEST_RANDOM_COUNT_PARSE) { return true; } else { return false; } } static bool subghz_encoder_test(const char* path) { subghz_test_decoder_count = 0; uint32_t test_start = furi_get_tick(); FuriString* temp_str; temp_str = furi_string_alloc(); bool file_load = false; Storage* storage = furi_record_open(RECORD_STORAGE); FlipperFormat* fff_data_file = flipper_format_file_alloc(storage); do { if(!flipper_format_file_open_existing(fff_data_file, path)) { FURI_LOG_E(TAG, "Error open file %s", path); break; } if(!flipper_format_read_string(fff_data_file, "Preset", temp_str)) { FURI_LOG_E(TAG, "Missing Preset"); break; } if(!flipper_format_read_string(fff_data_file, "Protocol", temp_str)) { FURI_LOG_E(TAG, "Missing Protocol"); break; } file_load = true; } while(false); if(file_load) { SubGhzTransmitter* transmitter = subghz_transmitter_alloc_init(environment_handler, furi_string_get_cstr(temp_str)); subghz_transmitter_deserialize(transmitter, fff_data_file); SubGhzProtocolDecoderBase* decoder = subghz_receiver_search_decoder_base_by_name( receiver_handler, furi_string_get_cstr(temp_str)); if(decoder) { LevelDuration level_duration; while(furi_get_tick() - test_start < TEST_TIMEOUT) { level_duration = subghz_transmitter_yield(transmitter); if(!level_duration_is_reset(level_duration)) { bool level = level_duration_get_level(level_duration); uint32_t duration = level_duration_get_duration(level_duration); decoder->protocol->decoder->feed(decoder, level, duration); } else { break; } } furi_delay_ms(10); } subghz_transmitter_free(transmitter); } flipper_format_free(fff_data_file); FURI_LOG_T(TAG, "\r\n Decoder count parse \033[0;33m%d\033[0m ", subghz_test_decoder_count); if(furi_get_tick() - test_start > TEST_TIMEOUT) { printf( "\033[0;31mTest encoder %s ERROR TimeOut\033[0m\r\n", furi_string_get_cstr(temp_str)); subghz_test_decoder_count = 0; } furi_string_free(temp_str); return subghz_test_decoder_count ? true : false; } static bool subghz_custom_preset_test(void) { static const uint8_t preset_data[][2] = { {CC1101_MDMCFG0, 0}, {CC1101_MDMCFG1, 0}, {CC1101_MDMCFG2, 0}, {CC1101_MDMCFG3, 0}, {CC1101_MDMCFG4, 0}, }; static uint8_t test_data[sizeof(preset_data)] = {0}; memcpy(test_data, preset_data, sizeof(preset_data)); uint8_t* test_data_ptr = &test_data[0]; { // CHEKING BANDWIDTH SET for(uint32_t i = 0; i < CH_BANDWIDTH_NUM; ++i) { uint8_t bw_value = subghz_preset_custom_bandwidth_values[i]; bool result = subghz_preset_custom_set_bandwidth(test_data_ptr, sizeof(test_data), bw_value); if(!result) { FURI_LOG_E(TAG, "Failed to set BW value: %hhu", bw_value); return false; } uint8_t get_bw_value = subghz_preset_custom_get_bandwidth(test_data_ptr, sizeof(test_data)); if(get_bw_value != bw_value) { FURI_LOG_E( TAG, "BW value from preset: %hhu is not equal expected value: %hhu", get_bw_value, bw_value); return false; } FURI_LOG_T(TAG, "Bandwidth check OK: %hhu", bw_value); } } { // CHEKING MACHESTER SET bool result = subghz_preset_custom_set_machester_enable(test_data_ptr, sizeof(test_data), false); if(!result) { FURI_LOG_E(TAG, "Failed to set manchester enable flag"); return false; } bool flag = subghz_preset_custom_get_machester_enable(test_data_ptr, sizeof(test_data)); if(flag != false) { FURI_LOG_E(TAG, "Manchester disable flag setup failed!"); return false; } subghz_preset_custom_set_machester_enable(test_data_ptr, sizeof(test_data), true); flag = subghz_preset_custom_get_machester_enable(test_data_ptr, sizeof(test_data)); if(flag != true) { FURI_LOG_E(TAG, "Manchester enable flag setup failed!"); return false; } FURI_LOG_T(TAG, "Manchester flag check OK"); } { // CHEKING DATARATE SET const float datarateRoughMax = 1600000.0f; // bauds const float datarateRoughStep = 5000.0f; const float datarateFineMax = 30000.0f; const float datarateFineStep = 50.0f; bool result = false; char datarate_set_str[16] = {0}; char datarate_get_str[16] = {0}; float datarate_set = datarateRoughMax; float datarate_get = -1.0f; while(datarate_set > 0) { subghz_preset_custom_printf_datarate( datarate_set, datarate_set_str, sizeof(datarate_set_str)); result = subghz_preset_custom_set_datarate(test_data_ptr, sizeof(test_data), datarate_set); if(!result) { FURI_LOG_E(TAG, "Failed to set datarate: %s!", datarate_set_str); return false; } datarate_get = subghz_preset_custom_get_datarate(test_data_ptr, sizeof(test_data)); subghz_preset_custom_printf_datarate( datarate_get, datarate_get_str, sizeof(datarate_get_str)); if(datarate_get < 0) { FURI_LOG_E(TAG, "Failed to get datarate!"); return false; } if(datarate_set > datarateFineMax) { result = fabsf(datarate_get - datarate_set) <= datarateRoughStep; datarate_set -= datarateRoughStep; } else { result = fabsf(datarate_get - datarate_set) <= datarateFineStep; datarate_set -= datarateFineStep; } if(result) { FURI_LOG_T( TAG, "Datarate check OK: Set: %s - Get: %s", datarate_set_str, datarate_get_str); } else { FURI_LOG_E( TAG, "Datarate check failed!: %s is way to diff %s! DRATE_E: %hhu DRATE_M: %hhu", datarate_set_str, datarate_get_str, test_data[4 * 2 + 1] & 0b00001111, test_data[3 * 2 + 1]); return false; } } } FURI_LOG_I(TAG, "Sub GHz custom preset test: OK"); return true; } MU_TEST(subghz_keystore_test) { mu_assert( subghz_environment_load_keystore(environment_handler, KEYSTORE_DIR_NAME), "Test keystore error"); } typedef enum { SubGhzHalAsyncTxTestTypeNormal, SubGhzHalAsyncTxTestTypeInvalidStart, SubGhzHalAsyncTxTestTypeInvalidMid, SubGhzHalAsyncTxTestTypeInvalidEnd, SubGhzHalAsyncTxTestTypeResetStart, SubGhzHalAsyncTxTestTypeResetMid, SubGhzHalAsyncTxTestTypeResetEnd, } SubGhzHalAsyncTxTestType; typedef struct { SubGhzHalAsyncTxTestType type; size_t pos; } SubGhzHalAsyncTxTest; #define SUBGHZ_HAL_TEST_DURATION 1 static LevelDuration subghz_hal_async_tx_test_yield(void* context) { SubGhzHalAsyncTxTest* test = context; bool is_odd = test->pos % 2; if(test->type == SubGhzHalAsyncTxTestTypeNormal) { if(test->pos < API_HAL_SUBGHZ_ASYNC_TX_BUFFER_FULL * 8) { test->pos++; return level_duration_make(is_odd, SUBGHZ_HAL_TEST_DURATION); } else if(test->pos == API_HAL_SUBGHZ_ASYNC_TX_BUFFER_FULL * 8) { test->pos++; return level_duration_reset(); } else { furi_crash("Yield after reset"); } } else if(test->type == SubGhzHalAsyncTxTestTypeInvalidStart) { if(test->pos == 0) { test->pos++; return level_duration_make(!is_odd, SUBGHZ_HAL_TEST_DURATION); } else if(test->pos < API_HAL_SUBGHZ_ASYNC_TX_BUFFER_FULL * 8) { test->pos++; return level_duration_make(is_odd, SUBGHZ_HAL_TEST_DURATION); } else if(test->pos == API_HAL_SUBGHZ_ASYNC_TX_BUFFER_FULL * 8) { test->pos++; return level_duration_reset(); } else { furi_crash("Yield after reset"); } } else if(test->type == SubGhzHalAsyncTxTestTypeInvalidMid) { if(test->pos == API_HAL_SUBGHZ_ASYNC_TX_BUFFER_HALF / 2) { test->pos++; return level_duration_make(!is_odd, SUBGHZ_HAL_TEST_DURATION); } else if(test->pos < API_HAL_SUBGHZ_ASYNC_TX_BUFFER_FULL * 8) { test->pos++; return level_duration_make(is_odd, SUBGHZ_HAL_TEST_DURATION); } else if(test->pos == API_HAL_SUBGHZ_ASYNC_TX_BUFFER_FULL * 8) { test->pos++; return level_duration_reset(); } else { furi_crash("Yield after reset"); } } else if(test->type == SubGhzHalAsyncTxTestTypeInvalidEnd) { if(test->pos == API_HAL_SUBGHZ_ASYNC_TX_BUFFER_FULL - 1) { test->pos++; return level_duration_make(!is_odd, SUBGHZ_HAL_TEST_DURATION); } else if(test->pos < API_HAL_SUBGHZ_ASYNC_TX_BUFFER_FULL * 8) { test->pos++; return level_duration_make(is_odd, SUBGHZ_HAL_TEST_DURATION); } else if(test->pos == API_HAL_SUBGHZ_ASYNC_TX_BUFFER_FULL * 8) { test->pos++; return level_duration_reset(); } else { furi_crash("Yield after reset"); } } else if(test->type == SubGhzHalAsyncTxTestTypeResetStart) { if(test->pos == 0) { test->pos++; return level_duration_reset(); } else { furi_crash("Yield after reset"); } } else if(test->type == SubGhzHalAsyncTxTestTypeResetMid) { if(test->pos < API_HAL_SUBGHZ_ASYNC_TX_BUFFER_HALF / 2) { test->pos++; return level_duration_make(is_odd, SUBGHZ_HAL_TEST_DURATION); } else if(test->pos == API_HAL_SUBGHZ_ASYNC_TX_BUFFER_HALF / 2) { test->pos++; return level_duration_reset(); } else { furi_crash("Yield after reset"); } } else if(test->type == SubGhzHalAsyncTxTestTypeResetEnd) { if(test->pos < API_HAL_SUBGHZ_ASYNC_TX_BUFFER_FULL - 1) { test->pos++; return level_duration_make(is_odd, SUBGHZ_HAL_TEST_DURATION); } else if(test->pos == API_HAL_SUBGHZ_ASYNC_TX_BUFFER_FULL - 1) { test->pos++; return level_duration_reset(); } else { furi_crash("Yield after reset"); } } else { furi_crash("Programming error"); } } bool subghz_hal_async_tx_test_run(SubGhzHalAsyncTxTestType type) { SubGhzHalAsyncTxTest test = {0}; test.type = type; furi_hal_subghz_reset(); furi_hal_subghz_load_preset(FuriHalSubGhzPresetOok650Async); furi_hal_subghz_set_frequency_and_path(433920000); if(!furi_hal_subghz_start_async_tx(subghz_hal_async_tx_test_yield, &test)) { return false; } while(!furi_hal_subghz_is_async_tx_complete()) { furi_delay_ms(10); } furi_hal_subghz_stop_async_tx(); furi_hal_subghz_sleep(); return true; } MU_TEST(subghz_hal_async_tx_test) { mu_assert( subghz_hal_async_tx_test_run(SubGhzHalAsyncTxTestTypeNormal), "Test furi_hal_async_tx normal"); mu_assert( subghz_hal_async_tx_test_run(SubGhzHalAsyncTxTestTypeInvalidStart), "Test furi_hal_async_tx invalid start"); mu_assert( subghz_hal_async_tx_test_run(SubGhzHalAsyncTxTestTypeInvalidMid), "Test furi_hal_async_tx invalid mid"); mu_assert( subghz_hal_async_tx_test_run(SubGhzHalAsyncTxTestTypeInvalidEnd), "Test furi_hal_async_tx invalid end"); mu_assert( subghz_hal_async_tx_test_run(SubGhzHalAsyncTxTestTypeResetStart), "Test furi_hal_async_tx reset start"); mu_assert( subghz_hal_async_tx_test_run(SubGhzHalAsyncTxTestTypeResetMid), "Test furi_hal_async_tx reset mid"); mu_assert( subghz_hal_async_tx_test_run(SubGhzHalAsyncTxTestTypeResetEnd), "Test furi_hal_async_tx reset end"); } //test decoders MU_TEST(subghz_decoder_came_atomo_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/came_atomo_raw.sub"), SUBGHZ_PROTOCOL_CAME_ATOMO_NAME), "Test decoder " SUBGHZ_PROTOCOL_CAME_ATOMO_NAME " error\r\n"); } MU_TEST(subghz_decoder_came_test) { mu_assert( subghz_decoder_test(EXT_PATH("unit_tests/subghz/came_raw.sub"), SUBGHZ_PROTOCOL_CAME_NAME), "Test decoder " SUBGHZ_PROTOCOL_CAME_NAME " error\r\n"); } MU_TEST(subghz_decoder_came_twee_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/came_twee_raw.sub"), SUBGHZ_PROTOCOL_CAME_TWEE_NAME), "Test decoder " SUBGHZ_PROTOCOL_CAME_TWEE_NAME " error\r\n"); } MU_TEST(subghz_decoder_faac_slh_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/faac_slh_raw.sub"), SUBGHZ_PROTOCOL_FAAC_SLH_NAME), "Test decoder " SUBGHZ_PROTOCOL_FAAC_SLH_NAME " error\r\n"); } MU_TEST(subghz_decoder_gate_tx_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/gate_tx_raw.sub"), SUBGHZ_PROTOCOL_GATE_TX_NAME), "Test decoder " SUBGHZ_PROTOCOL_GATE_TX_NAME " error\r\n"); } MU_TEST(subghz_decoder_hormann_hsm_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/hormann_hsm_raw.sub"), SUBGHZ_PROTOCOL_HORMANN_HSM_NAME), "Test decoder " SUBGHZ_PROTOCOL_HORMANN_HSM_NAME " error\r\n"); } MU_TEST(subghz_decoder_ido_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/ido_117_111_raw.sub"), SUBGHZ_PROTOCOL_IDO_NAME), "Test decoder " SUBGHZ_PROTOCOL_IDO_NAME " error\r\n"); } MU_TEST(subghz_decoder_keelog_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/doorhan_raw.sub"), SUBGHZ_PROTOCOL_KEELOQ_NAME), "Test decoder " SUBGHZ_PROTOCOL_KEELOQ_NAME " error\r\n"); } MU_TEST(subghz_decoder_kia_seed_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/kia_seed_raw.sub"), SUBGHZ_PROTOCOL_KIA_NAME), "Test decoder " SUBGHZ_PROTOCOL_KIA_NAME " error\r\n"); } MU_TEST(subghz_decoder_nero_radio_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/nero_radio_raw.sub"), SUBGHZ_PROTOCOL_NERO_RADIO_NAME), "Test decoder " SUBGHZ_PROTOCOL_NERO_RADIO_NAME " error\r\n"); } MU_TEST(subghz_decoder_nero_sketch_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/nero_sketch_raw.sub"), SUBGHZ_PROTOCOL_NERO_SKETCH_NAME), "Test decoder " SUBGHZ_PROTOCOL_NERO_SKETCH_NAME " error\r\n"); } MU_TEST(subghz_decoder_nice_flo_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/nice_flo_raw.sub"), SUBGHZ_PROTOCOL_NICE_FLO_NAME), "Test decoder " SUBGHZ_PROTOCOL_NICE_FLO_NAME " error\r\n"); } MU_TEST(subghz_decoder_nice_flor_s_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/nice_flor_s_raw.sub"), SUBGHZ_PROTOCOL_NICE_FLOR_S_NAME), "Test decoder " SUBGHZ_PROTOCOL_NICE_FLOR_S_NAME " error\r\n"); } MU_TEST(subghz_decoder_princeton_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/Princeton_raw.sub"), SUBGHZ_PROTOCOL_PRINCETON_NAME), "Test decoder " SUBGHZ_PROTOCOL_PRINCETON_NAME " error\r\n"); } MU_TEST(subghz_decoder_scher_khan_magic_code_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/scher_khan_magic_code.sub"), SUBGHZ_PROTOCOL_SCHER_KHAN_NAME), "Test decoder " SUBGHZ_PROTOCOL_SCHER_KHAN_NAME " error\r\n"); } MU_TEST(subghz_decoder_somfy_keytis_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/Somfy_keytis_raw.sub"), SUBGHZ_PROTOCOL_SOMFY_KEYTIS_NAME), "Test decoder " SUBGHZ_PROTOCOL_SOMFY_KEYTIS_NAME " error\r\n"); } MU_TEST(subghz_decoder_somfy_telis_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/somfy_telis_raw.sub"), SUBGHZ_PROTOCOL_SOMFY_TELIS_NAME), "Test decoder " SUBGHZ_PROTOCOL_SOMFY_TELIS_NAME " error\r\n"); } MU_TEST(subghz_decoder_star_line_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/cenmax_raw.sub"), SUBGHZ_PROTOCOL_STAR_LINE_NAME), "Test decoder " SUBGHZ_PROTOCOL_STAR_LINE_NAME " error\r\n"); } MU_TEST(subghz_decoder_linear_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/linear_raw.sub"), SUBGHZ_PROTOCOL_LINEAR_NAME), "Test decoder " SUBGHZ_PROTOCOL_LINEAR_NAME " error\r\n"); } MU_TEST(subghz_decoder_megacode_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/megacode_raw.sub"), SUBGHZ_PROTOCOL_MEGACODE_NAME), "Test decoder " SUBGHZ_PROTOCOL_MEGACODE_NAME " error\r\n"); } MU_TEST(subghz_decoder_secplus_v1_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/security_pls_1_0_raw.sub"), SUBGHZ_PROTOCOL_SECPLUS_V1_NAME), "Test decoder " SUBGHZ_PROTOCOL_SECPLUS_V1_NAME " error\r\n"); } MU_TEST(subghz_decoder_secplus_v2_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/security_pls_2_0_raw.sub"), SUBGHZ_PROTOCOL_SECPLUS_V2_NAME), "Test decoder " SUBGHZ_PROTOCOL_SECPLUS_V2_NAME " error\r\n"); } MU_TEST(subghz_decoder_holtek_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/holtek_raw.sub"), SUBGHZ_PROTOCOL_HOLTEK_NAME), "Test decoder " SUBGHZ_PROTOCOL_HOLTEK_NAME " error\r\n"); } MU_TEST(subghz_decoder_power_smart_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/power_smart_raw.sub"), SUBGHZ_PROTOCOL_POWER_SMART_NAME), "Test decoder " SUBGHZ_PROTOCOL_POWER_SMART_NAME " error\r\n"); } MU_TEST(subghz_decoder_marantec_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/marantec_raw.sub"), SUBGHZ_PROTOCOL_MARANTEC_NAME), "Test decoder " SUBGHZ_PROTOCOL_MARANTEC_NAME " error\r\n"); } MU_TEST(subghz_decoder_bett_test) { mu_assert( subghz_decoder_test(EXT_PATH("unit_tests/subghz/bett_raw.sub"), SUBGHZ_PROTOCOL_BETT_NAME), "Test decoder " SUBGHZ_PROTOCOL_BETT_NAME " error\r\n"); } MU_TEST(subghz_decoder_doitrand_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/doitrand_raw.sub"), SUBGHZ_PROTOCOL_DOITRAND_NAME), "Test decoder " SUBGHZ_PROTOCOL_DOITRAND_NAME " error\r\n"); } MU_TEST(subghz_decoder_phoenix_v2_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/phoenix_v2_raw.sub"), SUBGHZ_PROTOCOL_PHOENIX_V2_NAME), "Test decoder " SUBGHZ_PROTOCOL_PHOENIX_V2_NAME " error\r\n"); } MU_TEST(subghz_decoder_honeywell_wdb_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/honeywell_wdb_raw.sub"), SUBGHZ_PROTOCOL_HONEYWELL_WDB_NAME), "Test decoder " SUBGHZ_PROTOCOL_HONEYWELL_WDB_NAME " error\r\n"); } MU_TEST(subghz_decoder_magellan_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/magellan_raw.sub"), SUBGHZ_PROTOCOL_MAGELLAN_NAME), "Test decoder " SUBGHZ_PROTOCOL_MAGELLAN_NAME " error\r\n"); } MU_TEST(subghz_decoder_intertechno_v3_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/intertechno_v3_raw.sub"), SUBGHZ_PROTOCOL_INTERTECHNO_V3_NAME), "Test decoder " SUBGHZ_PROTOCOL_INTERTECHNO_V3_NAME " error\r\n"); } MU_TEST(subghz_decoder_clemsa_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/clemsa_raw.sub"), SUBGHZ_PROTOCOL_CLEMSA_NAME), "Test decoder " SUBGHZ_PROTOCOL_CLEMSA_NAME " error\r\n"); } MU_TEST(subghz_decoder_ansonic_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/ansonic_raw.sub"), SUBGHZ_PROTOCOL_ANSONIC_NAME), "Test decoder " SUBGHZ_PROTOCOL_ANSONIC_NAME " error\r\n"); } MU_TEST(subghz_decoder_smc5326_test) { mu_assert( subghz_decoder_test( EXT_PATH("unit_tests/subghz/smc5326_raw.sub"), SUBGHZ_PROTOCOL_SMC5326_NAME), "Test decoder " SUBGHZ_PROTOCOL_SMC5326_NAME " error\r\n"); } //test encoders MU_TEST(subghz_encoder_princeton_test) { mu_assert( subghz_encoder_test(EXT_PATH("unit_tests/subghz/princeton.sub")), "Test encoder " SUBGHZ_PROTOCOL_PRINCETON_NAME " error\r\n"); } MU_TEST(subghz_encoder_came_test) { mu_assert( subghz_encoder_test(EXT_PATH("unit_tests/subghz/came.sub")), "Test encoder " SUBGHZ_PROTOCOL_CAME_NAME " error\r\n"); } MU_TEST(subghz_encoder_came_twee_test) { mu_assert( subghz_encoder_test(EXT_PATH("unit_tests/subghz/came_twee.sub")), "Test encoder " SUBGHZ_PROTOCOL_CAME_TWEE_NAME " error\r\n"); } MU_TEST(subghz_encoder_gate_tx_test) { mu_assert( subghz_encoder_test(EXT_PATH("unit_tests/subghz/gate_tx.sub")), "Test encoder " SUBGHZ_PROTOCOL_GATE_TX_NAME " error\r\n"); } MU_TEST(subghz_encoder_nice_flo_test) { mu_assert( subghz_encoder_test(EXT_PATH("unit_tests/subghz/nice_flo.sub")), "Test encoder " SUBGHZ_PROTOCOL_NICE_FLO_NAME " error\r\n"); } MU_TEST(subghz_encoder_keelog_test) { mu_assert( subghz_encoder_test(EXT_PATH("unit_tests/subghz/doorhan.sub")), "Test encoder " SUBGHZ_PROTOCOL_KEELOQ_NAME " error\r\n"); } MU_TEST(subghz_encoder_linear_test) { mu_assert( subghz_encoder_test(EXT_PATH("unit_tests/subghz/linear.sub")), "Test encoder " SUBGHZ_PROTOCOL_LINEAR_NAME " error\r\n"); } MU_TEST(subghz_encoder_megacode_test) { mu_assert( subghz_encoder_test(EXT_PATH("unit_tests/subghz/megacode.sub")), "Test encoder " SUBGHZ_PROTOCOL_MEGACODE_NAME " error\r\n"); } MU_TEST(subghz_encoder_holtek_test) { mu_assert( subghz_encoder_test(EXT_PATH("unit_tests/subghz/holtek.sub")), "Test encoder " SUBGHZ_PROTOCOL_HOLTEK_NAME " error\r\n"); } MU_TEST(subghz_encoder_secplus_v1_test) { mu_assert( subghz_encoder_test(EXT_PATH("unit_tests/subghz/security_pls_1_0.sub")), "Test encoder " SUBGHZ_PROTOCOL_SECPLUS_V1_NAME " error\r\n"); } MU_TEST(subghz_encoder_secplus_v2_test) { mu_assert( subghz_encoder_test(EXT_PATH("unit_tests/subghz/security_pls_2_0.sub")), "Test encoder " SUBGHZ_PROTOCOL_SECPLUS_V2_NAME " error\r\n"); } MU_TEST(subghz_encoder_power_smart_test) { mu_assert( subghz_encoder_test(EXT_PATH("unit_tests/subghz/power_smart.sub")), "Test encoder " SUBGHZ_PROTOCOL_POWER_SMART_NAME " error\r\n"); } MU_TEST(subghz_encoder_marantec_test) { mu_assert( subghz_encoder_test(EXT_PATH("unit_tests/subghz/marantec.sub")), "Test encoder " SUBGHZ_PROTOCOL_MARANTEC_NAME " error\r\n"); } MU_TEST(subghz_encoder_bett_test) { mu_assert( subghz_encoder_test(EXT_PATH("unit_tests/subghz/bett.sub")), "Test encoder " SUBGHZ_PROTOCOL_BETT_NAME " error\r\n"); } MU_TEST(subghz_encoder_doitrand_test) { mu_assert( subghz_encoder_test(EXT_PATH("unit_tests/subghz/doitrand.sub")), "Test encoder " SUBGHZ_PROTOCOL_DOITRAND_NAME " error\r\n"); } MU_TEST(subghz_encoder_phoenix_v2_test) { mu_assert( subghz_encoder_test(EXT_PATH("unit_tests/subghz/phoenix_v2.sub")), "Test encoder " SUBGHZ_PROTOCOL_PHOENIX_V2_NAME " error\r\n"); } MU_TEST(subghz_encoder_honeywell_wdb_test) { mu_assert( subghz_encoder_test(EXT_PATH("unit_tests/subghz/honeywell_wdb.sub")), "Test encoder " SUBGHZ_PROTOCOL_HONEYWELL_WDB_NAME " error\r\n"); } MU_TEST(subghz_encoder_magellan_test) { mu_assert( subghz_encoder_test(EXT_PATH("unit_tests/subghz/magellan.sub")), "Test encoder " SUBGHZ_PROTOCOL_MAGELLAN_NAME " error\r\n"); } MU_TEST(subghz_encoder_intertechno_v3_test) { mu_assert( subghz_encoder_test(EXT_PATH("unit_tests/subghz/intertechno_v3.sub")), "Test encoder " SUBGHZ_PROTOCOL_INTERTECHNO_V3_NAME " error\r\n"); } MU_TEST(subghz_encoder_clemsa_test) { mu_assert( subghz_encoder_test(EXT_PATH("unit_tests/subghz/clemsa.sub")), "Test encoder " SUBGHZ_PROTOCOL_CLEMSA_NAME " error\r\n"); } MU_TEST(subghz_encoder_ansonic_test) { mu_assert( subghz_encoder_test(EXT_PATH("unit_tests/subghz/ansonic.sub")), "Test encoder " SUBGHZ_PROTOCOL_ANSONIC_NAME " error\r\n"); } MU_TEST(subghz_encoder_smc5326_test) { mu_assert( subghz_encoder_test(EXT_PATH("unit_tests/subghz/smc5326.sub")), "Test encoder " SUBGHZ_PROTOCOL_SMC5326_NAME " error\r\n"); } MU_TEST(subghz_random_test) { mu_assert(subghz_decode_random_test(TEST_RANDOM_DIR_NAME), "Random test error\r\n"); } MU_TEST(subghz_preset_test) { mu_assert(subghz_custom_preset_test(), "Custom preset logic error\r\n"); } MU_TEST_SUITE(subghz) { subghz_test_init(); MU_RUN_TEST(subghz_keystore_test); MU_RUN_TEST(subghz_hal_async_tx_test); MU_RUN_TEST(subghz_decoder_came_atomo_test); MU_RUN_TEST(subghz_decoder_came_test); MU_RUN_TEST(subghz_decoder_came_twee_test); MU_RUN_TEST(subghz_decoder_faac_slh_test); MU_RUN_TEST(subghz_decoder_gate_tx_test); MU_RUN_TEST(subghz_decoder_hormann_hsm_test); MU_RUN_TEST(subghz_decoder_ido_test); MU_RUN_TEST(subghz_decoder_keelog_test); MU_RUN_TEST(subghz_decoder_kia_seed_test); MU_RUN_TEST(subghz_decoder_nero_radio_test); MU_RUN_TEST(subghz_decoder_nero_sketch_test); MU_RUN_TEST(subghz_decoder_nice_flo_test); MU_RUN_TEST(subghz_decoder_nice_flor_s_test); MU_RUN_TEST(subghz_decoder_princeton_test); MU_RUN_TEST(subghz_decoder_scher_khan_magic_code_test); MU_RUN_TEST(subghz_decoder_somfy_keytis_test); MU_RUN_TEST(subghz_decoder_somfy_telis_test); MU_RUN_TEST(subghz_decoder_star_line_test); MU_RUN_TEST(subghz_decoder_linear_test); MU_RUN_TEST(subghz_decoder_megacode_test); MU_RUN_TEST(subghz_decoder_secplus_v1_test); MU_RUN_TEST(subghz_decoder_secplus_v2_test); MU_RUN_TEST(subghz_decoder_holtek_test); MU_RUN_TEST(subghz_decoder_power_smart_test); MU_RUN_TEST(subghz_decoder_marantec_test); MU_RUN_TEST(subghz_decoder_bett_test); MU_RUN_TEST(subghz_decoder_doitrand_test); MU_RUN_TEST(subghz_decoder_phoenix_v2_test); MU_RUN_TEST(subghz_decoder_honeywell_wdb_test); MU_RUN_TEST(subghz_decoder_magellan_test); MU_RUN_TEST(subghz_decoder_intertechno_v3_test); MU_RUN_TEST(subghz_decoder_clemsa_test); MU_RUN_TEST(subghz_decoder_ansonic_test); MU_RUN_TEST(subghz_decoder_smc5326_test); MU_RUN_TEST(subghz_encoder_princeton_test); MU_RUN_TEST(subghz_encoder_came_test); MU_RUN_TEST(subghz_encoder_came_twee_test); MU_RUN_TEST(subghz_encoder_gate_tx_test); MU_RUN_TEST(subghz_encoder_nice_flo_test); MU_RUN_TEST(subghz_encoder_keelog_test); MU_RUN_TEST(subghz_encoder_linear_test); MU_RUN_TEST(subghz_encoder_megacode_test); MU_RUN_TEST(subghz_encoder_holtek_test); MU_RUN_TEST(subghz_encoder_secplus_v1_test); MU_RUN_TEST(subghz_encoder_secplus_v2_test); MU_RUN_TEST(subghz_encoder_power_smart_test); MU_RUN_TEST(subghz_encoder_marantec_test); MU_RUN_TEST(subghz_encoder_bett_test); MU_RUN_TEST(subghz_encoder_doitrand_test); MU_RUN_TEST(subghz_encoder_phoenix_v2_test); MU_RUN_TEST(subghz_encoder_honeywell_wdb_test); MU_RUN_TEST(subghz_encoder_magellan_test); MU_RUN_TEST(subghz_encoder_intertechno_v3_test); MU_RUN_TEST(subghz_encoder_clemsa_test); MU_RUN_TEST(subghz_encoder_ansonic_test); MU_RUN_TEST(subghz_encoder_smc5326_test); MU_RUN_TEST(subghz_random_test); subghz_test_deinit(); } MU_TEST_SUITE(subghz_app) { MU_RUN_TEST(subghz_preset_test); } int run_minunit_test_subghz() { MU_RUN_SUITE(subghz); return MU_EXIT_CODE; } int run_minunit_test_subghz_app() { MU_RUN_SUITE(subghz_app); return MU_EXIT_CODE; }