// use std::cmp::max; // use std::collections::BTreeMap; // use std::sync::Arc; // use std::sync::atomic::AtomicBool; // // use tokio::sync::Mutex; // use tracing::{info, trace}; // // use exchanges::binance_swap_rest::BinanceSwapRest; // use exchanges::binance_swap_ws::{BinanceSwapLogin, BinanceSwapSubscribeType, BinanceSwapWs, BinanceSwapWsType}; // use exchanges::response_base::ResponseData; // use global::trace_stack::TraceStack; // // const ACCESS_KEY: &str = ""; // const SECRET_KEY: &str = ""; // // // //ws-订阅公共频道信息 // #[tokio::test(flavor = "multi_thread", worker_threads = 2)] // async fn ws_custom_subscribe() { // global::log_utils::init_log_with_trace(); // // // let (write_tx, write_rx) = futures_channel::mpsc::unbounded(); // let (read_tx, mut read_rx) = futures_channel::mpsc::unbounded::(); // // // let (write_tx, write_rx) = tokio::sync::broadcast::channel::(10); // // let (read_tx, mut read_rx) = tokio::sync::broadcast::channel::(10); // // // let mut ws = get_ws(None); // ws.set_symbols(vec!["BTC_USDT".to_string()]); // ws.set_subscribe(vec![ // BinanceSwapSubscribeType::PuBookTicker, // // BinanceSwapSubscribeType::PuAggTrade, // // BinanceSwapSubscribeType::PuDepth20levels100ms, // ]); // // // let write_tx_am = Arc::new(Mutex::new(write_tx)); // let is_shutdown_arc = Arc::new(AtomicBool::new(true)); // // //读取 // let _is_shutdown_arc_clone = Arc::clone(&is_shutdown_arc); // let _tr = tokio::spawn(async move { // trace!("线程-数据读取-开启"); // let mut max_delay = 0i64; // loop { // // 从通道中接收并丢弃所有的消息,直到通道为空 // while let Ok(Some(data)) = read_rx.try_next() { // // 消息被忽略 // let mut trace_stack = TraceStack::new(0, Instant::now()); // trace_stack.on_before_unlock_core(); // trace_stack.on_after_network(data.time); // // let delay = trace_stack.before_unlock_core - trace_stack.after_network; // max_delay = max(max_delay, delay); // info!("{}us, max={}us", delay, max_delay); // // // 从通道中接收并丢弃所有的消息,直到通道为空 // while let Ok(Some(_)) = read_rx.try_next() { // // 消息被忽略 // } // } // } // // trace!("线程-数据读取-结束"); // }); // // //写数据 // // let bool_v2_clone = Arc::clone(&is_shutdown_arc); // // let write_tx_clone = Arc::clone(&write_tx_am); // // let su = ws.get_subscription(); // // let tw = tokio::spawn(async move { // // trace!("线程-数据写入-开始"); // // loop { // // tokio::time::sleep(Duration::from_millis(20 * 1000)).await; // // // let close_frame = CloseFrame { // // // code: CloseCode::Normal, // // // reason: Cow::Borrowed("Bye bye"), // // // }; // // // let message = Message::Close(Some(close_frame)); // // // // // // let message = Message::Text(su.clone()); // // AbstractWsMode::send_subscribe(write_tx_clone.clone(), message.clone()).await; // // trace!("发送指令成功"); // // } // // trace!("线程-数据写入-结束"); // // }); // // let t1 = tokio::spawn(async move { // //链接 // let bool_v3_clone = Arc::clone(&is_shutdown_arc); // ws.ws_connect_async(bool_v3_clone, &write_tx_am, write_rx, read_tx).await.expect("链接失败(内部一个心跳线程应该已经关闭了)"); // trace!("test 唯一线程结束--"); // }); // tokio::try_join!(t1).unwrap(); // trace!("当此结束"); // trace!("重启!"); // trace!("参考交易所关闭"); // return; // // //************************************ // //************************************ // //************************************ // //************************************ // //************************************ // //************************************ // //************************************ // //11 点31 分 // // // let mut is_shutdown_arc = Arc::new(AtomicBool::new(true)); // // //创建读写通道 // // let (write_tx, write_rx) = futures_channel::mpsc::unbounded(); // // let (read_tx, mut read_rx) = futures_channel::mpsc::unbounded(); // // // 封装 write_tx 到 Arc 和 Mutex // // let write_tx_am = Arc::new(Mutex::new(write_tx)); // // // // //对象 // // let mut ws = get_ws(None); // // // 币对 // // ws.set_symbols(vec!["BTC_USDT".to_string()]); // // //订阅 // // ws.set_subscribe(vec![ // // BinanceSwapSubscribeType::PuBookTicker, // // BinanceSwapSubscribeType::PuAggTrade, // // BinanceSwapSubscribeType::PuDepth20levels100ms, // // ]); // // // // // // //模拟业务场景 开启链接 // // let is_shutdown_arc_clone = Arc::clone(&is_shutdown_arc); // // let write_tx_clone1 = Arc::clone(&write_tx_am); // // let t1 = tokio::spawn(async move { // // ws.ws_connect_async(is_shutdown_arc_clone, write_tx_clone1, write_rx, &read_tx).await.unwrap(); // // trace!("ws_connect_async 完成"); // // }); // // // // //模拟业务场景 一直监听数据 // // let t2 = tokio::spawn(async move { // // loop { // // if let Some(data) = read_rx.next().await { // // trace!("读取数据data:{:?}",data) // // } // // } // // trace!("数据读取退出 完成"); // // }); // // // // // // //模拟用户主动写入数据 // // // let write_tx_clone2 = Arc::clone(&write_tx_am); // // // let t3 = tokio::spawn(async move { // // // //模拟心跳 // // // loop { // // // tokio::time::sleep(Duration::from_millis(5000)).await; // // // let mut write_tx_clone = write_tx_clone2.lock().unwrap(); // // // match write_tx_clone.unbounded_send(Message::Pong(Vec::from("pong"))) { // // // Ok(_) => { // // // trace!("发送心跳"); // // // continue; // // // } // // // Err(_) => { // // // break; // // // } // // // } // // // } // // // trace!("主动推出 完成"); // // // }); // // // tokio::try_join!(y,y1,y2).unwrap(); // // tokio::try_join!(t1,t2).unwrap(); // // trace!("323123213"); // } // // //rest-获取服务器时间 // #[tokio::test] // async fn rest_get_server_time_test() { // global::log_utils::init_log_with_trace(); // // let mut rest = get_rest(); // let rep_data = rest.get_server_time().await; // trace!(?rep_data) // } // // //rest-获取交易规则和交易对 // #[tokio::test] // async fn rest_get_exchange_info_test() { // global::log_utils::init_log_with_trace(); // // let mut rest = get_rest(); // let rep_data = rest.get_exchange_info().await; // trace!(?rep_data) // } // // //rest-账户信息 // #[tokio::test] // async fn rest_get_account_test() { // global::log_utils::init_log_with_trace(); // // let mut rest = get_rest(); // let rep_data = rest.get_account().await; // trace!(?rep_data) // } // // // //rest-根据币对 撤销全部订单 // #[tokio::test(flavor = "multi_thread", worker_threads = 2)] // async fn rest_cancel_order_all_test() { // global::log_utils::init_log_with_trace(); // // let mut rest = get_rest(); // // let rep_data1 = rest.get_server_time().await; // trace!(?rep_data1); // // trace!("开始时间:{:?}",chrono::Utc::now().timestamp_millis().to_string()); // let rep_data = rest.cancel_order_all("BTCUSDT".to_string()).await; // trace!(?rep_data); // trace!("结束时间:{:?}",chrono::Utc::now().timestamp_millis().to_string()); // } // // //rest-账户成交历史 // #[tokio::test] // async fn rest_get_user_trades_test() { // global::log_utils::init_log_with_trace(); // // let mut rest = get_rest(); // let rep_data = rest.get_user_trades("BTCUSDT".to_string(), -1, -1, 500).await; // trace!(?rep_data) // } // // // fn get_ws(btree_map: Option) -> BinanceSwapWs { // let binance_ws = BinanceSwapWs::new(false, // btree_map, // BinanceSwapWsType::PublicAndPrivate); // binance_ws // } // // fn get_rest() -> BinanceSwapRest { // let mut btree_map: BTreeMap = BTreeMap::new(); // btree_map.insert("access_key".to_string(), ACCESS_KEY.to_string()); // btree_map.insert("secret_key".to_string(), SECRET_KEY.to_string()); // // let ba_exc = BinanceSwapRest::new(false, btree_map); // ba_exc // }