gate_swap_test.rs 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279
  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 gate_swap_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::GateSwap, SYMBOL).await;
  18. let gate_get_self_exchange = gate_swap_exchange.get_self_exchange();
  19. trace!(?gate_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 gate_swap_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::GateSwap, SYMBOL).await;
  27. let gate_get_self_symbol = gate_swap_exchange.get_self_symbol();
  28. trace!(?gate_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 gate_swap_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::GateSwap, SYMBOL).await;
  36. let gate_get_self_is_colo = gate_swap_exchange.get_self_is_colo();
  37. trace!(?gate_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 gate_swap_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::GateSwap, SYMBOL).await;
  45. let gate_get_self_params = gate_swap_exchange.get_self_params();
  46. trace!("gate_get_self_params={:?}",gate_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 gate_swap_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::GateSwap, SYMBOL).await;
  54. let gate_get_self_market = gate_swap_exchange.get_self_market();
  55. trace!(?gate_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 gate_swap_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::GateSwap, SYMBOL).await;
  63. let gate_get_request_delays = gate_swap_exchange.get_request_delays();
  64. trace!(?gate_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 gate_swap_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::GateSwap, SYMBOL).await;
  72. let gate_get_request_avg_delay = gate_swap_exchange.get_request_avg_delay();
  73. trace!(?gate_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 gate_swap_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::GateSwap, SYMBOL).await;
  81. let gate_get_request_max_delay = gate_swap_exchange.get_request_max_delay();
  82. trace!(?gate_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 gate_swap_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::GateSwap, SYMBOL).await;
  90. let gate_get_server_time = gate_swap_exchange.get_server_time().await;
  91. trace!(?gate_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 gate_swap_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::GateSwap, SYMBOL).await;
  99. let gate_get_account = gate_swap_exchange.get_account().await;
  100. trace!(?gate_get_account);
  101. }
  102. // 测试获取持仓信息
  103. #[tokio::test]
  104. #[instrument(level = "TRACE")]
  105. async fn test_get_position() {
  106. global::log_utils::init_log_with_trace();
  107. let mut gate_swap_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::GateSwap, SYMBOL).await;
  108. let gate_get_position = gate_swap_exchange.get_position().await;
  109. trace!(?gate_get_position);
  110. }
  111. // 测试获取所有持仓信息
  112. #[tokio::test]
  113. #[instrument(level = "TRACE")]
  114. async fn test_get_positions() {
  115. global::log_utils::init_log_with_trace();
  116. let mut gate_swap_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::GateSwap, SYMBOL).await;
  117. let gate_get_positions = gate_swap_exchange.get_positions().await;
  118. trace!(?gate_get_positions);
  119. }
  120. // 测试获取Ticker信息
  121. #[tokio::test]
  122. #[instrument(level = "TRACE")]
  123. async fn test_get_ticker() {
  124. global::log_utils::init_log_with_trace();
  125. let mut gate_swap_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::GateSwap, SYMBOL).await;
  126. let gate_get_ticker = gate_swap_exchange.get_ticker().await;
  127. trace!(?gate_get_ticker);
  128. }
  129. // 测试获取Market信息
  130. #[tokio::test]
  131. #[instrument(level = "TRACE")]
  132. async fn test_get_market() {
  133. global::log_utils::init_log_with_trace();
  134. let mut gate_swap_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::GateSwap, SYMBOL).await;
  135. let gate_get_market = gate_swap_exchange.get_market().await;
  136. trace!(?gate_get_market);
  137. }
  138. // 测试获取Order详情信息
  139. #[tokio::test]
  140. #[instrument(level = "TRACE")]
  141. async fn test_get_order_detail() {
  142. global::log_utils::init_log_with_trace();
  143. let mut gate_swap_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::GateSwap, SYMBOL).await;
  144. let gate_get_order_detail = gate_swap_exchange.get_order_detail("", "999999").await;
  145. trace!(?gate_get_order_detail);
  146. }
  147. // 测试获取Order列表信息
  148. #[tokio::test]
  149. #[instrument(level = "TRACE")]
  150. async fn test_get_orders_list() {
  151. global::log_utils::init_log_with_trace();
  152. let mut gate_swap_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::GateSwap, SYMBOL).await;
  153. let gate_get_orders_list = gate_swap_exchange.get_orders_list("finished").await;
  154. trace!(?gate_get_orders_list);
  155. }
  156. // 测试下单
  157. #[tokio::test]
  158. #[instrument(level = "TRACE")]
  159. async fn test_take_order() {
  160. global::log_utils::init_log_with_trace();
  161. let mut gate_swap_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::GateSwap, SYMBOL).await;
  162. let gate_take_order = gate_swap_exchange.take_order("999999", "kk", dec!(0.27), dec!(100)).await;
  163. trace!(?gate_take_order);
  164. }
  165. // 测试撤销订单
  166. #[tokio::test]
  167. #[instrument(level = "TRACE")]
  168. async fn test_cancel_order() {
  169. global::log_utils::init_log_with_trace();
  170. let mut gate_swap_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::GateSwap, SYMBOL).await;
  171. let gate_cancel_order = gate_swap_exchange.cancel_order("", "999999").await;
  172. trace!(?gate_cancel_order);
  173. }
  174. // 测试批量撤销订单
  175. #[tokio::test]
  176. #[instrument(level = "TRACE")]
  177. async fn test_cancel_orders() {
  178. global::log_utils::init_log_with_trace();
  179. let mut gate_swap_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::GateSwap, SYMBOL).await;
  180. let gate_cancel_orders = gate_swap_exchange.cancel_orders().await;
  181. trace!(?gate_cancel_orders);
  182. }
  183. // 测试设置持仓模式
  184. #[tokio::test]
  185. #[instrument(level = "TRACE")]
  186. async fn test_set_dual_mode() {
  187. global::log_utils::init_log_with_trace();
  188. let mut gate_swap_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::GateSwap, SYMBOL).await;
  189. let gate_set_dual_mode = gate_swap_exchange.set_dual_mode("usdt", true).await;
  190. trace!(?gate_set_dual_mode);
  191. }
  192. // 测试设置杠杆
  193. #[tokio::test]
  194. #[instrument(level = "TRACE")]
  195. async fn test_set_dual_leverage() {
  196. global::log_utils::init_log_with_trace();
  197. let mut gate_swap_exchange: Box<dyn Platform> = test_new_exchange(ExchangeEnum::GateSwap, SYMBOL).await;
  198. let gate_set_dual_leverage = gate_swap_exchange.set_dual_leverage("10").await;
  199. trace!(?gate_set_dual_leverage);
  200. }
  201. // 测试指令下单
  202. #[tokio::test]
  203. #[instrument(level = "TRACE")]
  204. async fn test_command_order() {
  205. global::log_utils::init_log_with_trace();
  206. utils::proxy_handle();
  207. let (order_sender, mut order_receiver): (mpsc::Sender<Order>, mpsc::Receiver<Order>) = mpsc::channel(1024);
  208. let (error_sender, mut error_receiver): (mpsc::Sender<Error>, mpsc::Receiver<Error>) = mpsc::channel(1024);
  209. let mut params: BTreeMap<String, String> = BTreeMap::new();
  210. let access_key = env::var("gate_access_key").unwrap_or("".to_string());
  211. let secret_key = env::var("gate_secret_key").unwrap_or("".to_string());
  212. params.insert("access_key".to_string(), access_key);
  213. params.insert("secret_key".to_string(), secret_key);
  214. let mut gate_swap_exchange: Box<dyn Platform> = Exchange::new(ExchangeEnum::GateSwap, SYMBOL.to_string(), false, params, order_sender, error_sender).await;
  215. let mut command = OrderCommand::new();
  216. command.cancel.insert("888888".to_string(), vec!["888888".to_string(), "".to_string()]);
  217. command.limits_open.insert("888888".to_string(), vec!["100".to_string(), "kd".to_string(), "0.18".to_string(), "888888".to_string()]);
  218. command.limits_close.insert("999999".to_string(), vec!["100".to_string(), "kk".to_string(), "0.25".to_string(), "999999".to_string()]);
  219. command.check.insert("888888".to_string(), vec!["999999".to_string(), "".to_string()]);
  220. gate_swap_exchange.command_order(command, Default::default()).await;
  221. loop {
  222. if let Ok(order) = order_receiver.try_recv() {
  223. trace!(?order);
  224. }
  225. if let Ok(error) = error_receiver.try_recv() {
  226. trace!(?error);
  227. }
  228. }
  229. }