| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314 |
- use std::collections::BTreeMap;
- use std::sync::Arc;
- use std::sync::atomic::AtomicBool;
- use serde_json::json;
- use tokio::sync::Mutex;
- use tracing::trace;
- use exchanges::htx_swap_rest::HtxSwapRest;
- use exchanges::htx_swap_ws::{HtxSwapLogin, HtxSwapSubscribeType, HtxSwapWs, HtxSwapWsType};
- use exchanges::proxy;
- use exchanges::response_base::ResponseData;
- 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 (_, mut read_rx) = futures_channel::mpsc::unbounded::<ResponseData>();
- // let (write_tx, write_rx) = tokio::sync::broadcast::channel::<Message>(10);
- // let (read_tx, mut read_rx) = tokio::sync::broadcast::channel::<ResponseData>(10);
- 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!("线程-数据读取-开启");
- loop {
- // 从通道中接收并丢弃所有的消息,直到通道为空
- while let Ok(Some(_)) = read_rx.try_next() {
- // 从通道中接收并丢弃所有的消息,直到通道为空
- 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 fun = move |data: ResponseData| {
- async move {
- trace!("---传入的方法~~~~{:?}", data);
- }
- };
- let param = HtxSwapLogin {
- api_key: ACCESS_KEY.to_string(),
- secret: SECRET_KEY.to_string(),
- };
- let t1 = tokio::spawn(async move {
- let mut ws = get_ws(Option::from(param), HtxSwapWsType::Private);
- ws.set_symbols(vec!["BTC_USDT".to_string()]);
- ws.set_subscribe(vec![
- // HtxSwapSubscribeType::PuFuturesDepth,
- // HtxSwapSubscribeType::PrFuturesOrders
- HtxSwapSubscribeType::PrFuturesOrders,
- HtxSwapSubscribeType::PrFuturesPositions,
- HtxSwapSubscribeType::PrFuturesBalances,
- ]);
- //链接
- let bool_v3_clone = Arc::clone(&is_shutdown_arc);
- ws.ws_connect_async(bool_v3_clone, fun, &write_tx_am, write_rx).await.expect("链接失败(内部一个心跳线程应该已经关闭了)");
- trace!("test 唯一线程结束--");
- });
- tokio::try_join!(t1).unwrap();
- trace!("当此结束");
- trace!("重启!");
- trace!("参考交易所关闭");
- return;
- }
- fn get_ws(btree_map: Option<HtxSwapLogin>, ws_type: HtxSwapWsType) -> HtxSwapWs {
- let htx_ws = HtxSwapWs::new(btree_map, ws_type);
- htx_ws
- }
- /*服务器时间戳*/
- #[tokio::test]
- async fn rest_get_server_time_test() {
- global::log_utils::init_log_with_trace();
- proxy_handle();
- let mut ret = get_rest();
- let req_data = ret.get_server_time().await;
- trace!("htx--服务器时间戳--{:?}", req_data);
- trace!("htx--服务器时间戳--{}", req_data.data);
- }
- /*获取聚合行情*/
- #[tokio::test]
- async fn rest_get_ticker_test() {
- global::log_utils::init_log_with_trace();
- proxy_handle();
- let mut ret = get_rest();
- let req_data = ret.get_ticker(json!({
- "contract_type":"swap"
- })
- ).await;
- trace!("htx--获取聚合行情--{:?}", req_data);
- trace!("htx--获取聚合行情--{}", req_data.data);
- }
- /*合约信息*/
- #[tokio::test]
- async fn rest_get_market_test() {
- global::log_utils::init_log_with_trace();
- proxy_handle();
- let mut ret = get_rest();
- let req_data = ret.get_market(json!({
- "contract_code":"BTC-USDT"
- })
- ).await;
- trace!("htx--合约信息--{:?}", req_data);
- trace!("htx--合约信息--{}", req_data.data);
- }
- /*查询合约账户*/
- #[tokio::test]
- async fn rest_get_account_test() {
- global::log_utils::init_log_with_trace();
- // proxy_handle();
- let mut ret = get_rest();
- let req_data = ret.get_account(json!({
- "valuation_asset":"USDT"
- })
- ).await;
- trace!("htx--查询合约账户--{:?}", req_data);
- trace!("htx--查询合约账户--{}", req_data.data);
- }
- /*用户仓位列表*/
- #[tokio::test]
- async fn rest_get_user_position_test() {
- global::log_utils::init_log_with_trace();
- // proxy_handle();
- let mut ret = get_rest();
- let req_data = ret.get_user_position(
- serde_json::json!({
- "contract_type":"swap"
- })
- ).await;
- trace!("htx--用户仓位列表--{:?}", req_data);
- trace!("htx--用户仓位列表--{}", req_data.data);
- }
- /*查询合约订单列表*/
- #[tokio::test]
- async fn rest_get_orders_test() {
- global::log_utils::init_log_with_trace();
- // proxy_handle();
- let mut ret = get_rest();
- let req_data = ret.get_orders(json!({
- })).await;
- trace!("htx--查询合约订单列表--{:?}", req_data);
- trace!("htx--查询合约订单列表--{}", req_data.data);
- }
- /*查询单个订单详情*/
- #[tokio::test]
- async fn rest_get_order_details_test() {
- global::log_utils::init_log_with_trace();
- // proxy_handle();
- let mut ret = get_rest();
- let req_data = ret.get_order_details(json!({
- "order_id":"123"
- })).await;
- trace!("htx--查询单个订单详情--{:?}", req_data);
- trace!("htx--查询单个订单详情--{}", req_data.data);
- }
- /*合约交易下单*/
- #[tokio::test]
- async fn rest_swap_order_test() {
- global::log_utils::init_log_with_trace();
- // proxy_handle();
- let mut ret = get_rest();
- let req_data = ret.swap_order(json!({
- "pair":"SHIB-USDT",
- "contract_type":"swap",
- "order_price_type":"limit",
- "offset":"open",
- "direction":"buy",
- "price":"0.000001359",
- "volume":1,
- "lever_rate":1,
- })).await;
- trace!("htx--合约交易下单--{:?}", req_data);
- trace!("htx--合约交易下单--{}", req_data.data);
- }
- /*全部撤单*/
- #[tokio::test]
- async fn rest_cancel_price_order_test() {
- global::log_utils::init_log_with_trace();
- // proxy_handle();
- let mut ret = get_rest();
- let req_data = ret.cancel_price_order(json!({ })).await;
- trace!("htx--全部撤单--{:?}", req_data);
- trace!("htx--全部撤单--{}", req_data.data);
- }
- /*撤单*/
- #[tokio::test]
- async fn rest_cancel_order_test() {
- global::log_utils::init_log_with_trace();
- // proxy_handle();
- let mut ret = get_rest();
- let req_data = ret.cancel_order(json!({
- "order_id":"123"
- })).await;
- trace!("htx--撤单--{:?}", req_data);
- trace!("htx--撤单--{}", req_data.data);
- }
- /*设置持仓模式*/
- #[tokio::test]
- async fn rest_setting_dual_mode_test() {
- global::log_utils::init_log_with_trace();
- // proxy_handle();
- let mut ret = get_rest();
- let req_data = ret.setting_dual_mode(json!({
- "margin_account":"USDT",
- "position_mode":"dual_side",
- })).await;
- trace!("htx--设置持仓模式--{:?}", req_data);
- trace!("htx--设置持仓模式--{}", req_data.data);
- }
- /*设置杠杆*/
- #[tokio::test]
- async fn rest_setting_dual_leverage_test() {
- global::log_utils::init_log_with_trace();
- // proxy_handle();
- let mut ret = get_rest();
- let req_data = ret.setting_dual_leverage(json!({
- "pair":"BTC-USDT",
- "contract_type":"swap",
- "lever_rate":1,
- })).await;
- trace!("htx--设置持仓模式--{:?}", req_data);
- trace!("htx--设置持仓模式--{}", req_data.data);
- }
- fn get_rest() -> HtxSwapRest {
- let mut btree_map: BTreeMap<String, String> = 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 htx_exc = HtxSwapRest::new(false, btree_map);
- htx_exc
- }
- // 检测是否走代理
- pub fn proxy_handle() {
- if proxy::ParsingDetail::http_enable_proxy() {
- trace!("检测有代理配置,配置走代理");
- }
- }
|