kucoin_spot_test.rs 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. mod exchange_test;
  2. use std::collections::BTreeMap;
  3. use std::env;
  4. use std::io::Error;
  5. use rust_decimal_macros::dec;
  6. use tokio::sync::mpsc;
  7. use tracing::{instrument, trace};
  8. use standard::exchange::{Exchange, ExchangeEnum};
  9. use standard::{Order, OrderCommand, Platform, utils};
  10. use crate::exchange_test::{test_new_exchange};
  11. const SYMBOL: &str = "BLZ_USDT";
  12. // 测试获取Exchange实体
  13. #[tokio::test]
  14. #[instrument(level = "TRACE")]
  15. async fn test_get_self_exchange() {
  16. global::log_utils::init_log_with_trace();
  17. let kucoin_spot_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::KucoinSpot, SYMBOL).await;
  18. let kucoin_get_self_exchange = kucoin_spot_exchange.get_self_exchange();
  19. trace!(?kucoin_get_self_exchange);
  20. }
  21. // 测试获取交易对信息
  22. #[tokio::test]
  23. #[instrument(level = "TRACE")]
  24. async fn test_get_self_symbol() {
  25. global::log_utils::init_log_with_trace();
  26. let kucoin_spot_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::KucoinSpot, SYMBOL).await;
  27. let kucoin_get_self_symbol = kucoin_spot_exchange.get_self_symbol();
  28. trace!(?kucoin_get_self_symbol);
  29. }
  30. // 测试获取是否使用高速通道
  31. #[tokio::test]
  32. #[instrument(level = "TRACE")]
  33. async fn test_get_self_is_colo() {
  34. global::log_utils::init_log_with_trace();
  35. let kucoin_spot_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::KucoinSpot, SYMBOL).await;
  36. let kucoin_get_self_is_colo = kucoin_spot_exchange.get_self_is_colo();
  37. trace!(?kucoin_get_self_is_colo);
  38. }
  39. // 测试获取登录params信息
  40. #[tokio::test]
  41. #[instrument(level = "TRACE")]
  42. async fn test_get_self_params() {
  43. global::log_utils::init_log_with_trace();
  44. let kucoin_spot_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::KucoinSpot, SYMBOL).await;
  45. let kucoin_get_self_params = kucoin_spot_exchange.get_self_params();
  46. trace!("kucoin_get_self_params={:?}",kucoin_get_self_params);
  47. }
  48. // 测试获取Market信息
  49. #[tokio::test]
  50. #[instrument(level = "TRACE")]
  51. async fn test_get_self_market() {
  52. global::log_utils::init_log_with_trace();
  53. let kucoin_spot_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::KucoinSpot, SYMBOL).await;
  54. let kucoin_get_self_market = kucoin_spot_exchange.get_self_market();
  55. trace!(?kucoin_get_self_market);
  56. }
  57. // 测试获取请求时间信息
  58. #[tokio::test]
  59. #[instrument(level = "TRACE")]
  60. async fn test_get_request_delays() {
  61. global::log_utils::init_log_with_trace();
  62. let kucoin_spot_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::KucoinSpot, SYMBOL).await;
  63. let kucoin_get_request_delays = kucoin_spot_exchange.get_request_delays();
  64. trace!(?kucoin_get_request_delays);
  65. }
  66. // 测试获取请求平均时间信息
  67. #[tokio::test]
  68. #[instrument(level = "TRACE")]
  69. async fn test_get_request_avg_delay() {
  70. global::log_utils::init_log_with_trace();
  71. let kucoin_spot_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::KucoinSpot, SYMBOL).await;
  72. let kucoin_get_request_avg_delay = kucoin_spot_exchange.get_request_avg_delay();
  73. trace!(?kucoin_get_request_avg_delay);
  74. }
  75. // 测试获取最大请求时间信息
  76. #[tokio::test]
  77. #[instrument(level = "TRACE")]
  78. async fn test_get_request_max_delay() {
  79. global::log_utils::init_log_with_trace();
  80. let kucoin_spot_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::KucoinSpot, SYMBOL).await;
  81. let kucoin_get_request_max_delay = kucoin_spot_exchange.get_request_max_delay();
  82. trace!(?kucoin_get_request_max_delay);
  83. }
  84. // 测试获取服务器时间
  85. #[tokio::test]
  86. #[instrument(level = "TRACE")]
  87. async fn test_get_server_time() {
  88. global::log_utils::init_log_with_trace();
  89. let mut kucoin_spot_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::KucoinSpot, SYMBOL).await;
  90. let kucoin_get_server_time = kucoin_spot_exchange.get_server_time().await;
  91. trace!(?kucoin_get_server_time);
  92. }
  93. // 测试获取账号信息
  94. #[tokio::test]
  95. #[instrument(level = "TRACE")]
  96. async fn test_get_account() {
  97. global::log_utils::init_log_with_trace();
  98. let mut kucoin_spot_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::KucoinSpot, SYMBOL).await;
  99. let kucoin_get_account = kucoin_spot_exchange.get_account().await;
  100. trace!(?kucoin_get_account);
  101. }
  102. // 测试获取Ticker信息
  103. #[tokio::test]
  104. #[instrument(level = "TRACE")]
  105. async fn test_get_ticker() {
  106. global::log_utils::init_log_with_trace();
  107. let mut kucoin_spot_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::KucoinSpot, SYMBOL).await;
  108. let kucoin_get_ticker = kucoin_spot_exchange.get_ticker().await;
  109. trace!(?kucoin_get_ticker);
  110. }
  111. // 测试获取Market信息
  112. #[tokio::test]
  113. #[instrument(level = "TRACE")]
  114. async fn test_get_market() {
  115. global::log_utils::init_log_with_trace();
  116. let mut kucoin_spot_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::KucoinSpot, SYMBOL).await;
  117. let kucoin_get_market = kucoin_spot_exchange.get_market().await;
  118. trace!(?kucoin_get_market);
  119. }