subghz_test.c 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407
  1. #include <furi.h>
  2. #include <furi_hal.h>
  3. #include "../minunit.h"
  4. #include <lib/subghz/receiver.h>
  5. #include <lib/subghz/transmitter.h>
  6. #include <lib/subghz/subghz_keystore.h>
  7. #include <lib/subghz/subghz_file_encoder_worker.h>
  8. #include <lib/subghz/protocols/registry.h>
  9. #include <flipper_format/flipper_format_i.h>
  10. #define TAG "SubGhz TEST"
  11. #define KEYSTORE_DIR_NAME "/ext/subghz/assets/keeloq_mfcodes"
  12. #define CAME_ATOMO_DIR_NAME "/ext/subghz/assets/came_atomo"
  13. #define NICE_FLOR_S_DIR_NAME "/ext/subghz/assets/nice_flor_s"
  14. #define TEST_RANDOM_DIR_NAME "/ext/unit_tests/subghz/test_random_raw.sub"
  15. #define TEST_RANDOM_COUNT_PARSE 59
  16. #define TEST_TIMEOUT 10000
  17. static SubGhzEnvironment* environment_handler;
  18. static SubGhzReceiver* receiver_handler;
  19. //static SubGhzTransmitter* transmitter_handler;
  20. static SubGhzFileEncoderWorker* file_worker_encoder_handler;
  21. static uint16_t subghz_test_decoder_count = 0;
  22. static void subghz_test_rx_callback(
  23. SubGhzReceiver* receiver,
  24. SubGhzProtocolDecoderBase* decoder_base,
  25. void* context) {
  26. UNUSED(receiver);
  27. UNUSED(context);
  28. string_t text;
  29. string_init(text);
  30. subghz_protocol_decoder_base_get_string(decoder_base, text);
  31. subghz_receiver_reset(receiver_handler);
  32. FURI_LOG_I(TAG, "\r\n%s", string_get_cstr(text));
  33. string_clear(text);
  34. subghz_test_decoder_count++;
  35. }
  36. static void subghz_test_init(void) {
  37. environment_handler = subghz_environment_alloc();
  38. subghz_environment_set_came_atomo_rainbow_table_file_name(
  39. environment_handler, CAME_ATOMO_DIR_NAME);
  40. subghz_environment_set_nice_flor_s_rainbow_table_file_name(
  41. environment_handler, NICE_FLOR_S_DIR_NAME);
  42. receiver_handler = subghz_receiver_alloc_init(environment_handler);
  43. subghz_receiver_set_filter(receiver_handler, SubGhzProtocolFlag_Decodable);
  44. subghz_receiver_set_rx_callback(receiver_handler, subghz_test_rx_callback, NULL);
  45. }
  46. static void subghz_test_deinit(void) {
  47. subghz_receiver_free(receiver_handler);
  48. subghz_environment_free(environment_handler);
  49. }
  50. static bool subghz_decode_test(const char* path, const char* name_decoder) {
  51. subghz_test_decoder_count = 0;
  52. uint32_t test_start = furi_hal_get_tick();
  53. SubGhzProtocolDecoderBase* decoder =
  54. subghz_receiver_search_decoder_base_by_name(receiver_handler, name_decoder);
  55. if(decoder) {
  56. file_worker_encoder_handler = subghz_file_encoder_worker_alloc();
  57. if(subghz_file_encoder_worker_start(file_worker_encoder_handler, path)) {
  58. //the worker needs a file in order to open and read part of the file
  59. osDelay(100);
  60. LevelDuration level_duration;
  61. while(furi_hal_get_tick() - test_start < TEST_TIMEOUT) {
  62. furi_hal_delay_us(
  63. 500); //you need to have time to read from the file from the SD card
  64. level_duration =
  65. subghz_file_encoder_worker_get_level_duration(file_worker_encoder_handler);
  66. if(!level_duration_is_reset(level_duration)) {
  67. bool level = level_duration_get_level(level_duration);
  68. uint32_t duration = level_duration_get_duration(level_duration);
  69. decoder->protocol->decoder->feed(decoder, level, duration);
  70. } else {
  71. break;
  72. }
  73. }
  74. furi_hal_delay_ms(10);
  75. }
  76. if(subghz_file_encoder_worker_is_running(file_worker_encoder_handler)) {
  77. subghz_file_encoder_worker_stop(file_worker_encoder_handler);
  78. }
  79. subghz_file_encoder_worker_free(file_worker_encoder_handler);
  80. }
  81. FURI_LOG_I(TAG, "\r\n Decoder count parse \033[0;33m%d\033[0m ", subghz_test_decoder_count);
  82. if(furi_hal_get_tick() - test_start > TEST_TIMEOUT) {
  83. printf("\033[0;31mTest decoder %s ERROR TimeOut\033[0m\r\n", name_decoder);
  84. return false;
  85. } else {
  86. return subghz_test_decoder_count ? true : false;
  87. }
  88. }
  89. static bool subghz_decode_ramdom_test(const char* path) {
  90. subghz_test_decoder_count = 0;
  91. subghz_receiver_reset(receiver_handler);
  92. uint32_t test_start = furi_hal_get_tick();
  93. file_worker_encoder_handler = subghz_file_encoder_worker_alloc();
  94. if(subghz_file_encoder_worker_start(file_worker_encoder_handler, path)) {
  95. //the worker needs a file in order to open and read part of the file
  96. osDelay(100);
  97. LevelDuration level_duration;
  98. while(furi_hal_get_tick() - test_start < TEST_TIMEOUT * 10) {
  99. furi_hal_delay_us(500); //you need to have time to read from the file from the SD card
  100. level_duration =
  101. subghz_file_encoder_worker_get_level_duration(file_worker_encoder_handler);
  102. if(!level_duration_is_reset(level_duration)) {
  103. bool level = level_duration_get_level(level_duration);
  104. uint32_t duration = level_duration_get_duration(level_duration);
  105. subghz_receiver_decode(receiver_handler, level, duration);
  106. } else {
  107. break;
  108. }
  109. }
  110. furi_hal_delay_ms(10);
  111. if(subghz_file_encoder_worker_is_running(file_worker_encoder_handler)) {
  112. subghz_file_encoder_worker_stop(file_worker_encoder_handler);
  113. }
  114. subghz_file_encoder_worker_free(file_worker_encoder_handler);
  115. }
  116. FURI_LOG_I(TAG, "\r\n Decoder count parse \033[0;33m%d\033[0m ", subghz_test_decoder_count);
  117. if(furi_hal_get_tick() - test_start > TEST_TIMEOUT * 10) {
  118. printf("\033[0;31mRandom test ERROR TimeOut\033[0m\r\n");
  119. return false;
  120. } else if(subghz_test_decoder_count == TEST_RANDOM_COUNT_PARSE) {
  121. return true;
  122. } else {
  123. return false;
  124. }
  125. }
  126. static bool subghz_ecode_test(const char* path) {
  127. subghz_test_decoder_count = 0;
  128. uint32_t test_start = furi_hal_get_tick();
  129. string_t temp_str;
  130. string_init(temp_str);
  131. bool file_load = false;
  132. Storage* storage = furi_record_open("storage");
  133. FlipperFormat* fff_data_file = flipper_format_file_alloc(storage);
  134. do {
  135. if(!flipper_format_file_open_existing(fff_data_file, path)) {
  136. FURI_LOG_E(TAG, "Error open file %s", path);
  137. break;
  138. }
  139. if(!flipper_format_read_string(fff_data_file, "Preset", temp_str)) {
  140. FURI_LOG_E(TAG, "Missing Preset");
  141. break;
  142. }
  143. if(!flipper_format_read_string(fff_data_file, "Protocol", temp_str)) {
  144. FURI_LOG_E(TAG, "Missing Protocol");
  145. break;
  146. }
  147. file_load = true;
  148. } while(false);
  149. if(file_load) {
  150. SubGhzTransmitter* transmitter =
  151. subghz_transmitter_alloc_init(environment_handler, string_get_cstr(temp_str));
  152. subghz_transmitter_deserialize(transmitter, fff_data_file);
  153. SubGhzProtocolDecoderBase* decoder = subghz_receiver_search_decoder_base_by_name(
  154. receiver_handler, string_get_cstr(temp_str));
  155. if(decoder) {
  156. LevelDuration level_duration;
  157. while(furi_hal_get_tick() - test_start < TEST_TIMEOUT) {
  158. level_duration = subghz_transmitter_yield(transmitter);
  159. if(!level_duration_is_reset(level_duration)) {
  160. bool level = level_duration_get_level(level_duration);
  161. uint32_t duration = level_duration_get_duration(level_duration);
  162. decoder->protocol->decoder->feed(decoder, level, duration);
  163. } else {
  164. break;
  165. }
  166. }
  167. furi_hal_delay_ms(10);
  168. }
  169. subghz_transmitter_free(transmitter);
  170. }
  171. flipper_format_free(fff_data_file);
  172. FURI_LOG_I(TAG, "\r\n Decoder count parse \033[0;33m%d\033[0m ", subghz_test_decoder_count);
  173. if(furi_hal_get_tick() - test_start > TEST_TIMEOUT) {
  174. printf("\033[0;31mTest encoder %s ERROR TimeOut\033[0m\r\n", string_get_cstr(temp_str));
  175. subghz_test_decoder_count = 0;
  176. }
  177. string_clear(temp_str);
  178. return subghz_test_decoder_count ? true : false;
  179. }
  180. MU_TEST(subghz_keystore_test) {
  181. mu_assert(
  182. subghz_environment_load_keystore(environment_handler, KEYSTORE_DIR_NAME),
  183. "Test keystore error");
  184. }
  185. MU_TEST(subghz_decoder_came_atomo_test) {
  186. mu_assert(
  187. subghz_decode_test(
  188. "/ext/unit_tests/subghz/came_atomo_raw.sub", SUBGHZ_PROTOCOL_CAME_ATOMO_NAME),
  189. "Test decoder " SUBGHZ_PROTOCOL_CAME_ATOMO_NAME " error\r\n");
  190. }
  191. MU_TEST(subghz_decoder_came_test) {
  192. mu_assert(
  193. subghz_decode_test("/ext/unit_tests/subghz/came_raw.sub", SUBGHZ_PROTOCOL_CAME_NAME),
  194. "Test decoder " SUBGHZ_PROTOCOL_CAME_NAME " error\r\n");
  195. }
  196. MU_TEST(subghz_decoder_came_twee_test) {
  197. mu_assert(
  198. subghz_decode_test(
  199. "/ext/unit_tests/subghz/came_twee_raw.sub", SUBGHZ_PROTOCOL_CAME_TWEE_NAME),
  200. "Test decoder " SUBGHZ_PROTOCOL_CAME_TWEE_NAME " error\r\n");
  201. }
  202. MU_TEST(subghz_decoder_faac_slh_test) {
  203. mu_assert(
  204. subghz_decode_test(
  205. "/ext/unit_tests/subghz/faac_slh_raw.sub", SUBGHZ_PROTOCOL_FAAC_SLH_NAME),
  206. "Test decoder " SUBGHZ_PROTOCOL_FAAC_SLH_NAME " error\r\n");
  207. }
  208. MU_TEST(subghz_decoder_gate_tx_test) {
  209. mu_assert(
  210. subghz_decode_test("/ext/unit_tests/subghz/gate_tx_raw.sub", SUBGHZ_PROTOCOL_GATE_TX_NAME),
  211. "Test decoder " SUBGHZ_PROTOCOL_GATE_TX_NAME " error\r\n");
  212. }
  213. MU_TEST(subghz_decoder_hormann_hsm_test) {
  214. mu_assert(
  215. subghz_decode_test(
  216. "/ext/unit_tests/subghz/hormann_hsm_raw.sub", SUBGHZ_PROTOCOL_HORMANN_HSM_NAME),
  217. "Test decoder " SUBGHZ_PROTOCOL_HORMANN_HSM_NAME " error\r\n");
  218. }
  219. MU_TEST(subghz_decoder_ido_test) {
  220. mu_assert(
  221. subghz_decode_test("/ext/unit_tests/subghz/ido_117_111_raw.sub", SUBGHZ_PROTOCOL_IDO_NAME),
  222. "Test decoder " SUBGHZ_PROTOCOL_IDO_NAME " error\r\n");
  223. }
  224. MU_TEST(subghz_decoder_keelog_test) {
  225. mu_assert(
  226. subghz_decode_test("/ext/unit_tests/subghz/doorhan_raw.sub", SUBGHZ_PROTOCOL_KEELOQ_NAME),
  227. "Test decoder " SUBGHZ_PROTOCOL_KEELOQ_NAME " error\r\n");
  228. }
  229. MU_TEST(subghz_decoder_kia_seed_test) {
  230. mu_assert(
  231. subghz_decode_test("/ext/unit_tests/subghz/kia_seed_raw.sub", SUBGHZ_PROTOCOL_KIA_NAME),
  232. "Test decoder " SUBGHZ_PROTOCOL_KIA_NAME " error\r\n");
  233. }
  234. MU_TEST(subghz_decoder_nero_radio_test) {
  235. mu_assert(
  236. subghz_decode_test(
  237. "/ext/unit_tests/subghz/nero_radio_raw.sub", SUBGHZ_PROTOCOL_NERO_RADIO_NAME),
  238. "Test decoder " SUBGHZ_PROTOCOL_NERO_RADIO_NAME " error\r\n");
  239. }
  240. MU_TEST(subghz_decoder_nero_sketch_test) {
  241. mu_assert(
  242. subghz_decode_test(
  243. "/ext/unit_tests/subghz/nero_sketch_raw.sub", SUBGHZ_PROTOCOL_NERO_SKETCH_NAME),
  244. "Test decoder " SUBGHZ_PROTOCOL_NERO_SKETCH_NAME " error\r\n");
  245. }
  246. MU_TEST(subghz_decoder_nice_flo_test) {
  247. mu_assert(
  248. subghz_decode_test(
  249. "/ext/unit_tests/subghz/nice_flo_raw.sub", SUBGHZ_PROTOCOL_NICE_FLO_NAME),
  250. "Test decoder " SUBGHZ_PROTOCOL_NICE_FLO_NAME " error\r\n");
  251. }
  252. MU_TEST(subghz_decoder_nice_flor_s_test) {
  253. mu_assert(
  254. subghz_decode_test(
  255. "/ext/unit_tests/subghz/nice_flor_s_raw.sub", SUBGHZ_PROTOCOL_NICE_FLOR_S_NAME),
  256. "Test decoder " SUBGHZ_PROTOCOL_NICE_FLOR_S_NAME " error\r\n");
  257. }
  258. MU_TEST(subghz_decoder_princeton_test) {
  259. mu_assert(
  260. subghz_decode_test(
  261. "/ext/unit_tests/subghz/Princeton_raw.sub", SUBGHZ_PROTOCOL_PRINCETON_NAME),
  262. "Test decoder " SUBGHZ_PROTOCOL_PRINCETON_NAME " error\r\n");
  263. }
  264. MU_TEST(subghz_decoder_scher_khan_magic_code_test) {
  265. mu_assert(
  266. subghz_decode_test(
  267. "/ext/unit_tests/subghz/scher_khan_magic_code.sub", SUBGHZ_PROTOCOL_SCHER_KHAN_NAME),
  268. "Test decoder " SUBGHZ_PROTOCOL_SCHER_KHAN_NAME " error\r\n");
  269. }
  270. MU_TEST(subghz_decoder_somfy_keytis_test) {
  271. mu_assert(
  272. subghz_decode_test(
  273. "/ext/unit_tests/subghz/Somfy_keytis_raw.sub", SUBGHZ_PROTOCOL_SOMFY_KEYTIS_NAME),
  274. "Test decoder " SUBGHZ_PROTOCOL_SOMFY_KEYTIS_NAME " error\r\n");
  275. }
  276. MU_TEST(subghz_decoder_somfy_telis_test) {
  277. mu_assert(
  278. subghz_decode_test(
  279. "/ext/unit_tests/subghz/somfy_telis_raw.sub", SUBGHZ_PROTOCOL_SOMFY_TELIS_NAME),
  280. "Test decoder " SUBGHZ_PROTOCOL_SOMFY_TELIS_NAME " error\r\n");
  281. }
  282. MU_TEST(subghz_decoder_star_line_test) {
  283. mu_assert(
  284. subghz_decode_test("/ext/unit_tests/subghz/cenmax_raw.sub", SUBGHZ_PROTOCOL_STAR_LINE_NAME),
  285. "Test decoder " SUBGHZ_PROTOCOL_STAR_LINE_NAME " error\r\n");
  286. }
  287. MU_TEST(subghz_ecoder_princeton_test) {
  288. mu_assert(
  289. subghz_ecode_test("/ext/unit_tests/subghz/princeton.sub"),
  290. "Test encoder " SUBGHZ_PROTOCOL_PRINCETON_NAME " error\r\n");
  291. }
  292. MU_TEST(subghz_ecoder_came_test) {
  293. mu_assert(
  294. subghz_ecode_test("/ext/unit_tests/subghz/came.sub"),
  295. "Test encoder " SUBGHZ_PROTOCOL_CAME_NAME " error\r\n");
  296. }
  297. MU_TEST(subghz_ecoder_came_twee_test) {
  298. mu_assert(
  299. subghz_ecode_test("/ext/unit_tests/subghz/came_twee.sub"),
  300. "Test encoder " SUBGHZ_PROTOCOL_CAME_TWEE_NAME " error\r\n");
  301. }
  302. MU_TEST(subghz_ecoder_gate_tx_test) {
  303. mu_assert(
  304. subghz_ecode_test("/ext/unit_tests/subghz/gate_tx.sub"),
  305. "Test encoder " SUBGHZ_PROTOCOL_GATE_TX_NAME " error\r\n");
  306. }
  307. MU_TEST(subghz_ecoder_nice_flo_test) {
  308. mu_assert(
  309. subghz_ecode_test("/ext/unit_tests/subghz/nice_flo.sub"),
  310. "Test encoder " SUBGHZ_PROTOCOL_NICE_FLO_NAME " error\r\n");
  311. }
  312. MU_TEST(subghz_ecoder_keelog_test) {
  313. mu_assert(
  314. subghz_ecode_test("/ext/unit_tests/subghz/doorhan.sub"),
  315. "Test encoder " SUBGHZ_PROTOCOL_KEELOQ_NAME " error\r\n");
  316. }
  317. MU_TEST(subghz_random_test) {
  318. mu_assert(subghz_decode_ramdom_test(TEST_RANDOM_DIR_NAME), "Random test error\r\n");
  319. }
  320. MU_TEST_SUITE(subghz) {
  321. //MU_SUITE_CONFIGURE(&subghz_test_init, &subghz_test_deinit);
  322. subghz_test_init();
  323. MU_RUN_TEST(subghz_keystore_test);
  324. MU_RUN_TEST(subghz_decoder_came_atomo_test);
  325. MU_RUN_TEST(subghz_decoder_came_test);
  326. MU_RUN_TEST(subghz_decoder_came_twee_test);
  327. MU_RUN_TEST(subghz_decoder_faac_slh_test);
  328. MU_RUN_TEST(subghz_decoder_gate_tx_test);
  329. MU_RUN_TEST(subghz_decoder_hormann_hsm_test);
  330. MU_RUN_TEST(subghz_decoder_ido_test);
  331. MU_RUN_TEST(subghz_decoder_keelog_test);
  332. MU_RUN_TEST(subghz_decoder_kia_seed_test);
  333. MU_RUN_TEST(subghz_decoder_nero_radio_test);
  334. MU_RUN_TEST(subghz_decoder_nero_sketch_test);
  335. MU_RUN_TEST(subghz_decoder_nice_flo_test);
  336. MU_RUN_TEST(subghz_decoder_nice_flor_s_test);
  337. MU_RUN_TEST(subghz_decoder_princeton_test);
  338. MU_RUN_TEST(subghz_decoder_scher_khan_magic_code_test);
  339. MU_RUN_TEST(subghz_decoder_somfy_keytis_test);
  340. MU_RUN_TEST(subghz_decoder_somfy_telis_test);
  341. MU_RUN_TEST(subghz_decoder_star_line_test);
  342. MU_RUN_TEST(subghz_ecoder_princeton_test);
  343. MU_RUN_TEST(subghz_ecoder_came_test);
  344. MU_RUN_TEST(subghz_ecoder_came_twee_test);
  345. MU_RUN_TEST(subghz_ecoder_gate_tx_test);
  346. MU_RUN_TEST(subghz_ecoder_nice_flo_test);
  347. MU_RUN_TEST(subghz_ecoder_keelog_test);
  348. MU_RUN_TEST(subghz_random_test);
  349. subghz_test_deinit();
  350. }
  351. int run_minunit_test_subghz() {
  352. MU_RUN_SUITE(subghz);
  353. return MU_EXIT_CODE;
  354. }