irda_decoder_test.c 2.8 KB

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