Freshness diagnostics API, UI trust notes, mission control/stats updates, and deploy scripts.

Made-with: Cursor
This commit is contained in:
defiQUG
2026-04-12 06:33:54 -07:00
parent 0972178cc5
commit 3fdb812a29
63 changed files with 5163 additions and 826 deletions

View File

@@ -2,10 +2,17 @@ package rest
import (
"context"
"database/sql"
"encoding/json"
"errors"
"net/http"
"net/http/httptest"
"strconv"
"strings"
"testing"
"time"
"github.com/explorer/backend/api/freshness"
"github.com/jackc/pgx/v5"
"github.com/stretchr/testify/require"
)
@@ -19,23 +26,56 @@ func (r fakeStatsRow) Scan(dest ...any) error {
}
func TestLoadExplorerStatsReturnsValues(t *testing.T) {
rpc := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
var req struct {
Method string `json:"method"`
}
require.NoError(t, json.NewDecoder(r.Body).Decode(&req))
w.Header().Set("Content-Type", "application/json")
switch req.Method {
case "eth_blockNumber":
_, _ = w.Write([]byte(`{"jsonrpc":"2.0","id":1,"result":"0x2c"}`))
case "eth_getBlockByNumber":
ts := time.Now().Add(-2 * time.Second).Unix()
_, _ = w.Write([]byte(`{"jsonrpc":"2.0","id":1,"result":{"timestamp":"0x` + strconv.FormatInt(ts, 16) + `"}}`))
default:
http.Error(w, `{"jsonrpc":"2.0","id":1,"error":{"message":"unsupported"}}`, http.StatusBadRequest)
}
}))
defer rpc.Close()
t.Setenv("RPC_URL", rpc.URL)
var call int
queryRow := func(_ context.Context, _ string, _ ...any) pgx.Row {
call++
return fakeStatsRow{
scan: func(dest ...any) error {
target, ok := dest[0].(*int64)
require.True(t, ok)
switch call {
case 1:
*target = 11
*dest[0].(*int64) = 11
case 2:
*target = 22
*dest[0].(*int64) = 22
case 3:
*target = 33
*dest[0].(*int64) = 33
case 4:
*target = 44
*dest[0].(*int64) = 44
case 5:
*dest[0].(*sql.NullFloat64) = sql.NullFloat64{Float64: 2000, Valid: true}
case 6:
*dest[0].(*sql.NullFloat64) = sql.NullFloat64{Float64: 1.25, Valid: true}
case 7:
*dest[0].(*sql.NullFloat64) = sql.NullFloat64{Float64: 37.5, Valid: true}
case 8:
*dest[0].(*sql.NullInt64) = sql.NullInt64{Int64: 18, Valid: true}
case 9:
*dest[0].(*int64) = 44
*dest[1].(*time.Time) = time.Now().Add(-2 * time.Second)
case 10:
*dest[0].(*string) = "0xabc"
*dest[1].(*int64) = 40
*dest[2].(*time.Time) = time.Now().Add(-5 * time.Second)
case 11:
*dest[0].(*int64) = 40
*dest[1].(*time.Time) = time.Now().Add(-5 * time.Second)
default:
t.Fatalf("unexpected query call %d", call)
}
@@ -50,9 +90,25 @@ func TestLoadExplorerStatsReturnsValues(t *testing.T) {
require.Equal(t, int64(22), stats.TotalTransactions)
require.Equal(t, int64(33), stats.TotalAddresses)
require.Equal(t, int64(44), stats.LatestBlock)
require.NotNil(t, stats.AverageBlockTime)
require.Equal(t, 2000.0, *stats.AverageBlockTime)
require.NotNil(t, stats.GasPrices)
require.NotNil(t, stats.GasPrices.Average)
require.Equal(t, 1.25, *stats.GasPrices.Average)
require.NotNil(t, stats.NetworkUtilizationPercentage)
require.Equal(t, 37.5, *stats.NetworkUtilizationPercentage)
require.NotNil(t, stats.TransactionsToday)
require.Equal(t, int64(18), *stats.TransactionsToday)
require.NotNil(t, stats.Freshness.ChainHead.BlockNumber)
require.Equal(t, int64(40), *stats.Freshness.LatestIndexedTransaction.BlockNumber)
require.Equal(t, int64(4), *stats.Freshness.LatestNonEmptyBlock.DistanceFromHead)
require.Equal(t, "reported", string(stats.Freshness.ChainHead.Source))
require.Equal(t, freshness.CompletenessComplete, stats.Completeness.GasMetrics)
require.Equal(t, freshness.CompletenessComplete, stats.Completeness.UtilizationMetric)
}
func TestLoadExplorerStatsReturnsErrorWhenQueryFails(t *testing.T) {
t.Setenv("RPC_URL", "")
queryRow := func(_ context.Context, query string, _ ...any) pgx.Row {
return fakeStatsRow{
scan: func(dest ...any) error {