#pragma once
#include <memory>
struct alarm_t;
class AlarmMock {
public:
MOCK_METHOD1(AlarmNew, alarm_t*(const char*));
MOCK_METHOD1(AlarmFree, void(alarm_t*));
MOCK_METHOD1(AlarmCancel, void(alarm_t*));
MOCK_METHOD4(AlarmSetOnMloop, void(alarm_t* alarm, uint64_t interval_ms,
alarm_callback_t cb, void* data));
alarm_t* AlarmNewImpl(const char* name) {
AlarmNew(name);
// We must return something from alarm_new in tests, if we just return null,
// unique_ptr will misbehave. Just reserve few bits they will be freed in
// AlarmFreeImpl
return (alarm_t*)new uint8_t[30];
}
void AlarmFreeImpl(alarm_t* alarm) {
uint8_t* ptr = (uint8_t*)alarm;
delete[] ptr;
return AlarmFree(alarm);
}
static inline AlarmMock* Get() {
if (!localAlarmMock) {
localAlarmMock = std::make_unique<AlarmMock>();
}
return localAlarmMock.get();
}
static inline void Reset() { localAlarmMock = std::make_unique<AlarmMock>(); }
private:
static std::unique_ptr<AlarmMock> localAlarmMock;
};
std::unique_ptr<AlarmMock> AlarmMock::localAlarmMock;
alarm_t* alarm_new(const char* name) {
return AlarmMock::Get()->AlarmNewImpl(name);
}
void alarm_free(alarm_t* alarm) { AlarmMock::Get()->AlarmFreeImpl(alarm); }
void alarm_set_on_mloop(alarm_t* alarm, uint64_t interval_ms,
alarm_callback_t cb, void* data) {
AlarmMock::Get()->AlarmSetOnMloop(alarm, interval_ms, cb, data);
}