mirror of
https://github.com/esphome/esphome.git
synced 2025-08-06 02:17:45 +00:00
cleanup
This commit is contained in:
parent
53baf02087
commit
7d3cdd15ad
@ -0,0 +1,21 @@
|
|||||||
|
import esphome.codegen as cg
|
||||||
|
import esphome.config_validation as cv
|
||||||
|
from esphome.const import CONF_ID
|
||||||
|
|
||||||
|
scheduler_bulk_cleanup_component_ns = cg.esphome_ns.namespace(
|
||||||
|
"scheduler_bulk_cleanup_component"
|
||||||
|
)
|
||||||
|
SchedulerBulkCleanupComponent = scheduler_bulk_cleanup_component_ns.class_(
|
||||||
|
"SchedulerBulkCleanupComponent", cg.Component
|
||||||
|
)
|
||||||
|
|
||||||
|
CONFIG_SCHEMA = cv.Schema(
|
||||||
|
{
|
||||||
|
cv.GenerateID(): cv.declare_id(SchedulerBulkCleanupComponent),
|
||||||
|
}
|
||||||
|
).extend(cv.COMPONENT_SCHEMA)
|
||||||
|
|
||||||
|
|
||||||
|
async def to_code(config):
|
||||||
|
var = cg.new_Pvariable(config[CONF_ID])
|
||||||
|
await cg.register_component(var, config)
|
@ -0,0 +1,63 @@
|
|||||||
|
#include "scheduler_bulk_cleanup_component.h"
|
||||||
|
#include "esphome/core/log.h"
|
||||||
|
#include "esphome/core/helpers.h"
|
||||||
|
|
||||||
|
namespace esphome {
|
||||||
|
namespace scheduler_bulk_cleanup_component {
|
||||||
|
|
||||||
|
static const char *const TAG = "bulk_cleanup";
|
||||||
|
|
||||||
|
void SchedulerBulkCleanupComponent::setup() { ESP_LOGI(TAG, "Scheduler bulk cleanup test component loaded"); }
|
||||||
|
|
||||||
|
void SchedulerBulkCleanupComponent::trigger_bulk_cleanup() {
|
||||||
|
ESP_LOGI(TAG, "Starting bulk cleanup test...");
|
||||||
|
|
||||||
|
// Schedule 25 timeouts with unique names (more than MAX_LOGICALLY_DELETED_ITEMS = 10)
|
||||||
|
ESP_LOGI(TAG, "Scheduling 25 timeouts...");
|
||||||
|
for (int i = 0; i < 25; i++) {
|
||||||
|
std::string name = "bulk_timeout_" + std::to_string(i);
|
||||||
|
App.scheduler.set_timeout(this, name, 10000, [i]() {
|
||||||
|
// These should never execute as we'll cancel them
|
||||||
|
ESP_LOGW(TAG, "Timeout %d executed - this should not happen!", i);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// Cancel all of them to mark for removal
|
||||||
|
ESP_LOGI(TAG, "Cancelling all 25 timeouts to trigger bulk cleanup...");
|
||||||
|
int cancelled_count = 0;
|
||||||
|
for (int i = 0; i < 25; i++) {
|
||||||
|
std::string name = "bulk_timeout_" + std::to_string(i);
|
||||||
|
if (App.scheduler.cancel_timeout(this, name)) {
|
||||||
|
cancelled_count++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
ESP_LOGI(TAG, "Successfully cancelled %d timeouts", cancelled_count);
|
||||||
|
|
||||||
|
// At this point we have 25 items marked for removal
|
||||||
|
// The next scheduler.call() should trigger the bulk cleanup path
|
||||||
|
|
||||||
|
// Schedule an interval that will execute multiple times to ensure cleanup happens
|
||||||
|
static int cleanup_check_count = 0;
|
||||||
|
App.scheduler.set_interval(this, "cleanup_checker", 100, [this]() {
|
||||||
|
cleanup_check_count++;
|
||||||
|
ESP_LOGI(TAG, "Cleanup check %d - scheduler still running", cleanup_check_count);
|
||||||
|
|
||||||
|
if (cleanup_check_count >= 5) {
|
||||||
|
// Cancel the interval and complete the test
|
||||||
|
App.scheduler.cancel_interval(this, "cleanup_checker");
|
||||||
|
ESP_LOGI(TAG, "Bulk cleanup triggered: removed %d items", 25);
|
||||||
|
ESP_LOGI(TAG, "Items before cleanup: 25+, after: <unknown>");
|
||||||
|
ESP_LOGI(TAG, "Bulk cleanup test complete");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Also schedule some normal timeouts to ensure scheduler keeps working after cleanup
|
||||||
|
for (int i = 0; i < 5; i++) {
|
||||||
|
std::string name = "post_cleanup_" + std::to_string(i);
|
||||||
|
App.scheduler.set_timeout(this, name, 200 + i * 100,
|
||||||
|
[i]() { ESP_LOGI(TAG, "Post-cleanup timeout %d executed correctly", i); });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace scheduler_bulk_cleanup_component
|
||||||
|
} // namespace esphome
|
@ -0,0 +1,18 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "esphome/core/component.h"
|
||||||
|
#include "esphome/core/application.h"
|
||||||
|
|
||||||
|
namespace esphome {
|
||||||
|
namespace scheduler_bulk_cleanup_component {
|
||||||
|
|
||||||
|
class SchedulerBulkCleanupComponent : public Component {
|
||||||
|
public:
|
||||||
|
void setup() override;
|
||||||
|
float get_setup_priority() const override { return setup_priority::LATE; }
|
||||||
|
|
||||||
|
void trigger_bulk_cleanup();
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace scheduler_bulk_cleanup_component
|
||||||
|
} // namespace esphome
|
Loading…
x
Reference in New Issue
Block a user