-
Notifications
You must be signed in to change notification settings - Fork 820
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
exchanges: shift GetDefaultConfig wrapper function to exchange.go #1472
Conversation
…ition, to ensure set defaults doesn't get called twice and to reduce code
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## master #1472 +/- ##
==========================================
+ Coverage 35.89% 35.96% +0.06%
==========================================
Files 411 411
Lines 177595 177227 -368
==========================================
- Hits 63752 63734 -18
+ Misses 106058 105705 -353
- Partials 7785 7788 +3
|
74fbfdb
to
72e5947
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nice simplification 🤙
exchanges/interfaces.go
Outdated
@@ -188,3 +189,11 @@ type MarginManagement interface { | |||
futures.PNLCalculation | |||
GetFuturesContractDetails(ctx context.Context, item asset.Item) ([]futures.Contract, error) | |||
} | |||
|
|||
// LimitedScope defines a subset of the exchange interface | |||
type LimitedScope interface { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think it would be good to rename it to be more relevant to its limited scope. ConfigGeneration
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I purged it, I was being lazy, you can see why in recent update.
exchanges/exchange.go
Outdated
@@ -1943,3 +1944,37 @@ func (b *Base) Bootstrap(_ context.Context) (continueBootstrap bool, err error) | |||
func (b *Base) IsVerbose() bool { | |||
return b.Verbose | |||
} | |||
|
|||
// GetDefaultConfig returns a default exchange config | |||
func (b *Base) GetDefaultConfig(ctx context.Context, instance LimitedScope) (*config.Exchange, error) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I agree with your PR assessment that its a bit jank. I think this can become an exported function instead
func GetDefaultConfig(ctx context.Context, instance IBotExchange) (*config.Exchange, error) {
That or LimitedScope
, but I don't see much problem with using IBotExchange
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
tACK! Thank you for improving the jank from last time 🎉
if err != nil { | ||
log.Errorln(common.LiveStrategy, err) | ||
} | ||
log.Errorln(common.LiveStrategy, err) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
log.Errorln(common.LiveStrategy, err) | |
if err != nil { | |
if err != nil { | |
if err == nil { | |
} else { | |
log.Errorln(common.LiveStrategy, err) | |
} | |
} | |
} |
😄
if exch.GetName() == "" { | ||
exch.SetDefaults() | ||
} | ||
|
||
b := exch.GetBase() | ||
|
||
exchCfg, err := b.GetStandardConfig() | ||
if err != nil { | ||
return nil, err | ||
} | ||
|
||
err = b.SetupDefaults(exchCfg) | ||
if err != nil { | ||
return nil, err | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This function is so weird! "get me the default config" means setup some parts of the exchange, reset some exchange values to the default config's and then make REST calls.
I'm not going to make you refactor this, it's how its been and refactoring isn't really going to improve much right now. Just a fun function
Moved to exchange base by thrasher-corp#1472
Moved to exchange base by thrasher-corp#1472
Moved to exchange base by thrasher-corp#1472
Moved to exchange base by thrasher-corp#1472
Moved to exchange base by thrasher-corp#1472
Moved to exchange base by thrasher-corp#1472
* Kline: Fix Raw Short, Marshal and Unmarshal * Deribit: Rename GenerateDefaultSubs * Deribit: Remove custom GetDefaultConfig Moved to exchange base by #1472 * Deribit: Straight Rename of eps to endpoints Since I had to ask what this abbreviation meant, I think we should abandon it * Deribit: Add Subscription configuration * Deribit: Fix race on Setup with optionsRegex Calling Setup twice would race on the assignment to this package var. There was an option to just move the assignment to the package var declaration, but this change improves the performance and allocations: ``` BenchmarkOptionPairToString-8 1000000 1239 ns/op 485 B/op 10 allocs/op BenchmarkOptionPairToString2-8 3473804 656.2 ns/op 348 B/op 7 allocs/op ``` I've also removed the t.Run because even success the -v output from tests would be very noisy, and I don't think we were getting any benefit from it at all: ``` === RUN TestOptionPairToString === PAUSE TestOptionPairToString === CONT TestOptionPairToString === RUN TestOptionPairToString/BTC-30MAY24-61000-C === PAUSE TestOptionPairToString/BTC-30MAY24-61000-C === RUN TestOptionPairToString/ETH-1JUN24-3200-P === PAUSE TestOptionPairToString/ETH-1JUN24-3200-P === RUN TestOptionPairToString/SOL_USDC-31MAY24-162-P === PAUSE TestOptionPairToString/SOL_USDC-31MAY24-162-P === RUN TestOptionPairToString/MATIC_USDC-6APR24-0d98-P === PAUSE TestOptionPairToString/MATIC_USDC-6APR24-0d98-P === CONT TestOptionPairToString/BTC-30MAY24-61000-C === CONT TestOptionPairToString/SOL_USDC-31MAY24-162-P === CONT TestOptionPairToString/ETH-1JUN24-3200-P === CONT TestOptionPairToString/MATIC_USDC-6APR24-0d98-P --- PASS: TestOptionPairToString (0.00s) --- PASS: TestOptionPairToString/BTC-30MAY24-61000-C (0.00s) --- PASS: TestOptionPairToString/ETH-1JUN24-3200-P (0.00s) --- PASS: TestOptionPairToString/SOL_USDC-31MAY24-162-P (0.00s) --- PASS: TestOptionPairToString/MATIC_USDC-6APR24-0d98-P (0.00s) ``` ( And that got worse with me adding more tests )
PR Description
Shifts
GetDefaultConfig
wrapper function toexchange.go
Mitigates potential issue when its called in a wrapper test and overwrites memory after initial
SetDefault
method func is called.Also RMs a bunch of code wrapper side which is nice but its signature is a tad janky. Optionally we can disconnect it as a method and just have an exported function.
Type of change
Please delete options that are not relevant and add an
x
in[]
as item is complete.How has this been tested
Please describe the tests that you ran to verify your changes. Provide instructions so we can reproduce. Please also list any relevant details for your test configuration and
also consider improving test coverage whilst working on a certain feature or package.
Checklist