upleb.uk

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

summaryrefslogtreecommitdiff
path: root/tests/unit/stubs
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/stubs
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/stubs')
-rw-r--r--tests/unit/stubs/dns_server.h11
-rw-r--r--tests/unit/stubs/esp_wifi_ap_get_sta_list.h38
-rw-r--r--tests/unit/stubs/freertos/task.h7
-rw-r--r--tests/unit/stubs/lwip/etharp.h22
-rw-r--r--tests/unit/stubs/lwip/ip4_addr.h3
-rw-r--r--tests/unit/stubs/lwip/lwip_napt.h (renamed from tests/unit/stubs/lwip/napt.h)0
-rw-r--r--tests/unit/stubs/lwip/netif.h16
-rw-r--r--tests/unit/stubs/lwip/prot/ip.h20
-rw-r--r--tests/unit/stubs/lwip/prot/ip4.h6
-rw-r--r--tests/unit/stubs/lwip/prot/tcp.h13
-rw-r--r--tests/unit/stubs/lwip/sockets.h6
11 files changed, 140 insertions, 2 deletions
diff --git a/tests/unit/stubs/dns_server.h b/tests/unit/stubs/dns_server.h
new file mode 100644
index 0000000..0a9450b
--- /dev/null
+++ b/tests/unit/stubs/dns_server.h
@@ -0,0 +1,11 @@
1#ifndef STUBS_DNS_SERVER_H
2#define STUBS_DNS_SERVER_H
3
4#include <stdint.h>
5#include <stdbool.h>
6
7static inline void dns_server_set_client_authenticated(uint32_t ip, bool auth) {
8 (void)ip; (void)auth;
9}
10
11#endif
diff --git a/tests/unit/stubs/esp_wifi_ap_get_sta_list.h b/tests/unit/stubs/esp_wifi_ap_get_sta_list.h
new file mode 100644
index 0000000..3e98032
--- /dev/null
+++ b/tests/unit/stubs/esp_wifi_ap_get_sta_list.h
@@ -0,0 +1,38 @@
1#ifndef STUBS_ESP_WIFI_AP_GET_STA_LIST_H
2#define STUBS_ESP_WIFI_AP_GET_STA_LIST_H
3
4#include <stdint.h>
5#include <string.h>
6#include "esp_err.h"
7
8#define ESP_WIFI_AP_MAX_STA 10
9
10typedef struct {
11 uint8_t mac[6];
12} wifi_sta_info_t;
13
14typedef struct {
15 int num;
16 wifi_sta_info_t sta[ESP_WIFI_AP_MAX_STA];
17} wifi_sta_list_t;
18
19typedef struct {
20 int num;
21 struct {
22 uint8_t mac[6];
23 esp_ip4_addr_t ip;
24 } sta[ESP_WIFI_AP_MAX_STA];
25} wifi_sta_mac_ip_list_t;
26
27static inline esp_err_t esp_wifi_ap_get_sta_list(wifi_sta_list_t *sta) {
28 memset(sta, 0, sizeof(*sta));
29 return ESP_FAIL;
30}
31
32static inline esp_err_t esp_wifi_ap_get_sta_list_with_ip(const wifi_sta_list_t *sta_in, wifi_sta_mac_ip_list_t *out) {
33 (void)sta_in;
34 memset(out, 0, sizeof(*out));
35 return ESP_FAIL;
36}
37
38#endif
diff --git a/tests/unit/stubs/freertos/task.h b/tests/unit/stubs/freertos/task.h
index 3855d41..ec96156 100644
--- a/tests/unit/stubs/freertos/task.h
+++ b/tests/unit/stubs/freertos/task.h
@@ -6,14 +6,17 @@
6 6
7typedef void *TaskHandle_t; 7typedef void *TaskHandle_t;
8typedef void *SemaphoreHandle_t; 8typedef void *SemaphoreHandle_t;
9typedef int BaseType_t;
10
11#define pdPASS 1
9 12
10static inline void vTaskDelete(TaskHandle_t t) { (void)t; } 13static inline void vTaskDelete(TaskHandle_t t) { (void)t; }
11static inline SemaphoreHandle_t xSemaphoreCreateMutex(void) { return (SemaphoreHandle_t)malloc(1); } 14static inline SemaphoreHandle_t xSemaphoreCreateMutex(void) { return (SemaphoreHandle_t)malloc(1); }
12static inline void vSemaphoreDelete(SemaphoreHandle_t s) { free(s); } 15static inline void vSemaphoreDelete(SemaphoreHandle_t s) { free(s); }
13static inline int xSemaphoreTake(SemaphoreHandle_t s, uint32_t blk) { (void)s; (void)blk; return 1; } 16static inline int xSemaphoreTake(SemaphoreHandle_t s, uint32_t blk) { (void)s; (void)blk; return 1; }
14static inline int xSemaphoreGive(SemaphoreHandle_t s) { (void)s; return 1; } 17static inline int xSemaphoreGive(SemaphoreHandle_t s) { (void)s; return 1; }
15static inline int xTaskCreate(void (*fn)(void*), const char *n, uint32_t st, void *p, uint32_t pri, TaskHandle_t *h) { 18static inline BaseType_t xTaskCreate(void (*fn)(void*), const char *n, uint32_t st, void *p, uint32_t pri, TaskHandle_t *h) {
16 (void)fn; (void)n; (void)st; (void)p; (void)pri; (void)h; return 1; 19 (void)fn; (void)n; (void)st; (void)p; (void)pri; (void)h; return pdPASS;
17} 20}
18 21
19#endif 22#endif
diff --git a/tests/unit/stubs/lwip/etharp.h b/tests/unit/stubs/lwip/etharp.h
new file mode 100644
index 0000000..adc6b7b
--- /dev/null
+++ b/tests/unit/stubs/lwip/etharp.h
@@ -0,0 +1,22 @@
1#ifndef STUBS_LWIP_ETHARP_H
2#define STUBS_LWIP_ETHARP_H
3
4#include <stdint.h>
5#include <stddef.h>
6#include "lwip/ip4_addr.h"
7
8struct eth_addr {
9 uint8_t addr[6];
10};
11
12struct netif;
13
14typedef int err_t;
15#define ERR_OK 0
16
17static inline err_t etharp_get_entry(ssize_t i, ip4_addr_t **ip, struct netif **netif, struct eth_addr **eth) {
18 (void)i; (void)ip; (void)netif; (void)eth;
19 return -1;
20}
21
22#endif
diff --git a/tests/unit/stubs/lwip/ip4_addr.h b/tests/unit/stubs/lwip/ip4_addr.h
index 174211b..9d92ff0 100644
--- a/tests/unit/stubs/lwip/ip4_addr.h
+++ b/tests/unit/stubs/lwip/ip4_addr.h
@@ -3,6 +3,9 @@
3 3
4#include <stdint.h> 4#include <stdint.h>
5 5
6typedef uint32_t u32_t;
7typedef uint16_t u16_t;
8
6typedef struct { 9typedef struct {
7 uint32_t addr; 10 uint32_t addr;
8} ip4_addr_t; 11} ip4_addr_t;
diff --git a/tests/unit/stubs/lwip/napt.h b/tests/unit/stubs/lwip/lwip_napt.h
index c6a5ca1..c6a5ca1 100644
--- a/tests/unit/stubs/lwip/napt.h
+++ b/tests/unit/stubs/lwip/lwip_napt.h
diff --git a/tests/unit/stubs/lwip/netif.h b/tests/unit/stubs/lwip/netif.h
index 461a64e..9415539 100644
--- a/tests/unit/stubs/lwip/netif.h
+++ b/tests/unit/stubs/lwip/netif.h
@@ -1,4 +1,20 @@
1#ifndef STUBS_LWIP_NETIF_H 1#ifndef STUBS_LWIP_NETIF_H
2#define STUBS_LWIP_NETIF_H 2#define STUBS_LWIP_NETIF_H
3 3
4#include <stdint.h>
5#include <stddef.h>
6
7struct pbuf {
8 void *payload;
9 uint16_t len;
10};
11
12static inline uint32_t lwip_ntohl(uint32_t n) {
13 return ((n & 0xFF) << 24) | ((n & 0xFF00) << 8) | ((n >> 8) & 0xFF00) | ((n >> 24) & 0xFF);
14}
15
16static inline uint16_t lwip_ntohs(uint16_t n) {
17 return ((n & 0xFF) << 8) | ((n >> 8) & 0xFF);
18}
19
4#endif 20#endif
diff --git a/tests/unit/stubs/lwip/prot/ip.h b/tests/unit/stubs/lwip/prot/ip.h
new file mode 100644
index 0000000..0770760
--- /dev/null
+++ b/tests/unit/stubs/lwip/prot/ip.h
@@ -0,0 +1,20 @@
1#ifndef STUBS_LWIP_PROT_IP_H
2#define STUBS_LWIP_PROT_IP_H
3
4#include <stdint.h>
5
6#define IP_PROTO_TCP 6
7#define IP_PROTO_UDP 17
8#define IP_HLEN 20
9
10struct ip_hdr {
11 uint8_t _proto;
12 union {
13 uint32_t addr;
14 } src;
15 union {
16 uint32_t addr;
17 } dest;
18};
19
20#endif
diff --git a/tests/unit/stubs/lwip/prot/ip4.h b/tests/unit/stubs/lwip/prot/ip4.h
new file mode 100644
index 0000000..0f70170
--- /dev/null
+++ b/tests/unit/stubs/lwip/prot/ip4.h
@@ -0,0 +1,6 @@
1#ifndef STUBS_LWIP_PROT_IP4_H
2#define STUBS_LWIP_PROT_IP4_H
3
4#include "ip.h"
5
6#endif
diff --git a/tests/unit/stubs/lwip/prot/tcp.h b/tests/unit/stubs/lwip/prot/tcp.h
new file mode 100644
index 0000000..5841371
--- /dev/null
+++ b/tests/unit/stubs/lwip/prot/tcp.h
@@ -0,0 +1,13 @@
1#ifndef STUBS_LWIP_PROT_TCP_H
2#define STUBS_LWIP_PROT_TCP_H
3
4#include <stdint.h>
5
6#define TCP_HLEN 20
7
8struct tcp_hdr {
9 uint16_t src;
10 uint16_t dest;
11};
12
13#endif
diff --git a/tests/unit/stubs/lwip/sockets.h b/tests/unit/stubs/lwip/sockets.h
index 44f03ac..91bf8b2 100644
--- a/tests/unit/stubs/lwip/sockets.h
+++ b/tests/unit/stubs/lwip/sockets.h
@@ -1,4 +1,10 @@
1#ifndef STUBS_LWIP_SOCKETS_H 1#ifndef STUBS_LWIP_SOCKETS_H
2#define STUBS_LWIP_SOCKETS_H 2#define STUBS_LWIP_SOCKETS_H
3 3
4#include <sys/socket.h>
5#include <netinet/in.h>
6#include <arpa/inet.h>
7#include <unistd.h>
8#include <string.h>
9
4#endif 10#endif