okx_swap_test.rs 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414
  1. use std::collections::BTreeMap;
  2. use std::sync::Arc;
  3. use std::sync::atomic::AtomicBool;
  4. use futures_util::StreamExt;
  5. use tokio::sync::Mutex;
  6. use tracing::trace;
  7. use exchanges::okx_swap_rest::OkxSwapRest;
  8. use exchanges::okx_swap_ws::{OkxSwapLogin, OkxSwapSubscribeType, OkxSwapWs, OkxSwapWsType};
  9. const ACCESS_KEY: &str = "";
  10. const SECRET_KEY: &str = "";
  11. const PASS_KEY: &str = "";
  12. //ws-订阅公共频道信息
  13. #[tokio::test(flavor = "multi_thread", worker_threads = 5)]
  14. async fn ws_custom_subscribe_pu() {
  15. global::log_utils::init_log_with_trace();
  16. let (write_tx, write_rx) = futures_channel::mpsc::unbounded();
  17. let (read_tx, mut read_rx) = futures_channel::mpsc::unbounded();
  18. // let (write_tx, write_rx) = tokio::sync::broadcast::channel::<Message>(10);
  19. // let (read_tx, mut read_rx) = tokio::sync::broadcast::channel::<ResponseData>(10);
  20. let mut ws = get_ws(None, OkxSwapWsType::Public).await;
  21. ws.set_symbols(vec!["BTC_USDT".to_string()]);
  22. ws.set_subscribe(vec![
  23. // OkxSwapSubscribeType::PuBooks5,
  24. // OkxSwapSubscribeType::Putrades,
  25. // OkxSwapSubscribeType::PuBooks50L2tbt,
  26. OkxSwapSubscribeType::PuIndexTickers,
  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. loop {
  35. if let Some(data) = read_rx.next().await {
  36. trace!("读取数据data:{:?}",data)
  37. }
  38. }
  39. // trace!("线程-数据读取-结束");
  40. });
  41. //写数据
  42. // let bool_v2_clone = Arc::clone(&bool_v1);
  43. // let write_tx_clone = Arc::clone(&write_tx_am);
  44. // let su = ws.get_subscription();
  45. // let tw = tokio::spawn(async move {
  46. // trace!("线程-数据写入-开始");
  47. // loop {
  48. // tokio::time::sleep(Duration::from_millis(20 * 1000)).await;
  49. // // let close_frame = CloseFrame {
  50. // // code: CloseCode::Normal,
  51. // // reason: Cow::Borrowed("Bye bye"),
  52. // // };
  53. // // let message = Message::Close(Some(close_frame));
  54. //
  55. //
  56. // let message = Message::Text(su.clone());
  57. // AbstractWsMode::send_subscribe(write_tx_clone.clone(), message.clone()).await;
  58. // trace!("发送指令成功");
  59. // }
  60. // trace!("线程-数据写入-结束");
  61. // });
  62. let t1 = tokio::spawn(async move {
  63. //链接
  64. let bool_v3_clone = Arc::clone(&bool_v1);
  65. ws.ws_connect_async(bool_v3_clone, &write_tx_am, write_rx, read_tx).await.expect("链接失败(内部一个心跳线程应该已经关闭了)");
  66. trace!("test 唯一线程结束--");
  67. });
  68. tokio::try_join!(t1).unwrap();
  69. trace!("当此结束");
  70. trace!("重启!");
  71. trace!("参考交易所关闭");
  72. return;
  73. }
  74. //ws-订阅私有频道信息
  75. #[tokio::test(flavor = "multi_thread", worker_threads = 2)]
  76. async fn ws_custom_subscribe_bu() {
  77. global::log_utils::init_log_with_trace();
  78. let (write_tx, write_rx) = futures_channel::mpsc::unbounded();
  79. let (read_tx, mut read_rx) = futures_channel::mpsc::unbounded();
  80. let mut ws = get_ws(None, OkxSwapWsType::Business).await;
  81. ws.set_symbols(vec!["BTC-USD".to_string()]);
  82. ws.set_subscribe(vec![
  83. OkxSwapSubscribeType::BuIndexCandle30m,
  84. ]);
  85. let write_tx_am = Arc::new(Mutex::new(write_tx));
  86. let bool_v1 = Arc::new(AtomicBool::new(true));
  87. //读取
  88. let _bool_v1_clone = Arc::clone(&bool_v1);
  89. let _tr = tokio::spawn(async move {
  90. trace!("线程-数据读取-开启");
  91. loop {
  92. if let Some(data) = read_rx.next().await {
  93. trace!("读取数据data:{:?}",data)
  94. }
  95. }
  96. // trace!("线程-数据读取-结束");
  97. });
  98. //写数据
  99. // let bool_v2_clone = Arc::clone(&bool_v1);
  100. // let write_tx_clone = Arc::clone(&write_tx_am);
  101. // let su = ws.get_subscription();
  102. // let tw = tokio::spawn(async move {
  103. // trace!("线程-数据写入-开始");
  104. // loop {
  105. // tokio::time::sleep(Duration::from_millis(20 * 1000)).await;
  106. // // let close_frame = CloseFrame {
  107. // // code: CloseCode::Normal,
  108. // // reason: Cow::Borrowed("Bye bye"),
  109. // // };
  110. // // let message = Message::Close(Some(close_frame));
  111. //
  112. //
  113. // let message = Message::Text(su.clone());
  114. // AbstractWsMode::send_subscribe(write_tx_clone.clone(), message.clone()).await;
  115. // trace!("发送指令成功");
  116. // }
  117. // trace!("线程-数据写入-结束");
  118. // });
  119. let t1 = tokio::spawn(async move {
  120. //链接
  121. let bool_v3_clone = Arc::clone(&bool_v1);
  122. ws.ws_connect_async(bool_v3_clone, &write_tx_am, write_rx, read_tx).await.expect("链接失败(内部一个心跳线程应该已经关闭了)");
  123. trace!("test 唯一线程结束--");
  124. });
  125. tokio::try_join!(t1).unwrap();
  126. trace!("当此结束");
  127. trace!("重启!");
  128. trace!("参考交易所关闭");
  129. return;
  130. }
  131. //ws-订阅私有频道信息
  132. #[tokio::test(flavor = "multi_thread", worker_threads = 5)]
  133. async fn ws_custom_subscribe_pr() {
  134. global::log_utils::init_log_with_trace();
  135. let (write_tx, write_rx) = futures_channel::mpsc::unbounded();
  136. let (read_tx, mut read_rx) = futures_channel::mpsc::unbounded();
  137. let btree_map = OkxSwapLogin {
  138. api_key: ACCESS_KEY.to_string(),
  139. secret_key: SECRET_KEY.to_string(),
  140. passphrase: PASS_KEY.to_string(),
  141. };
  142. let mut ws = get_ws(Option::from(btree_map), OkxSwapWsType::Private).await;
  143. ws.set_symbols(vec!["BTC-USDT".to_string()]);
  144. ws.set_subscribe(vec![
  145. OkxSwapSubscribeType::PrAccount("USDT".to_string()),
  146. OkxSwapSubscribeType::PrOrders,
  147. OkxSwapSubscribeType::PrPositions,
  148. OkxSwapSubscribeType::PrBalanceAndPosition,
  149. ]);
  150. let write_tx_am = Arc::new(Mutex::new(write_tx));
  151. let bool_v1 = Arc::new(AtomicBool::new(true));
  152. //读取
  153. let _bool_v1_clone = Arc::clone(&bool_v1);
  154. let _tr = tokio::spawn(async move {
  155. trace!("线程-数据读取-开启");
  156. loop {
  157. if let Some(data) = read_rx.next().await {
  158. trace!("读取数据data:{:?}",data)
  159. }
  160. }
  161. // trace!("线程-数据读取-结束");
  162. });
  163. //写数据
  164. // let bool_v2_clone = Arc::clone(&bool_v1);
  165. // let write_tx_clone = Arc::clone(&write_tx_am);
  166. // let su = ws.get_subscription();
  167. // let tw = tokio::spawn(async move {
  168. // trace!("线程-数据写入-开始");
  169. // loop {
  170. // tokio::time::sleep(Duration::from_millis(20 * 1000)).await;
  171. // // let close_frame = CloseFrame {
  172. // // code: CloseCode::Normal,
  173. // // reason: Cow::Borrowed("Bye bye"),
  174. // // };
  175. // // let message = Message::Close(Some(close_frame));
  176. //
  177. //
  178. // let message = Message::Text(su.clone());
  179. // AbstractWsMode::send_subscribe(write_tx_clone.clone(), message.clone()).await;
  180. // trace!("发送指令成功");
  181. // }
  182. // trace!("线程-数据写入-结束");
  183. // });
  184. let t1 = tokio::spawn(async move {
  185. //链接
  186. let bool_v3_clone = Arc::clone(&bool_v1);
  187. ws.ws_connect_async(bool_v3_clone, &write_tx_am, write_rx, read_tx).await.expect("链接失败(内部一个心跳线程应该已经关闭了)");
  188. trace!("test 唯一线程结束--");
  189. });
  190. tokio::try_join!(t1).unwrap();
  191. trace!("当此结束");
  192. trace!("重启!");
  193. trace!("参考交易所关闭");
  194. return;
  195. //
  196. // let mut bool_v1 = Arc::new(AtomicBool::new(true));
  197. // let mut btree_map: BTreeMap<String, String> = BTreeMap::new();
  198. //
  199. // btree_map.insert("access_key".to_string(), ACCESS_KEY.to_string());
  200. // btree_map.insert("secret_key".to_string(), SECRET_KEY.to_string());
  201. // btree_map.insert("pass_key".to_string(), PASS_KEY.to_string());
  202. //
  203. // let (tx, mut rx) = channel(1024);
  204. // let mut ws = get_ws(btree_map, OkxWsType::Private, tx).await;
  205. // ws.set_subscribe(vec![
  206. // OkxSubscribeType::PrBalanceAndPosition,
  207. // // OkxSubscribeType::PrAccount("USDT".to_string()),
  208. // OkxSubscribeType::PrOrders,
  209. // OkxSubscribeType::PrPositions,
  210. // ]);
  211. //
  212. // let t1 = tokio::spawn(async move {
  213. // ws.custom_subscribe(bool_v1, vec!["BTC-USDT".to_string()]).await;
  214. // });
  215. //
  216. // let t2 = tokio::spawn(async move {
  217. // loop {
  218. // if let Ok(received) = rx.try_recv() {
  219. // trace!( "age: {:?}", received);
  220. // }
  221. // }
  222. // });
  223. // try_join!(t1,t2).unwrap();
  224. }
  225. //rest-订单查询
  226. #[tokio::test]
  227. async fn rest_get_order_test() {
  228. global::log_utils::init_log_with_trace();
  229. let mut ret = get_rest();
  230. let req_data = ret.get_order("BTC-USDT".to_string(), "3333".to_string(), "".to_string()).await;
  231. println!("okx--订单查询--{:?}", req_data);
  232. }
  233. //rest-未完成的订单
  234. #[tokio::test]
  235. async fn rest_get_incomplete_order_test() {
  236. global::log_utils::init_log_with_trace();
  237. let mut ret = get_rest();
  238. let req_data = ret.get_incomplete_order("BTC-USDT".to_string()).await;
  239. println!("okx--未完成的订单--{:?}", req_data);
  240. }
  241. //rest-获取系统时间
  242. #[tokio::test]
  243. async fn rest_get_server_time_test() {
  244. global::log_utils::init_log_with_trace();
  245. let mut ret = get_rest();
  246. let req_data = ret.get_server_time().await;
  247. println!("okx--获取系统时间--{:?}", req_data);
  248. }
  249. //rest-查看持仓信息
  250. #[tokio::test]
  251. async fn rest_get_positions_test() {
  252. global::log_utils::init_log_with_trace();
  253. let mut ret = get_rest();
  254. let req_data = ret.get_positions("SWA1P".to_string()).await;
  255. println!("okx--查看持仓信息--{:?}", req_data);
  256. }
  257. //rest-获取单个产品行情信息
  258. #[tokio::test]
  259. async fn rest_get_ticker_test() {
  260. global::log_utils::init_log_with_trace();
  261. let mut ret = get_rest();
  262. let req_data = ret.get_ticker("BTC-USD".to_string()).await;
  263. println!("okx--获取单个产品行情信息--{:?}", req_data);
  264. }
  265. //rest-查看账户余额
  266. #[tokio::test]
  267. async fn rest_get_balance_test() {
  268. global::log_utils::init_log_with_trace();
  269. let mut ret = get_rest();
  270. let req_data = ret.get_balance("BTC,ETH".to_string()).await;
  271. println!("okx--查看账户余额--{:?}", req_data);
  272. }
  273. //rest-获取交易产品基础信息
  274. #[tokio::test]
  275. async fn rest_get_instruments_test() {
  276. global::log_utils::init_log_with_trace();
  277. let mut ret = get_rest();
  278. let req_data = ret.get_instruments().await;
  279. println!("okx--获取交易产品基础信息--{:?}", req_data);
  280. }
  281. //rest-获取成交明细(近三天)
  282. #[tokio::test]
  283. async fn rest_get_trade_fills_test() {
  284. global::log_utils::init_log_with_trace();
  285. let mut ret = get_rest();
  286. let req_data = ret.get_trade_fills("".to_string()).await;
  287. println!("okx--获取成交明细(近三天)--{:?}", req_data);
  288. }
  289. //rest-撤单
  290. #[tokio::test]
  291. async fn rest_cancel_order_test() {
  292. global::log_utils::init_log_with_trace();
  293. let mut ret = get_rest();
  294. let req_data = ret.cancel_order("BTC-USD".to_string(), "1111".to_string(), "".to_string()).await;
  295. println!("okx--撤单--{:?}", req_data);
  296. }
  297. //rest-设置杠杆倍数
  298. #[tokio::test]
  299. async fn rest_set_leverage_test() {
  300. global::log_utils::init_log_with_trace();
  301. let mut ret = get_rest();
  302. let req_data = ret.set_leverage("BTC-USDT".to_string(), "5".to_string()).await;
  303. println!("okx--设置杠杆倍数--{:?}", req_data);
  304. }
  305. //rest-设置持仓模式
  306. #[tokio::test]
  307. async fn rest_set_position_mode_test() {
  308. global::log_utils::init_log_with_trace();
  309. let mut ret = get_rest();
  310. let req_data = ret.set_position_mode().await;
  311. println!("okx--设置持仓模式--{:?}", req_data);
  312. }
  313. //rest-获取历史订单记录(近七天)
  314. #[tokio::test]
  315. async fn rest_get_orders_history_test() {
  316. global::log_utils::init_log_with_trace();
  317. let mut ret = get_rest();
  318. let req_data = ret.get_orders_history("".to_string(),
  319. "".to_string(),
  320. "filled".to_string(),
  321. "".to_string(),
  322. "".to_string(),
  323. "".to_string(),
  324. ).await;
  325. println!("okx--获取历史订单记录--{:?}", req_data);
  326. }
  327. //rest-获取历史成交数据(近七天)
  328. #[tokio::test]
  329. async fn rest_get_trades_test() {
  330. global::log_utils::init_log_with_trace();
  331. let mut ret = get_rest();
  332. let req_data = ret.get_trades("".to_string(),
  333. "".to_string(),
  334. "".to_string(),
  335. "".to_string(),
  336. "".to_string(),
  337. "100".to_string(),
  338. ).await;
  339. println!("okx--获取历史成交数据--{:?}", req_data);
  340. }
  341. async fn get_ws(btree_map: Option<OkxSwapLogin>, type_v: OkxSwapWsType) -> OkxSwapWs {
  342. let ku_ws = OkxSwapWs::new(false, btree_map, type_v);
  343. ku_ws
  344. }
  345. fn get_rest() -> OkxSwapRest {
  346. let mut btree_map: BTreeMap<String, String> = BTreeMap::new();
  347. btree_map.insert("access_key".to_string(), ACCESS_KEY.to_string());
  348. btree_map.insert("secret_key".to_string(), SECRET_KEY.to_string());
  349. btree_map.insert("pass_key".to_string(), PASS_KEY.to_string());
  350. let okx_exc = OkxSwapRest::new(false, btree_map.clone());
  351. okx_exc
  352. }