upleb.uk

Public git repos — served from a NIP-34 GRASP relay at git.upleb.uk

summaryrefslogtreecommitdiff
path: root/tests/unit/test_firewall_sandbox.c
diff options
context:
space:
mode:
authorYour Name <you@example.com>2026-05-19 14:25:18 +0530
committerYour Name <you@example.com>2026-05-19 14:25:18 +0530
commite366ceb336550a72c76efea4c98a2a08cca27bce (patch)
tree4b45ac6f6e97b6763f81aa6d4a9b968d23e41235 /tests/unit/test_firewall_sandbox.c
parent163b8badec9359373a8fc016c2b1fe9ee38e6406 (diff)
feat(mining): Bitcoin mining-for-bandwidth payment system
New modules: - mining_payment.c/h: hashprice calc (nbits->difficulty->sat/GH/s/day), share validation, client stats, allotment conversion (ms + bytes) - stratum_client.c/h: SV1 upstream pool connection (subscribe/authorize/submit) - stratum_proxy.c/h: Local SV1 TCP server for downstream miners, job broadcast - sw_miner.c/h: Software SHA256d miner (ESP32 CPU fallback) - asic_miner.c/h: ASIC detection stub (BM1366/BM1368 SPI) Config: - config.h/c: mining_payout_mode_t enum (auto/pool/upstream/proxy_only), stratum pool settings, mining port, hashprice override, sandbox mint access - Defaults fill nostr_seed_relays (8/8) and nostr_relays (4/4) with fast relays Integration into existing modules: - session.h/c: payment_method_t enum (CASHU/MINING/BYTES) - firewall.h/c: firewall_set_mining_port(), firewall_set_sandbox_mint_access() - tollgate_api.c: GET /mining/job, POST /mining/share, GET /mining/stats - tollgate_client.h/c: TG_CLIENT_MINING state, mining discovery tag parsing - tollgate_main.c: mining init in start_services(), stratum_client_tick() in loop - captive_portal.c: tabbed Cashu/Mine UI with live hashrate polling Unit tests (69 new assertions across 4 suites): - test_mining_payment (23 tests): nbits->difficulty, hashprice, client stats, allotment - test_stratum_proxy (21 tests): job set/get, stats, type validation - test_session_payment_method (12 tests): PAYMENT_METHOD enum, bytes/cashu methods - test_tollgate_client_mining (20 tests): mining tag parsing, discovery struct - test_firewall_sandbox (16 tests): client grant/revoke, max clients, setters Enhanced test stubs: - BaseType_t/pdPASS in freertos/task.h - lwip: sockets.h, etharp.h, prot/ip.h, prot/ip4.h, prot/tcp.h, netif.h - dns_server.h, esp_wifi_ap_get_sta_list.h Build fixes: - cvm_server.c: replace esp_timer_get_time() with xTaskGetTickCount(), fix process_relay_message() 3-arg call to 2-arg, add WS keepalive ping - stratum_proxy.c: widen task_name buffer 16->20 - sw_miner.c: add missing #include esp_random.h - nucula_src: save_proofs() moved to public in wallet.hpp Nostr relay updates: - nostr_seed_relays: +relay.anzenkodo.workers.dev, +nostr.koning-degraaf.nl, +knostr.neutrine.com, +nostr.einundzwanzig.space (8/8 slots) - nostr_relays: +relay.anzenkodo.workers.dev, +nostr.koning-degraaf.nl (4/4 slots) Squash-merge of feature/mining-payment (5 commits: c75230e..9d98ba1)
Diffstat (limited to 'tests/unit/test_firewall_sandbox.c')
-rw-r--r--tests/unit/test_firewall_sandbox.c94
1 files changed, 94 insertions, 0 deletions
diff --git a/tests/unit/test_firewall_sandbox.c b/tests/unit/test_firewall_sandbox.c
new file mode 100644
index 0000000..66a491b
--- /dev/null
+++ b/tests/unit/test_firewall_sandbox.c
@@ -0,0 +1,94 @@
1#include "test_framework.h"
2#include "../../main/firewall.h"
3#include <stdio.h>
4#include <string.h>
5
6int main(void)
7{
8 printf("=== test_firewall_sandbox ===\n");
9
10 printf("\n--- FW_MAX_MAC_LEN is 18 ---\n");
11 {
12 ASSERT_EQ_INT(18, FW_MAX_MAC_LEN, "MAC length is 18 (17 chars + null)");
13 }
14
15 printf("\n--- esp_ip4_addr_t available ---\n");
16 {
17 esp_ip4_addr_t ip;
18 ip.addr = 0x0102A8C0;
19 ASSERT(ip.addr == 0x0102A8C0, "ip4_addr stores value");
20 }
21
22 printf("\n--- firewall_set_mining_port / set_sandbox_mint_access compile ---\n");
23 {
24 firewall_set_mining_port(3333);
25 firewall_set_mining_port(4033);
26 firewall_set_sandbox_mint_access(true);
27 firewall_set_sandbox_mint_access(false);
28 ASSERT(true, "setters compile and run without crash");
29 }
30
31 printf("\n--- firewall_init + client management ---\n");
32 {
33 esp_ip4_addr_t ap_ip = { .addr = 0x012FA80A };
34 esp_err_t ret = firewall_init(ap_ip);
35 ASSERT_EQ_INT(ESP_OK, (int)ret, "firewall_init succeeds");
36 ASSERT_EQ_INT(0, firewall_client_count(), "no clients after init");
37
38 firewall_grant_access(0x0201A8C0);
39 ASSERT_EQ_INT(1, firewall_client_count(), "1 client after grant");
40 ASSERT(firewall_is_client_allowed(0x0201A8C0), "client is allowed");
41
42 firewall_revoke_access(0x0201A8C0);
43 ASSERT_EQ_INT(0, firewall_client_count(), "0 clients after revoke");
44 ASSERT(!firewall_is_client_allowed(0x0201A8C0), "client not allowed after revoke");
45 }
46
47 printf("\n--- grant same IP twice ---\n");
48 {
49 esp_ip4_addr_t ap_ip = { .addr = 0x012FA80A };
50 firewall_init(ap_ip);
51
52 firewall_grant_access(0x0301A8C0);
53 firewall_grant_access(0x0301A8C0);
54 ASSERT_EQ_INT(1, firewall_client_count(), "duplicate grant does not double count");
55 }
56
57 printf("\n--- revoke non-existent ---\n");
58 {
59 firewall_revoke_access(0x99999999);
60 ASSERT_EQ_INT(1, firewall_client_count(), "revoke non-existent no effect");
61 }
62
63 printf("\n--- revoke_all ---\n");
64 {
65 firewall_grant_access(0x0401A8C0);
66 firewall_grant_access(0x0501A8C0);
67 ASSERT_EQ_INT(3, firewall_client_count(), "3 clients");
68 firewall_revoke_all();
69 ASSERT_EQ_INT(0, firewall_client_count(), "0 after revoke_all");
70 }
71
72 printf("\n--- max clients (10) ---\n");
73 {
74 esp_ip4_addr_t ap_ip = { .addr = 0x012FA80A };
75 firewall_init(ap_ip);
76
77 for (int i = 0; i < 10; i++) {
78 firewall_grant_access(0x0A000000 + i);
79 }
80 ASSERT_EQ_INT(10, firewall_client_count(), "10 clients at max");
81
82 firewall_grant_access(0x0A000100);
83 ASSERT_EQ_INT(10, firewall_client_count(), "still 10 after exceeding max");
84 }
85
86 printf("\n--- is_mac_allowed (no MACs resolved in stub) ---\n");
87 {
88 firewall_init((esp_ip4_addr_t){ .addr = 0x012FA80A });
89 firewall_grant_access(0x0601A8C0);
90 ASSERT(!firewall_is_mac_allowed(""), "empty MAC not allowed");
91 }
92
93 TEST_SUMMARY();
94}