* Add initial workflows config * Add PSQL service * Add 32bit and frontend jobs * Add gcc-multilib and fix typo * Fix backtester test for linux/unix filesystem errors and npm commands * 32-bit Add -race to purposefully throw an error to ensure envs are set correctly (will revert) * Revert "32-bit Add -race to purposefully throw an error to ensure envs are set correctly (will revert)" This reverts commit b97e66c49fca859f8738e01107f96f9ca4040b2e. * Bump workers count for orderbook processing * Remove comments to trigger 32-bit cache hit after job success * Cancel addition plus version bump, spawn more overlords * Update build badge to Github Actions * Brach -> Branch
3.9 KiB
GoCryptoTrader Backtester: Exchange package
This exchange package is part of the GoCryptoTrader codebase.
This is still in active development
You can track ideas, planned features and what's in progress on this Trello board: https://trello.com/b/ZAhMhpOy/gocryptotrader.
Join our slack to discuss all things related to GoCryptoTrader! GoCryptoTrader Slack
Exchange package overview
The exchange eventhandler is responsible for calling the engine package's ordermanager to place either a fake, or real order on the exchange via API.
The following steps are taken for the ExecuteOrder function:
- Calculate slippage. If the order is a sell order, it will reduce the price by a random percentage between the two values. If it is a buy order, it will raise the price by a random percentage between the two values
- If
RealOrdersis set tofalse:- It will estimate the slippage based on what is in the config file under
min-slippage-percentandmax-slippage-percent. - It will be sized within the constraints of the current candles OHLCV values
- It will generate the exchange fee based on what is stored in the config for the exchange asset currency pair
- It will estimate the slippage based on what is in the config file under
- If
RealOrdersis set totrue, it will use the latest orderbook data to calculate slippage by simulating the order
- If
- Place the order with the engine order manager
- If
RealOrdersis set tofalseit will submit the order with no calls to the exchange's API, use no API credentials and it will always pass - If
RealOrdersis set totrueit will submit the order via the exchange's API and if successful, will be stored in the order manager - If an order is successfully placed, a snapshot of all existing orders in the run will be captured and store for statistical purposes
Please click GoDocs chevron above to view current GoDoc information for this package
Contribution
Please feel free to submit any pull requests or suggest any desired features to be added.
When submitting a PR, please abide by our coding guidelines:
- Code must adhere to the official Go formatting guidelines (i.e. uses gofmt).
- Code must be documented adhering to the official Go commentary guidelines.
- Code must adhere to our coding style.
- Pull requests need to be based on and opened against the
masterbranch.
Donations
If this framework helped you in any way, or you would like to support the developers working on it, please donate Bitcoin to:
bc1qk0jareu4jytc0cfrhr5wgshsq8282awpavfahc