Files
gocryptotrader/currency/conversion_test.go
Scott ccfcdf26aa Engine: Protocol Features, coverage, types, BTC markets websocket (#368)
* Attempts to update orderbook so it doesn't need to sort

* Reverts the ws ob stuff. Gets rid of sorting because it happens later. Adds some exchange features

* update existing feature lists. Expands list definition to match my emotions

* Adds bithumb bitmex and bitstamp. adds a couple more types

* Features for you, features for me, features for bittrex, btcmarkets, btse, coinbasepro, coinut, exmo, gateio and gemini

* Features for hitbtc, huobi, itbit, kraken, lakebtc, lbank, localbitcoins, okcoin, okex, poloniex, yobit, zb

* Who can forget good old alphapoint?

* Adds btcmarksets websocket :glitch_crab: fixes alphapoint features

* Adds extra data not in the documentation :/

* Replaces websocket features by using protocol features. However, it breaks it due to import cycles. I'm not sure what I'll do just yet

* Removes import cycle via duplicate structs.

* Increases coverage of config with `TestCheckCurrencyConfigValues`. Moves all currency pair package types into their own files or places it at the bottom of files if necessary

* Increase coverage in code.go

* One way of determining a test has failed, is when to it fails. Removed redundant explanation

* Increases code coverage of conversion

* Lint fixes

* Fixes orderbook tests

* Re-adds sorting because its important to still have the internal pre-processed orderbook to be representative of a real orderbook

* Secret lints that did not show up via Windows linting

* Adds protocol package to contain exchange features

* Fixes protocol implementation

* Fixes ws tests

* Addresses the following: Removes st-st-stutters in config types, changes GetAvailableForexProviders -> GetSupportedForexProviders, removes errors from tests where error is nil, removes orderbook setup when not necessary, removes import newlines, removes false bools from declaration, changes should of to should have

* imports and casing

* Fixes two more nil error checks
2019-10-22 10:56:20 +11:00

248 lines
4.8 KiB
Go

package currency
import (
"fmt"
"strings"
"testing"
)
func TestNewConversionFromString(t *testing.T) {
expected := "AUDUSD"
conv, err := NewConversionFromString(expected)
if err != nil {
t.Error(err)
}
if conv.String() != expected {
t.Errorf("NewConversion() error expected %s but received %s",
expected,
conv)
}
newexpected := strings.ToLower(expected)
conv, err = NewConversionFromString(newexpected)
if err != nil {
t.Error(err)
}
if conv.String() != newexpected {
t.Errorf("NewConversion() error expected %s but received %s",
newexpected,
conv)
}
}
func TestNewConversionFromStrings(t *testing.T) {
from := "AUD"
to := "USD"
expected := "AUDUSD"
conv, err := NewConversionFromStrings(from, to)
if err != nil {
t.Error(err)
}
if conv.String() != expected {
t.Errorf("NewConversion() error expected %s but received %s",
expected,
conv)
}
}
func TestNewConversion(t *testing.T) {
from := NewCode("AUD")
to := NewCode("USD")
expected := "AUDUSD"
conv, err := NewConversion(from, to)
if err != nil {
t.Error(err)
}
if conv.String() != expected {
t.Errorf("NewConversion() error expected %s but received %s",
expected,
conv)
}
}
func TestConversionIsInvalid(t *testing.T) {
from := AUD
to := USD
conv, err := NewConversion(from, to)
if err != nil {
t.Fatal(err)
}
if conv.IsInvalid() {
t.Errorf("IsInvalid() error expected false but received %v",
conv.IsInvalid())
}
to = AUD
conv, err = NewConversion(from, to)
if err == nil {
t.Error("Expected error")
}
}
func TestConversionIsFiatPair(t *testing.T) {
from := AUD
to := USD
conv, err := NewConversion(from, to)
if err != nil {
t.Fatal(err)
}
if !conv.IsFiat() {
t.Errorf("IsFiatPair() error expected true but received %v",
conv.IsFiat())
}
to = LTC
conv, err = NewConversion(from, to)
if err == nil {
t.Error("Expected error")
}
}
func TestConversionsRatesSystem(t *testing.T) {
var SuperDuperConversionSystem ConversionRates
if SuperDuperConversionSystem.HasData() {
t.Fatalf("HasData() error expected false but received %v",
SuperDuperConversionSystem.HasData())
}
testmap := map[string]float64{
"USDAUD": 1.3969317581,
"USDBRL": 3.7047257979,
"USDCAD": 1.3186386881,
"USDCHF": 1,
"USDCNY": 6.7222712044,
"USDCZK": 22.6406277552,
"USDDKK": 6.5785575736,
"USDEUR": 0.8816787163,
"USDGBP": 0.7665755599,
"USDHKD": 7.8492329395,
"USDILS": 3.6152354082,
"USDINR": 71.154558279,
"USDJPY": 110.7476635514,
"USDKRW": 1122.7913948157,
"USDMXN": 19.1589666725,
"USDNOK": 8.5818197849,
"USDNZD": 1.4559160642,
"USDPLN": 3.8304531829,
"USDRUB": 65.7533062952,
"USDSEK": 9.3196085346,
"USDSGD": 1.3512608006,
"USDTHB": 31.0950449656,
"USDZAR": 14.138070887,
}
err := SuperDuperConversionSystem.Update(testmap)
if err != nil {
t.Fatal(err)
}
err = SuperDuperConversionSystem.Update(nil)
if err == nil {
t.Fatal("Update() error cannot be nil")
}
if !SuperDuperConversionSystem.HasData() {
t.Fatalf("HasData() error expected true but received %v",
SuperDuperConversionSystem.HasData())
}
// * to a rate
p := SuperDuperConversionSystem.m[USD.Item][AUD.Item]
// inverse * to a rate
pi := SuperDuperConversionSystem.m[AUD.Item][USD.Item]
r := *p * 1000
expectedRate := 1396.9317581
if r != expectedRate {
t.Errorf("Convert() error expected %.13f but received %.13f",
expectedRate,
r)
}
inverseR := *pi * expectedRate
expectedInverseRate := float64(1000)
if inverseR != expectedInverseRate {
t.Errorf("Convert() error expected %.13f but received %.13f",
expectedInverseRate,
inverseR)
}
}
func TestGetRate(t *testing.T) {
from := NewCode("AUD")
to := NewCode("USD")
c, err := NewConversion(from, to)
if err != nil {
t.Error(err)
}
rate, err := c.GetRate()
if err != nil {
t.Error(err)
}
if rate == 0 {
t.Error("Rate not set")
}
inv, err := c.GetInversionRate()
if err != nil {
t.Error(err)
}
if inv == 0 {
t.Error("Inverted rate not set")
}
conv, err := c.Convert(1)
if err != nil {
t.Error(err)
}
if rate != conv {
t.Errorf("Incorrect rate %v %v", rate, conv)
}
invConv, err := c.ConvertInverse(1)
if err != nil {
t.Error(err)
}
if inv != invConv {
t.Errorf("Incorrect rate %v %v", conv, invConv)
}
var convs ConversionRates
var convRate float64
_, err = convs.GetRate(BTC, USDT)
if err == nil {
t.Errorf("Expected %s", fmt.Errorf("rate not found for from %s to %s conversion",
BTC,
USD))
}
convRate, err = convs.GetRate(USDT, USD)
if err != nil {
t.Error(err)
}
if convRate != 1 {
t.Errorf("Expected rate to be 1")
}
convRate, err = convs.GetRate(RUR, RUB)
if err != nil {
t.Error(err)
}
if convRate != 1 {
t.Errorf("Expected rate to be 1")
}
convRate, err = convs.GetRate(RUB, RUR)
if err != nil {
t.Error(err)
}
if convRate != 1 {
t.Errorf("Expected rate to be 1")
}
}