From ef9ae982e42cd8c719a8ba5a0b87f25a5a5f91ba Mon Sep 17 00:00:00 2001 From: Your Name Date: Tue, 19 May 2026 13:10:54 +0530 Subject: test: add 4 new unit test suites for mining modules - test_stratum_proxy: job set/get, stats, init (21 tests) - test_session_payment_method: PAYMENT_METHOD enum, bytes/cashu methods (12 tests) - test_tollgate_client_mining: mining tag parsing, discovery struct (20 tests) - test_firewall_sandbox: client management, grant/revoke, max clients (16 tests) - Enhanced stubs: BaseType_t/pdPASS in task.h, lwip sockets/etharp/prot headers, dns_server.h, esp_wifi_ap_get_sta_list.h - All 15 test suites pass (344+ total assertions) --- tests/unit/test_session_payment_method.c | 74 ++++++++++++++++++++++++++++++++ 1 file changed, 74 insertions(+) create mode 100644 tests/unit/test_session_payment_method.c (limited to 'tests/unit/test_session_payment_method.c') diff --git a/tests/unit/test_session_payment_method.c b/tests/unit/test_session_payment_method.c new file mode 100644 index 0000000..0239140 --- /dev/null +++ b/tests/unit/test_session_payment_method.c @@ -0,0 +1,74 @@ +#include "test_framework.h" +#include "../../main/session.h" +#include "../../main/firewall.h" +#include "../../main/config.h" +#include "../../main/cashu.h" +#include +#include + +static tollgate_config_t g_test_config; + +const tollgate_config_t *tollgate_config_get(void) { + return &g_test_config; +} + +esp_err_t firewall_get_mac_for_ip(uint32_t ip, char *mac_out, size_t size) { + (void)ip; + snprintf(mac_out, size, "AA:BB:CC:DD:EE:FF"); + return 0; +} + +static uint32_t g_granted_ips[32]; +static int g_granted_count = 0; + +void firewall_grant_access(uint32_t ip) { + if (g_granted_count < 32) g_granted_ips[g_granted_count++] = ip; +} + +void firewall_revoke_access(uint32_t ip) { + (void)ip; +} + +int main(void) +{ + printf("=== test_session_payment_method ===\n"); + memset(&g_test_config, 0, sizeof(g_test_config)); + strncpy(g_test_config.metric, "milliseconds", sizeof(g_test_config.metric) - 1); + g_granted_count = 0; + + printf("\n--- session_create sets PAYMENT_METHOD_CASHU ---\n"); + session_manager_init(); + session_t *s1 = session_create(0x0A010001, 60000); + ASSERT(s1 != NULL, "session created"); + ASSERT_EQ_INT(PAYMENT_METHOD_CASHU, (int)s1->payment_method, "cashu session has PAYMENT_METHOD_CASHU"); + + printf("\n--- session_create_bytes sets PAYMENT_METHOD_BYTES ---\n"); + session_manager_init(); + g_granted_count = 0; + session_t *s2 = session_create_bytes(0x0A010002, 1048576); + ASSERT(s2 != NULL, "bytes session created"); + ASSERT_EQ_INT(PAYMENT_METHOD_BYTES, (int)s2->payment_method, "bytes session has PAYMENT_METHOD_BYTES"); + ASSERT_EQ_UINT64(1048576, s2->allotment_bytes, "allotment_bytes set"); + ASSERT_EQ_UINT64(0, s2->bytes_consumed, "bytes_consumed starts at 0"); + + printf("\n--- payment_method_t enum values are distinct ---\n"); + ASSERT(PAYMENT_METHOD_CASHU != PAYMENT_METHOD_MINING, "CASHU != MINING"); + ASSERT(PAYMENT_METHOD_CASHU != PAYMENT_METHOD_BYTES, "CASHU != BYTES"); + ASSERT(PAYMENT_METHOD_MINING != PAYMENT_METHOD_BYTES, "MINING != BYTES"); + + printf("\n--- session extend preserves payment_method ---\n"); + session_manager_init(); + g_granted_count = 0; + session_t *s3 = session_create(0x0A010003, 60000); + ASSERT_EQ_INT(PAYMENT_METHOD_CASHU, (int)s3->payment_method, "initially CASHU"); + session_extend(s3, 30000); + ASSERT_EQ_INT(PAYMENT_METHOD_CASHU, (int)s3->payment_method, "still CASHU after extend"); + + printf("\n--- bytes session allotment_ms is INT64_MAX ---\n"); + session_manager_init(); + g_granted_count = 0; + session_t *s4 = session_create_bytes(0x0A010004, 2097152); + ASSERT(s4->allotment_ms == INT64_MAX, "bytes session has INT64_MAX allotment_ms"); + + TEST_SUMMARY(); +} -- cgit v1.2.3