binance_swap_test.rs 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243
  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 = "";
  12. const SECRET_KEY: &str = "";
  13. //ws-订阅公共频道信息
  14. #[tokio::test(flavor = "multi_thread", worker_threads = 8)]
  15. async fn ws_custom_subscribe() {
  16. global::log_utils::init_log_with_trace();
  17. let (write_tx, write_rx) = futures_channel::mpsc::unbounded();
  18. let (read_tx, mut read_rx) = futures_channel::mpsc::unbounded::<ResponseData>();
  19. // let (write_tx, write_rx) = tokio::sync::broadcast::channel::<Message>(10);
  20. // let (read_tx, mut read_rx) = tokio::sync::broadcast::channel::<ResponseData>(10);
  21. let mut ws = get_ws(None);
  22. ws.set_symbols(vec!["BTC_USDT".to_string()]);
  23. ws.set_subscribe(vec![
  24. BinanceSwapSubscribeType::PuBookTicker,
  25. // BinanceSwapSubscribeType::PuAggTrade,
  26. // BinanceSwapSubscribeType::PuDepth20levels100ms,
  27. ]);
  28. let write_tx_am = Arc::new(Mutex::new(write_tx));
  29. let bool_v1 = Arc::new(AtomicBool::new(true));
  30. //读取
  31. let _bool_v1_clone = Arc::clone(&bool_v1);
  32. let _tr = tokio::spawn(async move {
  33. trace!("线程-数据读取-开启");
  34. let mut max_delay = 0i64;
  35. loop {
  36. // 从通道中接收并丢弃所有的消息,直到通道为空
  37. while let Ok(Some(data)) = read_rx.try_next() {
  38. // 消息被忽略
  39. let mut trace_stack = TraceStack::default();
  40. trace_stack.on_before_unlock_quant();
  41. trace_stack.on_after_network(data.time);
  42. if data.time != 0 {
  43. let delay = trace_stack.before_unlock_quant - trace_stack.after_network;
  44. max_delay = max(max_delay, delay);
  45. info!("{}us, max={}us", delay, max_delay);
  46. }
  47. }
  48. }
  49. // trace!("线程-数据读取-结束");
  50. });
  51. //写数据
  52. // let bool_v2_clone = Arc::clone(&bool_v1);
  53. // let write_tx_clone = Arc::clone(&write_tx_am);
  54. // let su = ws.get_subscription();
  55. // let tw = tokio::spawn(async move {
  56. // trace!("线程-数据写入-开始");
  57. // loop {
  58. // tokio::time::sleep(Duration::from_millis(20 * 1000)).await;
  59. // // let close_frame = CloseFrame {
  60. // // code: CloseCode::Normal,
  61. // // reason: Cow::Borrowed("Bye bye"),
  62. // // };
  63. // // let message = Message::Close(Some(close_frame));
  64. //
  65. //
  66. // let message = Message::Text(su.clone());
  67. // AbstractWsMode::send_subscribe(write_tx_clone.clone(), message.clone()).await;
  68. // trace!("发送指令成功");
  69. // }
  70. // trace!("线程-数据写入-结束");
  71. // });
  72. let t1 = tokio::spawn(async move {
  73. //链接
  74. let bool_v3_clone = Arc::clone(&bool_v1);
  75. ws.ws_connect_async(bool_v3_clone, &write_tx_am, write_rx, read_tx).await.expect("链接失败(内部一个心跳线程应该已经关闭了)");
  76. trace!("test 唯一线程结束--");
  77. });
  78. tokio::try_join!(t1).unwrap();
  79. trace!("当此结束");
  80. trace!("重启!");
  81. trace!("参考交易所关闭");
  82. return;
  83. //************************************
  84. //************************************
  85. //************************************
  86. //************************************
  87. //************************************
  88. //************************************
  89. //************************************
  90. //11 点31 分
  91. // let mut bool_v1 = Arc::new(AtomicBool::new(true));
  92. // //创建读写通道
  93. // let (write_tx, write_rx) = futures_channel::mpsc::unbounded();
  94. // let (read_tx, mut read_rx) = futures_channel::mpsc::unbounded();
  95. // // 封装 write_tx 到 Arc 和 Mutex
  96. // let write_tx_am = Arc::new(Mutex::new(write_tx));
  97. //
  98. // //对象
  99. // let mut ws = get_ws(None);
  100. // // 币对
  101. // ws.set_symbols(vec!["BTC_USDT".to_string()]);
  102. // //订阅
  103. // ws.set_subscribe(vec![
  104. // BinanceSwapSubscribeType::PuBookTicker,
  105. // BinanceSwapSubscribeType::PuAggTrade,
  106. // BinanceSwapSubscribeType::PuDepth20levels100ms,
  107. // ]);
  108. //
  109. //
  110. // //模拟业务场景 开启链接
  111. // let bool_v1_clone = Arc::clone(&bool_v1);
  112. // let write_tx_clone1 = Arc::clone(&write_tx_am);
  113. // let t1 = tokio::spawn(async move {
  114. // ws.ws_connect_async(bool_v1_clone, write_tx_clone1, write_rx, &read_tx).await.unwrap();
  115. // trace!("ws_connect_async 完成");
  116. // });
  117. //
  118. // //模拟业务场景 一直监听数据
  119. // let t2 = tokio::spawn(async move {
  120. // loop {
  121. // if let Some(data) = read_rx.next().await {
  122. // trace!("读取数据data:{:?}",data)
  123. // }
  124. // }
  125. // trace!("数据读取退出 完成");
  126. // });
  127. //
  128. //
  129. // //模拟用户主动写入数据
  130. // // let write_tx_clone2 = Arc::clone(&write_tx_am);
  131. // // let t3 = tokio::spawn(async move {
  132. // // //模拟心跳
  133. // // loop {
  134. // // tokio::time::sleep(Duration::from_millis(5000)).await;
  135. // // let mut write_tx_clone = write_tx_clone2.lock().unwrap();
  136. // // match write_tx_clone.unbounded_send(Message::Pong(Vec::from("pong"))) {
  137. // // Ok(_) => {
  138. // // trace!("发送心跳");
  139. // // continue;
  140. // // }
  141. // // Err(_) => {
  142. // // break;
  143. // // }
  144. // // }
  145. // // }
  146. // // trace!("主动推出 完成");
  147. // // });
  148. // // tokio::try_join!(y,y1,y2).unwrap();
  149. // tokio::try_join!(t1,t2).unwrap();
  150. // trace!("323123213");
  151. }
  152. //rest-获取服务器时间
  153. #[tokio::test]
  154. async fn rest_get_server_time_test() {
  155. global::log_utils::init_log_with_trace();
  156. let mut rest = get_rest();
  157. let rep_data = rest.get_server_time().await;
  158. trace!(?rep_data)
  159. }
  160. //rest-获取交易规则和交易对
  161. #[tokio::test]
  162. async fn rest_get_exchange_info_test() {
  163. global::log_utils::init_log_with_trace();
  164. let mut rest = get_rest();
  165. let rep_data = rest.get_exchange_info().await;
  166. trace!(?rep_data)
  167. }
  168. //rest-账户信息
  169. #[tokio::test]
  170. async fn rest_get_account_test() {
  171. global::log_utils::init_log_with_trace();
  172. let mut rest = get_rest();
  173. let rep_data = rest.get_account().await;
  174. trace!(?rep_data)
  175. }
  176. //rest-根据币对 撤销全部订单
  177. #[tokio::test(flavor = "multi_thread", worker_threads = 2)]
  178. async fn rest_cancel_order_all_test() {
  179. global::log_utils::init_log_with_trace();
  180. let mut rest = get_rest();
  181. let rep_data1 = rest.get_server_time().await;
  182. trace!(?rep_data1);
  183. trace!("开始时间:{:?}",chrono::Utc::now().timestamp_millis().to_string());
  184. let rep_data = rest.cancel_order_all("BTCUSDT".to_string()).await;
  185. trace!(?rep_data);
  186. trace!("结束时间:{:?}",chrono::Utc::now().timestamp_millis().to_string());
  187. }
  188. //rest-账户成交历史
  189. #[tokio::test]
  190. async fn rest_get_user_trades_test() {
  191. global::log_utils::init_log_with_trace();
  192. let mut rest = get_rest();
  193. let rep_data = rest.get_user_trades("BTCUSDT".to_string(), -1, -1, 500).await;
  194. trace!(?rep_data)
  195. }
  196. fn get_ws(btree_map: Option<BinanceSwapLogin>) -> BinanceSwapWs {
  197. let binance_ws = BinanceSwapWs::new(false,
  198. btree_map,
  199. BinanceSwapWsType::PublicAndPrivate);
  200. binance_ws
  201. }
  202. fn get_rest() -> BinanceSwapRest {
  203. let mut btree_map: BTreeMap<String, String> = BTreeMap::new();
  204. btree_map.insert("access_key".to_string(), ACCESS_KEY.to_string());
  205. btree_map.insert("secret_key".to_string(), SECRET_KEY.to_string());
  206. let ba_exc = BinanceSwapRest::new(false, btree_map);
  207. ba_exc
  208. }