irda_decoder_test.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. #include <furi.h>
  2. #include "../minunit.h"
  3. #include "irda.h"
  4. #include "test_data/irda_decoder_nec_test_data.srcdata"
  5. #include "test_data/irda_decoder_necext_test_data.srcdata"
  6. #include "test_data/irda_decoder_samsung_test_data.srcdata"
  7. #define RUN_DECODER(data, expected) \
  8. run_decoder((data), COUNT_OF(data), (expected), COUNT_OF(expected))
  9. static IrdaHandler* decoder;
  10. static void test_setup(void) {
  11. decoder = irda_alloc_decoder();
  12. }
  13. static void test_teardown(void) {
  14. irda_free_decoder(decoder);
  15. }
  16. static void
  17. compare_message_results(const IrdaMessage* message_decoded, const IrdaMessage* message_expected) {
  18. mu_check(message_decoded->protocol == message_expected->protocol);
  19. mu_check(message_decoded->command == message_expected->command);
  20. mu_check(message_decoded->address == message_expected->address);
  21. mu_check(message_decoded->repeat == message_expected->repeat);
  22. }
  23. static void run_decoder(
  24. const uint32_t* input_delays,
  25. uint32_t input_delays_len,
  26. const IrdaMessage* message_expected,
  27. uint32_t message_expected_len) {
  28. const IrdaMessage* message_decoded = 0;
  29. bool level = 1;
  30. uint32_t message_counter = 0;
  31. for(uint32_t i = 0; i < input_delays_len; ++i) {
  32. message_decoded = irda_decode(decoder, level, input_delays[i]);
  33. if(message_decoded) {
  34. mu_assert(message_counter < message_expected_len, "decoded more than expected");
  35. if(message_counter >= message_expected_len) break;
  36. compare_message_results(message_decoded, &message_expected[message_counter]);
  37. ++message_counter;
  38. }
  39. level = !level;
  40. }
  41. mu_assert(message_counter == message_expected_len, "decoded less than expected");
  42. }
  43. MU_TEST(test_samsung32) {
  44. RUN_DECODER(test_samsung32_input1, test_samsung32_expected1);
  45. }
  46. MU_TEST(test_mix) {
  47. RUN_DECODER(test_necext_input1, test_necext_expected1);
  48. RUN_DECODER(test_samsung32_input1, test_samsung32_expected1);
  49. RUN_DECODER(test_nec_input1, test_nec_expected1);
  50. RUN_DECODER(test_samsung32_input1, test_samsung32_expected1);
  51. RUN_DECODER(test_necext_input1, test_necext_expected1);
  52. RUN_DECODER(test_nec_input2, test_nec_expected2);
  53. }
  54. MU_TEST(test_nec1) {
  55. RUN_DECODER(test_nec_input1, test_nec_expected1);
  56. }
  57. MU_TEST(test_nec2) {
  58. RUN_DECODER(test_nec_input2, test_nec_expected2);
  59. }
  60. MU_TEST(test_unexpected_end_in_sequence) {
  61. // test_nec_input1 and test_nec_input2 shuts unexpected
  62. RUN_DECODER(test_nec_input1, test_nec_expected1);
  63. RUN_DECODER(test_nec_input1, test_nec_expected1);
  64. RUN_DECODER(test_nec_input2, test_nec_expected2);
  65. RUN_DECODER(test_nec_input2, test_nec_expected2);
  66. }
  67. MU_TEST(test_necext1) {
  68. RUN_DECODER(test_necext_input1, test_necext_expected1);
  69. RUN_DECODER(test_necext_input1, test_necext_expected1);
  70. }
  71. MU_TEST_SUITE(test_irda_decoder) {
  72. MU_SUITE_CONFIGURE(&test_setup, &test_teardown);
  73. MU_RUN_TEST(test_unexpected_end_in_sequence);
  74. MU_RUN_TEST(test_nec1);
  75. MU_RUN_TEST(test_nec2);
  76. MU_RUN_TEST(test_samsung32);
  77. MU_RUN_TEST(test_necext1);
  78. MU_RUN_TEST(test_mix);
  79. }
  80. int run_minunit_test_irda_decoder() {
  81. MU_RUN_SUITE(test_irda_decoder);
  82. MU_REPORT();
  83. return MU_EXIT_CODE;
  84. }