From cdf9481bef898ce8b878400b2901b9fcabb02980 Mon Sep 17 00:00:00 2001 From: Shawn Reuland Date: Mon, 12 Feb 2024 12:48:59 -0800 Subject: [PATCH] #8: make the test config params proper, per review feedback --- cmd/soroban-rpc/internal/test/archive_test.go | 2 +- cmd/soroban-rpc/internal/test/integration.go | 27 ++++++++++--------- 2 files changed, 16 insertions(+), 13 deletions(-) diff --git a/cmd/soroban-rpc/internal/test/archive_test.go b/cmd/soroban-rpc/internal/test/archive_test.go index 2840881e..127e6e61 100644 --- a/cmd/soroban-rpc/internal/test/archive_test.go +++ b/cmd/soroban-rpc/internal/test/archive_test.go @@ -10,7 +10,7 @@ import ( func TestArchiveUserAgent(t *testing.T) { userAgents := sync.Map{} - cfg := &Test{ + cfg := &TestConfig{ historyArchiveProxyCallback: func(r *http.Request) { userAgents.Store(r.Header["User-Agent"][0], "") }, diff --git a/cmd/soroban-rpc/internal/test/integration.go b/cmd/soroban-rpc/internal/test/integration.go index b1e98f85..d3755a9c 100644 --- a/cmd/soroban-rpc/internal/test/integration.go +++ b/cmd/soroban-rpc/internal/test/integration.go @@ -34,9 +34,11 @@ const ( StandaloneNetworkPassphrase = "Standalone Network ; February 2017" stellarCoreProtocolVersion = 20 stellarCorePort = 11626 + stellarCoreArchiveHost = "localhost:1570" goModFile = "go.mod" goMonorepoGithubPath = "github.com/stellar/go" - friendbotURL = "http://localhost:8000/friendbot" + + friendbotURL = "http://localhost:8000/friendbot" // Needed when Core is run with ARTIFICIALLY_ACCELERATE_TIME_FOR_TESTING=true checkpointFrequency = 8 sorobanRPCPort = 8000 @@ -44,6 +46,10 @@ const ( helloWorldContractPath = "../../../../target/wasm32-unknown-unknown/test-wasms/test_hello_world.wasm" ) +type TestConfig struct { + historyArchiveProxyCallback func(*http.Request) +} + type Test struct { t *testing.T @@ -61,7 +67,7 @@ type Test struct { shutdownCalls []func() } -func NewTest(t *testing.T, i *Test) *Test { +func NewTest(t *testing.T, cfg *TestConfig) *Test { if os.Getenv("SOROBAN_RPC_INTEGRATION_TESTS_ENABLED") == "" { t.Skip("skipping integration test: SOROBAN_RPC_INTEGRATION_TESTS_ENABLED not set") } @@ -70,22 +76,19 @@ func NewTest(t *testing.T, i *Test) *Test { t.Fatal("missing SOROBAN_RPC_INTEGRATION_TESTS_CAPTIVE_CORE_BIN") } - if i == nil { - i = &Test{} + i := &Test{ + t: t, + composePath: findDockerComposePath(), } - - i.t = t - i.composePath = findDockerComposePath() i.masterAccount = &txnbuild.SimpleAccount{ AccountID: i.MasterKey().Address(), Sequence: 0, } - - origin, err := url.Parse("http://localhost:1570") - if err != nil { - panic(err) + if cfg != nil { + i.historyArchiveProxyCallback = cfg.historyArchiveProxyCallback } - proxy := httputil.NewSingleHostReverseProxy(origin) + + proxy := httputil.NewSingleHostReverseProxy(&url.URL{Scheme: "http", Host: stellarCoreArchiveHost}) i.historyArchiveProxy = httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { if i.historyArchiveProxyCallback != nil {