mirror of
https://github.com/d0zingcat/gocryptotrader.git
synced 2026-05-24 23:16:52 +00:00
exchanges: Improve TestMain usage (#1946)
* exchanges: Improve TestMain usage * exchanges: Further cleanups * exchanges/kucoin: update TestProcessOrderbook to use test context * refactor: rename SetRunning to SetRunningURL for clarity across exchanges
This commit is contained in:
@@ -9,35 +9,24 @@ import (
|
||||
"os"
|
||||
"testing"
|
||||
|
||||
"github.com/thrasher-corp/gocryptotrader/config"
|
||||
exchange "github.com/thrasher-corp/gocryptotrader/exchanges"
|
||||
"github.com/thrasher-corp/gocryptotrader/exchanges/sharedtestvalues"
|
||||
testexch "github.com/thrasher-corp/gocryptotrader/internal/testing/exchange"
|
||||
)
|
||||
|
||||
var mockTests = false
|
||||
|
||||
func TestMain(m *testing.M) {
|
||||
cfg := config.GetConfig()
|
||||
err := cfg.LoadConfig("../../testdata/configtest.json", true)
|
||||
if err != nil {
|
||||
log.Fatal("Gemini load config error", err)
|
||||
g = new(Gemini)
|
||||
if err := testexch.Setup(g); err != nil {
|
||||
log.Fatalf("Gemini Setup error: %s", err)
|
||||
}
|
||||
geminiConfig, err := cfg.GetExchangeConfig("Gemini")
|
||||
if err != nil {
|
||||
log.Fatal("Gemini Setup() init error", err)
|
||||
if apiKey != "" && apiSecret != "" {
|
||||
g.API.AuthenticatedSupport = true
|
||||
g.SetCredentials(apiKey, apiSecret, "", "", "", "")
|
||||
}
|
||||
geminiConfig.API.AuthenticatedSupport = true
|
||||
geminiConfig.API.Credentials.Key = apiKey
|
||||
geminiConfig.API.Credentials.Secret = apiSecret
|
||||
g.SetDefaults()
|
||||
g.Websocket = sharedtestvalues.NewTestWebsocket()
|
||||
err = g.Setup(geminiConfig)
|
||||
if err != nil {
|
||||
log.Fatal("Gemini setup error", err)
|
||||
}
|
||||
err = g.API.Endpoints.SetRunning(exchange.RestSpot.String(), geminiAPIURL)
|
||||
if err != nil {
|
||||
log.Fatalf("endpoint setting failed. key: %s, val: %s", exchange.RestSpot.String(), geminiAPIURL)
|
||||
if err := g.API.Endpoints.SetRunningURL(exchange.RestSpot.String(), geminiAPIURL); err != nil {
|
||||
log.Fatalf("Gemini SetRunningURL error: %s", err)
|
||||
}
|
||||
log.Printf(sharedtestvalues.LiveTesting, g.Name)
|
||||
os.Exit(m.Run())
|
||||
|
||||
@@ -9,52 +9,20 @@ import (
|
||||
"os"
|
||||
"testing"
|
||||
|
||||
"github.com/thrasher-corp/gocryptotrader/config"
|
||||
"github.com/thrasher-corp/gocryptotrader/exchanges/mock"
|
||||
"github.com/thrasher-corp/gocryptotrader/exchanges/sharedtestvalues"
|
||||
testexch "github.com/thrasher-corp/gocryptotrader/internal/testing/exchange"
|
||||
)
|
||||
|
||||
const mockFile = "../../testdata/http_mock/gemini/gemini.json"
|
||||
|
||||
var mockTests = true
|
||||
|
||||
func TestMain(m *testing.M) {
|
||||
cfg := config.GetConfig()
|
||||
err := cfg.LoadConfig("../../testdata/configtest.json", true)
|
||||
if err != nil {
|
||||
log.Fatal("Gemini load config error", err)
|
||||
}
|
||||
geminiConfig, err := cfg.GetExchangeConfig("Gemini")
|
||||
if err != nil {
|
||||
log.Fatal("Mock server error", err)
|
||||
}
|
||||
g.SkipAuthCheck = true
|
||||
geminiConfig.API.AuthenticatedSupport = true
|
||||
geminiConfig.API.Credentials.Key = apiKey
|
||||
geminiConfig.API.Credentials.Secret = apiSecret
|
||||
g.SetDefaults()
|
||||
g.Websocket = sharedtestvalues.NewTestWebsocket()
|
||||
err = g.Setup(geminiConfig)
|
||||
if err != nil {
|
||||
log.Fatal("Gemini setup error", err)
|
||||
g = new(Gemini)
|
||||
if err := testexch.Setup(g); err != nil {
|
||||
log.Fatalf("Gemini Setup error: %s", err)
|
||||
}
|
||||
|
||||
serverDetails, newClient, err := mock.NewVCRServer(mockFile)
|
||||
if err != nil {
|
||||
log.Fatalf("Mock server error %s", err)
|
||||
if err := testexch.MockHTTPInstance(g); err != nil {
|
||||
log.Fatalf("Gemini MockHTTPInstance error: %s", err)
|
||||
}
|
||||
|
||||
err = g.SetHTTPClient(newClient)
|
||||
if err != nil {
|
||||
log.Fatalf("Mock server error %s", err)
|
||||
}
|
||||
endpointMap := g.API.Endpoints.GetURLMap()
|
||||
for k := range endpointMap {
|
||||
err = g.API.Endpoints.SetRunning(k, serverDetails)
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
}
|
||||
log.Printf(sharedtestvalues.MockTesting, g.Name)
|
||||
os.Exit(m.Run())
|
||||
}
|
||||
|
||||
@@ -552,7 +552,7 @@ func TestGetDepositAddress(t *testing.T) {
|
||||
// TestWsAuth dials websocket, sends login request.
|
||||
func TestWsAuth(t *testing.T) {
|
||||
t.Parallel()
|
||||
err := g.API.Endpoints.SetRunning(exchange.WebsocketSpot.String(), geminiWebsocketSandboxEndpoint)
|
||||
err := g.API.Endpoints.SetRunningURL(exchange.WebsocketSpot.String(), geminiWebsocketSandboxEndpoint)
|
||||
if err != nil {
|
||||
t.Error(err)
|
||||
}
|
||||
|
||||
@@ -128,7 +128,7 @@ func (g *Gemini) Setup(exch *config.Exchange) error {
|
||||
}
|
||||
|
||||
if exch.UseSandbox {
|
||||
err = g.API.Endpoints.SetRunning(exchange.RestSpot.String(), geminiSandboxAPIURL)
|
||||
err = g.API.Endpoints.SetRunningURL(exchange.RestSpot.String(), geminiSandboxAPIURL)
|
||||
if err != nil {
|
||||
log.Errorln(log.ExchangeSys, err)
|
||||
}
|
||||
|
||||
22335
exchanges/gemini/testdata/http.json
vendored
Normal file
22335
exchanges/gemini/testdata/http.json
vendored
Normal file
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user