mirror of
https://github.com/d0zingcat/gocryptotrader.git
synced 2026-05-13 23:16:45 +00:00
* Added TimeInForce type and updated related files * Linter issue fix and minor coinbasepro type update * Bitrex consts update * added unit test and minor changes in bittrex * Unit tests update * Fix minor linter issues * Update TestStringToTimeInForce unit test * Exchange test template change * A different approach * fix conflict with gateio timeInForce * minor exchange template update * Minor fix to test_files template * Update order tests * Complete updating the order unit tests * Updating exchange wrapper and test template files * update kucoin and deribit wrapper to match the time in force change * minor comment update * fix time-in-force related test errors * linter issue fix * ADD_NEW_EXCHANGE documentation update * time in force constants, functions and unit tests update * shift tif policies to TimeInForce * Update time-in-force, related functions, and unit tests * fix linter issue and time-in-force processing * added a good till crossing tif value * order type fix and fix related tim-in-force entries * update time-in-force unmarshaling and unit test * consistency guideline added * fix time-in-force error in gateio * linter issue fix * update based on review comments * add unit test and fix missing issues * minor fix and added benchmark unit test * change GTT to GTC for limit * fix linter issue * added time-in-force value to place order param * fix minor issues based on review comment and move tif code to separate files * update on exchanges linked to time-in-force * resolve missing review comments * minor linter issues fix * added time-in-force handler and update timeInForce parametered endpoint * minor fixes based on review * nits fix * update based on review * linter fix * rm getTimeInForce func and minor change to time-in-force * minor change * update based on review comments * wrappers and time-in-force calling approach * minor change * update gateio string to timeInForce conversion and unit test * update exchange template * update wrapper template file * policy comments, and template files update * rename all exchange types name to Exchange * update on template files and template generation * templates and generation code and other updates * linter issue fix * added subscriptions and websocket templates * update ADD_NEW_EXCHANGE.md with recent binance functions and implementations * rename template files and update unit tests * minor template and unit test fix * rename templates and fix on unit tests * update on template files and documentation * removed unnecessary tag fix and update templates * fix Add_NEW_EXCHANGE.md doc file * formatting, comments, and error checks update on template files * rename exchange receivers to e and ex for consistency * rename unit test exchange receiver and minor updates * linter issues fix * fix deribit issue and minor style update * fix test issues caused by receiver change * raname local variables exchange declaration variables * update templates comments * update templates and related comments * renamed ex to e * update template comments * toggle WS to false to improve coverage * template comments update * added test coverage to Ws enabled and minor changes --------- Co-authored-by: Samuel Reid <43227667+cranktakular@users.noreply.github.com>
100 lines
2.1 KiB
Go
100 lines
2.1 KiB
Go
package main
|
|
|
|
import (
|
|
"os"
|
|
"path/filepath"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
"github.com/thrasher-corp/gocryptotrader/common/file"
|
|
"github.com/thrasher-corp/gocryptotrader/config"
|
|
)
|
|
|
|
func TestCheckExchangeName(t *testing.T) {
|
|
t.Parallel()
|
|
for _, tt := range []struct {
|
|
Name string
|
|
ErrExpected error
|
|
}{
|
|
{
|
|
Name: "test exch",
|
|
ErrExpected: errInvalidExchangeName,
|
|
},
|
|
{
|
|
ErrExpected: errInvalidExchangeName,
|
|
},
|
|
{
|
|
Name: " ",
|
|
ErrExpected: errInvalidExchangeName,
|
|
},
|
|
{
|
|
Name: "m",
|
|
ErrExpected: errInvalidExchangeName,
|
|
},
|
|
{
|
|
Name: "mu",
|
|
ErrExpected: errInvalidExchangeName,
|
|
},
|
|
{
|
|
Name: "testexch",
|
|
},
|
|
} {
|
|
t.Run(tt.Name, func(t *testing.T) {
|
|
t.Parallel()
|
|
err := checkExchangeName(tt.Name)
|
|
if tt.ErrExpected == nil {
|
|
assert.NoError(t, err)
|
|
} else {
|
|
assert.Equal(t, tt.ErrExpected, err)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestNewExchangeAndSaveConfig(t *testing.T) {
|
|
const testExchangeName = "testexch"
|
|
testExchangeDir := filepath.Join(targetPath, testExchangeName)
|
|
cfg := config.GetConfig()
|
|
|
|
t.Cleanup(func() {
|
|
if err := os.RemoveAll(testExchangeDir); err != nil {
|
|
t.Errorf("RemoveAll failed: %s, manual deletion of test directory required", err)
|
|
}
|
|
})
|
|
|
|
_, err := makeExchange(
|
|
testExchangeDir,
|
|
cfg,
|
|
&exchange{
|
|
Name: testExchangeName,
|
|
REST: true,
|
|
WS: true,
|
|
},
|
|
)
|
|
assert.NoError(t, err)
|
|
|
|
err = os.RemoveAll(testExchangeDir)
|
|
require.NoErrorf(t, err, "RemoveAll failed: %s, manual deletion of test directory required", err)
|
|
|
|
exchCfg, err := makeExchange(
|
|
testExchangeDir,
|
|
cfg,
|
|
&exchange{
|
|
Name: testExchangeName,
|
|
REST: true,
|
|
WS: false,
|
|
},
|
|
)
|
|
require.NoError(t, err)
|
|
|
|
cfgData, err := os.ReadFile(exchangeConfigPath)
|
|
require.NoError(t, err, "os.ReadFile must not error")
|
|
|
|
err = saveConfig(testExchangeDir, cfg, exchCfg)
|
|
require.NoError(t, err, "saveConfig must not error")
|
|
|
|
err = os.WriteFile(exchangeConfigPath, cfgData, file.DefaultPermissionOctal)
|
|
require.NoError(t, err, "os.WriteFile must not error")
|
|
}
|