2023-08-29 14:12:09 +00:00
|
|
|
/**
|
2023-08-29 14:56:25 +00:00
|
|
|
* limbo_test.h
|
2023-08-29 14:12:09 +00:00
|
|
|
* =============================================================================
|
2025-01-21 01:18:59 +00:00
|
|
|
* Copyright (c) 2023-present Serhii Snitsaruk and the LimboAI contributors.
|
2023-08-29 14:12:09 +00:00
|
|
|
*
|
|
|
|
* Use of this source code is governed by an MIT-style
|
|
|
|
* license that can be found in the LICENSE file or at
|
|
|
|
* https://opensource.org/licenses/MIT.
|
|
|
|
* =============================================================================
|
|
|
|
*/
|
|
|
|
|
2023-08-29 14:56:25 +00:00
|
|
|
#ifndef LIMBO_TEST_H
|
|
|
|
#define LIMBO_TEST_H
|
|
|
|
|
2024-01-10 22:26:24 +00:00
|
|
|
#define LIMBOAI_MODULE
|
|
|
|
|
2023-09-05 09:01:20 +00:00
|
|
|
#include "core/object/ref_counted.h"
|
2023-08-29 14:56:25 +00:00
|
|
|
#include "tests/test_macros.h"
|
2023-08-29 14:12:09 +00:00
|
|
|
|
|
|
|
#include "modules/limboai/bt/tasks/bt_action.h"
|
|
|
|
|
2023-09-05 09:01:20 +00:00
|
|
|
class CallbackCounter : public RefCounted {
|
|
|
|
GDCLASS(CallbackCounter, RefCounted);
|
|
|
|
|
|
|
|
public:
|
|
|
|
int num_callbacks = 0;
|
|
|
|
|
|
|
|
void callback() { num_callbacks += 1; }
|
2023-09-11 13:33:13 +00:00
|
|
|
void callback_delta(double delta) { num_callbacks += 1; }
|
2023-09-05 09:01:20 +00:00
|
|
|
|
|
|
|
protected:
|
|
|
|
static void _bind_methods() {
|
|
|
|
ClassDB::bind_method(D_METHOD("callback"), &CallbackCounter::callback);
|
2023-09-11 13:33:13 +00:00
|
|
|
ClassDB::bind_method(D_METHOD("callback_delta", "delta"), &CallbackCounter::callback_delta);
|
2023-09-05 09:01:20 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2023-08-29 14:12:09 +00:00
|
|
|
class BTTestAction : public BTAction {
|
|
|
|
GDCLASS(BTTestAction, BTAction);
|
|
|
|
|
|
|
|
public:
|
2023-09-19 11:43:26 +00:00
|
|
|
Status ret_status = BTTask::SUCCESS;
|
2023-08-29 14:12:09 +00:00
|
|
|
int num_entries = 0;
|
|
|
|
int num_ticks = 0;
|
|
|
|
int num_exits = 0;
|
|
|
|
|
|
|
|
protected:
|
|
|
|
virtual void _enter() override { num_entries += 1; }
|
|
|
|
virtual void _exit() override { num_exits += 1; }
|
|
|
|
|
2023-09-19 11:43:26 +00:00
|
|
|
virtual Status _tick(double p_delta) override {
|
2023-08-29 14:12:09 +00:00
|
|
|
num_ticks += 1;
|
|
|
|
return ret_status;
|
|
|
|
}
|
|
|
|
|
|
|
|
public:
|
2023-09-19 11:43:26 +00:00
|
|
|
bool is_status_either(Status p_status1, Status p_status2) { return (get_status() == p_status1 || get_status() == p_status2); }
|
2023-08-30 10:20:18 +00:00
|
|
|
|
2023-09-19 11:43:26 +00:00
|
|
|
BTTestAction(Status p_return_status) { ret_status = p_return_status; }
|
2023-08-30 08:34:12 +00:00
|
|
|
BTTestAction() {}
|
2023-08-29 14:12:09 +00:00
|
|
|
};
|
|
|
|
|
2023-08-29 14:56:25 +00:00
|
|
|
#define CHECK_ENTRIES_TICKS_EXITS(m_task, m_entries, m_ticks, m_exits) \
|
|
|
|
CHECK(m_task->num_entries == m_entries); \
|
|
|
|
CHECK(m_task->num_ticks == m_ticks); \
|
|
|
|
CHECK(m_task->num_exits == m_exits);
|
|
|
|
|
2023-08-30 09:19:14 +00:00
|
|
|
#define CHECK_ENTRIES_TICKS_EXITS_UP_TO(m_task, m_entries, m_ticks, m_exits) \
|
|
|
|
CHECK(m_task->num_entries <= m_entries); \
|
|
|
|
CHECK(m_task->num_ticks <= m_ticks); \
|
|
|
|
CHECK(m_task->num_exits <= m_exits);
|
|
|
|
|
2023-08-31 11:41:03 +00:00
|
|
|
#define CHECK_STATUS_ENTRIES_TICKS_EXITS(m_task, m_status, m_entries, m_ticks, m_exits) \
|
|
|
|
CHECK(m_task->get_status() == m_status); \
|
|
|
|
CHECK(m_task->num_entries == m_entries); \
|
|
|
|
CHECK(m_task->num_ticks == m_ticks); \
|
|
|
|
CHECK(m_task->num_exits == m_exits);
|
|
|
|
|
2023-08-29 14:56:25 +00:00
|
|
|
#endif // LIMBO_TEST_H
|