From 308fe4b5a7bcc9fc5376c52a4c09976d53f63922 Mon Sep 17 00:00:00 2001 From: Pascal Brunot Date: Sun, 11 Aug 2024 22:12:10 +0200 Subject: [PATCH 1/4] Trying to solve repeated start/stop use events in short periods Probably the user is keeping the card a little bit too long on the box, so I added a configuration settings with 2s default value to disable RFID readings. --- conf/conf.hpp | 3 +++ include/BaseRfidWrapper.hpp | 3 +++ include/BoardLogic.hpp | 1 - include/RFIDWrapper.hpp | 5 ++++- src/BoardLogic.cpp | 10 ++-------- src/RFIDWrapper.tpp | 21 ++++++++++++++++++++- 6 files changed, 32 insertions(+), 11 deletions(-) diff --git a/conf/conf.hpp b/conf/conf.hpp index 126da633..c148c526 100644 --- a/conf/conf.hpp +++ b/conf/conf.hpp @@ -70,6 +70,9 @@ namespace fabomatic /// @brief Minimum time to confirm by long tap maintenance static constexpr auto LONG_TAP_DURATION{10s}; + /// @brief Disabled RFID reading after a successfull read for X seconds. + static constexpr auto DELAY_BETWEEN_SWEEPS{2s}; + } // namespace conf::machine /// @brief Debug settings diff --git a/include/BaseRfidWrapper.hpp b/include/BaseRfidWrapper.hpp index 296d40df..c07b04f3 100644 --- a/include/BaseRfidWrapper.hpp +++ b/include/BaseRfidWrapper.hpp @@ -3,6 +3,7 @@ #include #include "card.hpp" +#include "Tasks.hpp" namespace fabomatic { @@ -21,6 +22,8 @@ namespace fabomatic virtual auto readCardSerial() const -> std::optional = 0; virtual auto selfTest() const -> bool = 0; virtual auto reset() const -> void = 0; + + virtual auto setDisabledUntil(fabomatic::Tasks::time_point t) -> void = 0; }; } // namespace fabomatic #endif // BASERFIDWRAPPER_HPP_ \ No newline at end of file diff --git a/include/BoardLogic.hpp b/include/BoardLogic.hpp index c7043411..38a7f387 100644 --- a/include/BoardLogic.hpp +++ b/include/BoardLogic.hpp @@ -95,7 +95,6 @@ namespace fabomatic FabBackend server; std::optional> rfid{std::nullopt}; // Configured at runtime std::optional> lcd{std::nullopt}; // Configured at runtime - bool ready_for_a_new_card{true}; bool led_status{false}; Machine machine; diff --git a/include/RFIDWrapper.hpp b/include/RFIDWrapper.hpp index 58343825..95cb0261 100644 --- a/include/RFIDWrapper.hpp +++ b/include/RFIDWrapper.hpp @@ -19,6 +19,7 @@ namespace fabomatic { private: std::unique_ptr driver; + std::optional disabledUntil; public: RFIDWrapper(); @@ -46,6 +47,8 @@ namespace fabomatic [[nodiscard]] auto getUid() const -> card::uid_t override; + [[nodiscard]] auto setDisabledUntil(fabomatic::Tasks::time_point delay) -> void override; + /// @brief Returns the driver object for testing/simulation Driver &getDriver(); @@ -53,7 +56,7 @@ namespace fabomatic RFIDWrapper &operator=(const RFIDWrapper &x) = delete; // copy assignment RFIDWrapper(RFIDWrapper &&) = delete; // move constructor RFIDWrapper &operator=(RFIDWrapper &&) = delete; // move assignment - ~RFIDWrapper() override{}; // Default destructor + ~RFIDWrapper() override {}; // Default destructor }; } // namespace fabomatic diff --git a/src/BoardLogic.cpp b/src/BoardLogic.cpp index a81a423c..3aa6b47d 100644 --- a/src/BoardLogic.cpp +++ b/src/BoardLogic.cpp @@ -75,12 +75,6 @@ namespace fabomatic { ESP_LOGD(TAG, "New card present"); - if (!ready_for_a_new_card) - { - return; - } - ready_for_a_new_card = false; - if (machine.isFree()) { // machine is free @@ -556,13 +550,13 @@ namespace fabomatic const auto &result = rfid.readCardSerial(); if (result) { + // This function may block for several seconds if a long tap is required onNewCard(result.value()); + rfid.setDisabledUntil(Tasks::arduinoNow() + conf::machine::DELAY_BETWEEN_SWEEPS); } return; } - // No new card present - ready_for_a_new_card = true; if (machine.isFree()) { changeStatus(Status::MachineFree); diff --git a/src/RFIDWrapper.tpp b/src/RFIDWrapper.tpp index 0ecbccc7..29148f8c 100644 --- a/src/RFIDWrapper.tpp +++ b/src/RFIDWrapper.tpp @@ -12,7 +12,7 @@ namespace fabomatic { /// @brief Constructor template - RFIDWrapper::RFIDWrapper() : driver{std::make_unique()} {}; + RFIDWrapper::RFIDWrapper() : driver{std::make_unique()}, disabledUntil{std::nullopt} {}; /// @brief indicates if a new card is present in the RFID chip antenna area /// @return true if a new card is present @@ -24,15 +24,34 @@ namespace fabomatic if (conf::debug::ENABLE_LOGS && result) ESP_LOGD(TAG, "isNewCardPresent=%d", result); + if (disabledUntil && disabledUntil > fabomatic::Tasks::arduinoNow()) + { + ESP_LOGD(TAG, "isNewCardPresent is disabled"); + return false; + } + return result; } + template + [[nodiscard]] auto RFIDWrapper::setDisabledUntil(fabomatic::Tasks::time_point delay) -> void + { + this->disabledUntil = delay; + } + /// @brief tries to read the card serial number /// @return true if successfull, result can be read with getUid() template auto RFIDWrapper::readCardSerial() const -> std::optional { const auto &result = driver->PICC_ReadCardSerial(); + + if (disabledUntil && disabledUntil > fabomatic::Tasks::arduinoNow()) + { + ESP_LOGD(TAG, "readCardSerial is disabled"); + return std::nullopt; + } + if (result) { return getUid(); From e16e3c0a5c90d30fe524f5e04237984169843979 Mon Sep 17 00:00:00 2001 From: Pascal Brunot Date: Sun, 11 Aug 2024 22:33:18 +0200 Subject: [PATCH 2/4] PlatformIO: remove compilation warning CORE_DEBUG_LEVEL redefined --- platformio.ini | 1 - 1 file changed, 1 deletion(-) diff --git a/platformio.ini b/platformio.ini index 981b17e9..ede3f3d7 100644 --- a/platformio.ini +++ b/platformio.ini @@ -68,7 +68,6 @@ board_build.f_flash = 80000000L build_flags = ${env.build_flags} -D ARDUINO_USB_CDC_ON_BOOT build_src_flags = ${env.build_src_flags} - -D CORE_DEBUG_LEVEL=5 -D MQTT_SIMULATION=false -D RFID_SIMULATION=false -D PINS_HARDWARE_REV0 From bca7140c2c2996057103ec9efc8f4fd1cabbd415 Mon Sep 17 00:00:00 2001 From: Pascal Brunot Date: Sun, 11 Aug 2024 22:34:14 +0200 Subject: [PATCH 3/4] Rfid: allow optional timepoint to disable rfid events beforehand. + test update. --- include/BaseRfidWrapper.hpp | 2 +- include/RFIDWrapper.hpp | 2 +- src/RFIDWrapper.tpp | 2 +- test/test_logic/test_common.cpp | 5 ++++- 4 files changed, 7 insertions(+), 4 deletions(-) diff --git a/include/BaseRfidWrapper.hpp b/include/BaseRfidWrapper.hpp index c07b04f3..98788b86 100644 --- a/include/BaseRfidWrapper.hpp +++ b/include/BaseRfidWrapper.hpp @@ -23,7 +23,7 @@ namespace fabomatic virtual auto selfTest() const -> bool = 0; virtual auto reset() const -> void = 0; - virtual auto setDisabledUntil(fabomatic::Tasks::time_point t) -> void = 0; + virtual auto setDisabledUntil(std::optional t) -> void = 0; }; } // namespace fabomatic #endif // BASERFIDWRAPPER_HPP_ \ No newline at end of file diff --git a/include/RFIDWrapper.hpp b/include/RFIDWrapper.hpp index 95cb0261..980dd718 100644 --- a/include/RFIDWrapper.hpp +++ b/include/RFIDWrapper.hpp @@ -47,7 +47,7 @@ namespace fabomatic [[nodiscard]] auto getUid() const -> card::uid_t override; - [[nodiscard]] auto setDisabledUntil(fabomatic::Tasks::time_point delay) -> void override; + [[nodiscard]] auto setDisabledUntil(std::optional delay) -> void override; /// @brief Returns the driver object for testing/simulation Driver &getDriver(); diff --git a/src/RFIDWrapper.tpp b/src/RFIDWrapper.tpp index 29148f8c..0966f210 100644 --- a/src/RFIDWrapper.tpp +++ b/src/RFIDWrapper.tpp @@ -34,7 +34,7 @@ namespace fabomatic } template - [[nodiscard]] auto RFIDWrapper::setDisabledUntil(fabomatic::Tasks::time_point delay) -> void + [[nodiscard]] auto RFIDWrapper::setDisabledUntil(std::optional delay) -> void { this->disabledUntil = delay; } diff --git a/test/test_logic/test_common.cpp b/test/test_logic/test_common.cpp index f613ed76..0ecb4fb2 100644 --- a/test/test_logic/test_common.cpp +++ b/test/test_logic/test_common.cpp @@ -21,7 +21,11 @@ namespace fabomatic::tests std::optional duration_tap) { constexpr auto DEFAULT_CYCLES = 3; + + // Ignore DELAY_BETWEEN_SWEEPS delay between cards events + rfid.setDisabledUntil(std::nullopt); MockMrfc522 &driver = rfid.getDriver(); + driver.resetUid(); for (auto i = 0; i < DEFAULT_CYCLES; i++) { @@ -38,7 +42,6 @@ namespace fabomatic::tests logic.checkRfid(); delay(50); } while (duration_tap.has_value() && fabomatic::Tasks::arduinoNow() - start < duration_tap); - } else if (duration_tap) { From 805305a20723dc5960c289d7b84214c817a07825 Mon Sep 17 00:00:00 2001 From: Pascal Brunot Date: Sun, 11 Aug 2024 23:18:07 +0200 Subject: [PATCH 4/4] Tests: rework after DELAY_BETWEEN_SWEEPS --- test/test_logic/test_common.cpp | 8 +++++--- test/test_logic/test_logic.cpp | 8 +++++--- 2 files changed, 10 insertions(+), 6 deletions(-) diff --git a/test/test_logic/test_common.cpp b/test/test_logic/test_common.cpp index 0ecb4fb2..e1b7a03a 100644 --- a/test/test_logic/test_common.cpp +++ b/test/test_logic/test_common.cpp @@ -22,24 +22,26 @@ namespace fabomatic::tests { constexpr auto DEFAULT_CYCLES = 3; - // Ignore DELAY_BETWEEN_SWEEPS delay between cards events - rfid.setDisabledUntil(std::nullopt); MockMrfc522 &driver = rfid.getDriver(); driver.resetUid(); + rfid.setDisabledUntil(std::nullopt); + for (auto i = 0; i < DEFAULT_CYCLES; i++) { logic.checkRfid(); + rfid.setDisabledUntil(std::nullopt); } + if (uid.has_value()) { driver.setUid(uid.value(), duration_tap); TEST_ASSERT_TRUE_MESSAGE(uid == rfid.getUid(), "Card UID not equal"); auto start = fabomatic::Tasks::arduinoNow(); - do { logic.checkRfid(); + rfid.setDisabledUntil(std::nullopt); delay(50); } while (duration_tap.has_value() && fabomatic::Tasks::arduinoNow() - start < duration_tap); } diff --git a/test/test_logic/test_logic.cpp b/test/test_logic/test_logic.cpp index 94d28b18..2f64bf12 100644 --- a/test/test_logic/test_logic.cpp +++ b/test/test_logic/test_logic.cpp @@ -141,6 +141,8 @@ namespace fabomatic::tests const auto card_uid = get_test_uid(1); simulate_rfid_card(rfid, logic, card_uid, std::nullopt); + + Tasks::delay(fabomatic::conf::machine::DELAY_BETWEEN_SWEEPS); TEST_ASSERT_TRUE_MESSAGE(rfid.isNewCardPresent(), "New card not present"); TEST_ASSERT_TRUE_MESSAGE(rfid.readCardSerial().has_value(), "Card serial not read"); TEST_ASSERT_TRUE_MESSAGE(rfid.readCardSerial().value() == card_uid, "Card serial not equal"); @@ -271,8 +273,8 @@ namespace fabomatic::tests TEST_ASSERT_EQUAL_UINT16_MESSAGE(BoardLogic::Status::MaintenanceNeeded, logic.getStatus(), "Status not MaintenanceNeeded"); simulate_rfid_card(rfid, logic, std::nullopt); - simulate_rfid_card(rfid, logic, card_admin, conf::machine::LONG_TAP_DURATION + 10s); // Log in + Conferma manutenzione perché non ritorna prima della conclusione - simulate_rfid_card(rfid, logic, std::nullopt); // Card away + simulate_rfid_card(rfid, logic, card_admin, conf::machine::LONG_TAP_DURATION + 3s); // Log in + Conferma manutenzione perché non ritorna prima della conclusione + simulate_rfid_card(rfid, logic, std::nullopt); // Card away TEST_ASSERT_EQUAL_UINT16_MESSAGE(BoardLogic::Status::MachineInUse, logic.getStatus(), "Status not MachineInUse by admin"); TEST_ASSERT_FALSE_MESSAGE(logic.getMachine().isMaintenanceNeeded(), "Maintenance not cleared by admin"); @@ -355,7 +357,7 @@ void setup() { delay(1000); esp_log_level_set(TAG, LOG_LOCAL_LEVEL); - + auto config = fabomatic::SavedConfig::LoadFromEEPROM(); UNITY_BEGIN(); RUN_TEST(fabomatic::tests::test_machine_defaults);