binance_swap_test.rs 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. use std::cmp::max;
  2. use std::collections::BTreeMap;
  3. use std::sync::Arc;
  4. use std::sync::atomic::AtomicBool;
  5. use tokio::sync::Mutex;
  6. use tracing::{info, trace};
  7. use exchanges::binance_swap_rest::BinanceSwapRest;
  8. use exchanges::binance_swap_ws::{BinanceSwapLogin, BinanceSwapSubscribeType, BinanceSwapWs, BinanceSwapWsType};
  9. use exchanges::response_base::ResponseData;
  10. use global::trace_stack::TraceStack;
  11. const ACCESS_KEY: &str = "rgKH05A1QOpXj4NDKuIb8edOLPPpF0gYu8WBpiAIqG4aCwHsytjFWiOtoWYUPB7R";
  12. const SECRET_KEY: &str = "14573tSKmHLyV5WO7L31hNK0HZ21yiyMqWg85POvrKDyOn2i9bZKNTlPBUqR3fpm";
  13. //ws-订阅公共频道信息
  14. #[tokio::test(flavor = "multi_thread", worker_threads = 2)]
  15. async fn ws_custom_subscribe() {
  16. global::log_utils::init_log_with_trace();
  17. //
  18. //
  19. // let (write_tx, write_rx) = futures_channel::mpsc::unbounded();
  20. // let (read_tx, mut read_rx) = futures_channel::mpsc::unbounded::<ResponseData>();
  21. //
  22. // // let (write_tx, write_rx) = tokio::sync::broadcast::channel::<Message>(10);
  23. // // let (read_tx, mut read_rx) = tokio::sync::broadcast::channel::<ResponseData>(10);
  24. //
  25. //
  26. // let mut ws = get_ws(None);
  27. // ws.set_symbols(vec!["BTC_USDT".to_string()]);
  28. // ws.set_subscribe(vec![
  29. // BinanceSwapSubscribeType::PuBookTicker,
  30. // // BinanceSwapSubscribeType::PuAggTrade,
  31. // // BinanceSwapSubscribeType::PuDepth20levels100ms,
  32. // ]);
  33. //
  34. //
  35. // let write_tx_am = Arc::new(Mutex::new(write_tx));
  36. // let is_shutdown_arc = Arc::new(AtomicBool::new(true));
  37. //
  38. // //读取
  39. // let _is_shutdown_arc_clone = Arc::clone(&is_shutdown_arc);
  40. // let _tr = tokio::spawn(async move {
  41. // trace!("线程-数据读取-开启");
  42. // let mut max_delay = 0i64;
  43. // loop {
  44. // // 从通道中接收并丢弃所有的消息,直到通道为空
  45. // while let Ok(Some(data)) = read_rx.try_next() {
  46. // // 消息被忽略
  47. // let mut trace_stack = TraceStack::new(0, Instant::now());
  48. // trace_stack.on_before_unlock_core();
  49. // trace_stack.on_after_network(data.time);
  50. //
  51. // let delay = trace_stack.before_unlock_core - trace_stack.after_network;
  52. // max_delay = max(max_delay, delay);
  53. // info!("{}us, max={}us", delay, max_delay);
  54. //
  55. // // 从通道中接收并丢弃所有的消息,直到通道为空
  56. // while let Ok(Some(_)) = read_rx.try_next() {
  57. // // 消息被忽略
  58. // }
  59. // }
  60. // }
  61. // // trace!("线程-数据读取-结束");
  62. // });
  63. //
  64. // //写数据
  65. // // let bool_v2_clone = Arc::clone(&is_shutdown_arc);
  66. // // let write_tx_clone = Arc::clone(&write_tx_am);
  67. // // let su = ws.get_subscription();
  68. // // let tw = tokio::spawn(async move {
  69. // // trace!("线程-数据写入-开始");
  70. // // loop {
  71. // // tokio::time::sleep(Duration::from_millis(20 * 1000)).await;
  72. // // // let close_frame = CloseFrame {
  73. // // // code: CloseCode::Normal,
  74. // // // reason: Cow::Borrowed("Bye bye"),
  75. // // // };
  76. // // // let message = Message::Close(Some(close_frame));
  77. // //
  78. // //
  79. // // let message = Message::Text(su.clone());
  80. // // AbstractWsMode::send_subscribe(write_tx_clone.clone(), message.clone()).await;
  81. // // trace!("发送指令成功");
  82. // // }
  83. // // trace!("线程-数据写入-结束");
  84. // // });
  85. //
  86. // let t1 = tokio::spawn(async move {
  87. // //链接
  88. // let bool_v3_clone = Arc::clone(&is_shutdown_arc);
  89. // ws.ws_connect_async(bool_v3_clone, &write_tx_am, write_rx, read_tx).await.expect("链接失败(内部一个心跳线程应该已经关闭了)");
  90. // trace!("test 唯一线程结束--");
  91. // });
  92. // tokio::try_join!(t1).unwrap();
  93. // trace!("当此结束");
  94. // trace!("重启!");
  95. // trace!("参考交易所关闭");
  96. // return;
  97. //
  98. }
  99. //rest-获取服务器时间
  100. #[tokio::test]
  101. async fn rest_get_server_time_test() {
  102. global::log_utils::init_log_with_trace();
  103. let mut rest = get_rest();
  104. let rep_data = rest.get_server_time().await;
  105. trace!(?rep_data)
  106. }
  107. //rest-获取交易规则和交易对
  108. #[tokio::test]
  109. async fn rest_get_exchange_info_test() {
  110. global::log_utils::init_log_with_trace();
  111. let mut rest = get_rest();
  112. let rep_data = rest.get_exchange_info().await;
  113. trace!(?rep_data)
  114. }
  115. //rest-账户信息
  116. #[tokio::test]
  117. async fn rest_get_account_test() {
  118. global::log_utils::init_log_with_trace();
  119. let mut rest = get_rest();
  120. let rep_data = rest.get_account().await;
  121. trace!(?rep_data)
  122. }
  123. //rest-根据币对 撤销全部订单
  124. #[tokio::test(flavor = "multi_thread", worker_threads = 2)]
  125. async fn rest_cancel_order_all_test() {
  126. global::log_utils::init_log_with_trace();
  127. let mut rest = get_rest();
  128. let rep_data1 = rest.get_server_time().await;
  129. trace!(?rep_data1);
  130. trace!("开始时间:{:?}",chrono::Utc::now().timestamp_millis().to_string());
  131. let rep_data = rest.cancel_order_all("BTCUSDT".to_string()).await;
  132. trace!(?rep_data);
  133. trace!("结束时间:{:?}",chrono::Utc::now().timestamp_millis().to_string());
  134. }
  135. //rest-账户成交历史
  136. #[tokio::test]
  137. async fn rest_get_user_trades_test() {
  138. global::log_utils::init_log_with_trace();
  139. let mut rest = get_rest();
  140. let rep_data = rest.get_user_trades("BTCUSDT".to_string(), -1, -1, 500).await;
  141. trace!(?rep_data)
  142. }
  143. fn get_ws(btree_map: Option<BinanceSwapLogin>) -> BinanceSwapWs {
  144. let binance_ws = BinanceSwapWs::new(false,
  145. btree_map,
  146. BinanceSwapWsType::PublicAndPrivate);
  147. binance_ws
  148. }
  149. fn get_rest() -> BinanceSwapRest {
  150. let mut btree_map: BTreeMap<String, String> = BTreeMap::new();
  151. btree_map.insert("access_key".to_string(), ACCESS_KEY.to_string());
  152. btree_map.insert("secret_key".to_string(), SECRET_KEY.to_string());
  153. let ba_exc = BinanceSwapRest::new(false, btree_map);
  154. ba_exc
  155. }