1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
|
#include "test_framework.h"
#include "../../main/config.h"
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#include <cjson/cJSON.h>
static tollgate_config_t g_test_config;
const tollgate_config_t *tollgate_config_get(void) {
return &g_test_config;
}
uint64_t nucula_wallet_balance(void) { return 100; }
esp_err_t nucula_wallet_send(uint64_t a, char *b, size_t c) { (void)a; (void)b; (void)c; return ESP_OK; }
#define TOLLGATE_IE_GEOHASH_MAX 9
#define MARKET_MAX_ENTRIES 10
typedef struct { uint8_t bssid[6]; char ssid[33]; int8_t rssi; uint16_t price_per_step; uint32_t step_size; uint8_t metric; uint8_t mint_hash[4]; uint8_t npub_hash[4]; char geohash[10]; int64_t discovered_ms; bool valid; } market_entry_t;
typedef struct { market_entry_t entries[MARKET_MAX_ENTRIES]; int count; int64_t last_scan_ms; bool scanning; int consecutive_failures; } market_t;
static inline const market_t *market_get(void) { static market_t m = {0}; return &m; }
static inline int market_find_cheapest(void) { return -1; }
#define MARKET_H
#include "freertos/FreeRTOS.h"
#include "../../main/tollgate_client.c"
int main(void)
{
printf("=== test_tollgate_client_mining ===\n");
memset(&g_test_config, 0, sizeof(g_test_config));
g_test_config.client_enabled = true;
printf("\n--- mining tag: mining_available=true, port=3333 ---\n");
{
const char *json = "{\"kind\":10021,\"tags\":["
"[\"metric\",\"milliseconds\"],"
"[\"step_size\",\"60000\"],"
"[\"price_per_step\",\"0\",\"mining\",\"3333\",\"sat\"],"
"[\"tips\",\"1\",\"2\",\"5\"]"
"]}";
tollgate_discovery_t disc;
bool ok = parse_discovery_response(json, &disc);
ASSERT(ok, "mining discovery parsed");
ASSERT(disc.is_tollgate, "is_tollgate=true");
ASSERT(disc.mining_available, "mining_available=true");
ASSERT_EQ_INT(3333, (int)disc.mining_port, "mining_port=3333");
}
printf("\n--- mining tag: no mining tag ---\n");
{
const char *json = "{\"kind\":10021,\"tags\":["
"[\"metric\",\"milliseconds\"],"
"[\"step_size\",\"60000\"],"
"[\"price_per_step\",\"cashu\",\"21\",\"sat\",\"https://testnut.cashu.space\",\"1\"]"
"]}";
tollgate_discovery_t disc;
bool ok = parse_discovery_response(json, &disc);
ASSERT(ok, "cashu discovery parsed");
ASSERT(disc.is_tollgate, "is_tollgate=true");
ASSERT(!disc.mining_available, "mining_available=false");
ASSERT_EQ_INT(0, (int)disc.mining_port, "mining_port=0 when no mining");
ASSERT_EQ_INT(21, disc.price_per_step, "price_per_step=21 for cashu");
}
printf("\n--- mining tag: custom port 4033 ---\n");
{
const char *json = "{\"kind\":10021,\"tags\":["
"[\"metric\",\"milliseconds\"],"
"[\"step_size\",\"60000\"],"
"[\"price_per_step\",\"0\",\"mining\",\"4033\",\"sat\"]"
"]}";
tollgate_discovery_t disc;
bool ok = parse_discovery_response(json, &disc);
ASSERT(ok, "mining custom port parsed");
ASSERT(disc.mining_available, "mining_available=true");
ASSERT_EQ_INT(4033, (int)disc.mining_port, "mining_port=4033");
}
printf("\n--- tollgate_discovery_t zero-init ---\n");
{
tollgate_discovery_t disc = {0};
ASSERT(!disc.is_tollgate, "zero-init: is_tollgate=false");
ASSERT(!disc.mining_available, "zero-init: mining_available=false");
ASSERT_EQ_INT(0, (int)disc.mining_port, "zero-init: mining_port=0");
ASSERT_EQ_INT(0, disc.price_per_step, "zero-init: price=0");
}
printf("\n--- TG_CLIENT_MINING state enum ---\n");
{
ASSERT(TG_CLIENT_MINING > TG_CLIENT_PAID, "MINING > PAID in enum");
ASSERT(TG_CLIENT_MINING < TG_CLIENT_ERROR, "MINING < ERROR in enum");
}
printf("\n--- discovery struct fields ---\n");
{
tollgate_discovery_t disc;
memset(&disc, 0, sizeof(disc));
disc.mining_available = true;
disc.mining_port = 9999;
ASSERT(disc.mining_available, "mining_available set");
ASSERT_EQ_INT(9999, (int)disc.mining_port, "mining_port set");
}
TEST_SUMMARY();
}
|