Skip to content

Sandbox API testing

Some exchanges provide sandboxes or testbeds for risk-free testing, while running the bot against a real exchange. With some configuration, freqtrade (in combination with ccxt) provides access to these.

This document is an overview to configure Freqtrade to be used with sandboxes. This can be useful to developers and trader alike.

Warning

Sandboxes usually have very low volume, and either a very wide spread, or no orders available at all. Therefore, sandboxes will usually not do a good job of showing you how a strategy would work in real trading.

Exchanges known to have a sandbox / testnet

Note

We did not test correct functioning of all of the above testnets. Please report your experiences with each sandbox.


Configure a Sandbox account

When testing your API connectivity, make sure to use the appropriate sandbox / testnet URL.

In general, you should follow these steps to enable an exchange's sandbox:

  • Figure out if an exchange has a sandbox (most likely by using google or the exchange's support documents)
  • Create a sandbox account (often the sandbox-account requires separate registration)
  • Add some test assets to account
  • Create API keys

Add test funds

Usually, sandbox exchanges allow depositing funds directly via web-interface. You should make sure to have a realistic amount of funds available to your test-account, so results are representable of your real account funds.

Warning

Test exchanges will NEVER require your real credit card or banking details!

Configure freqtrade to use a exchange's sandbox

Sandbox URLs

Freqtrade makes use of CCXT which in turn provides a list of URLs to Freqtrade. These include ['test'] and ['api'].

  • [Test] if available will point to an Exchanges sandbox.
  • [Api] normally used, and resolves to live API target on the exchange.

To make use of sandbox / test add "sandbox": true, to your config.json

  "exchange": {
        "name": "coinbasepro",
        "sandbox": true,
        "key": "5wowfxemogxeowo;heiohgmd",
        "secret": "/ZMH1P62rCVmwefewrgcewX8nh4gob+lywxfwfxwwfxwfNsH1ySgvWCUR/w==",
        "password": "1bkjfkhfhfu6sr",
        "outdated_offset": 5
        "pair_whitelist": [
            "BTC/USD"
        ]
  },
  "datadir": "user_data/data/coinbasepro_sandbox"

Also the following information:

  • api-key (created for the sandbox webpage)
  • api-secret (noted earlier)
  • password (the passphrase - noted earlier)

Different data directory

We also recommend to set datadir to something identifying downloaded data as sandbox data, to avoid having sandbox data mixed with data from the real exchange. This can be done by adding the "datadir" key to the configuration. Now, whenever you use this configuration, your data directory will be set to this directory.


You should now be ready to test your sandbox

Ensure Freqtrade logs show the sandbox URL, and trades made are shown in sandbox. Also make sure to select a pair which shows at least some decent value (which very often is BTC/).

Common problems with sandbox exchanges

Sandbox exchange instances often have very low volume, which can cause some problems which usually are not seen on a real exchange instance.

Old Candles problem

Since Sandboxes often have low volume, candles can be quite old and show no volume. To disable the error "Outdated history for pair ...", best increase the parameter "outdated_offset" to a number that seems realistic for the sandbox you're using.

Unfilled orders

Sandboxes often have very low volumes - which means that many trades can go unfilled, or can go unfilled for a very long time.

To mitigate this, you can try to match the first order on the opposite orderbook side using the following configuration:

jsonc "order_types": { "entry": "limit", "exit": "limit" // ... }, "entry_pricing": { "price_side": "other", // ... }, "exit_pricing":{ "price_side": "other", // ... },

The configuration is similar to the suggested configuration for market orders - however by using limit-orders you can avoid moving the price too much, and you can set the worst price you might get.