From d76ed8abc8f31e210f4e93f173f41bc2861870dd Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Tue, 06 Apr 2021 15:37:49 +0800
Subject: [PATCH] 20210406  交易员列表查询

---
 src/test/java/com/xcong/excoin/WholeTest.java |  116 +++++++++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 111 insertions(+), 5 deletions(-)

diff --git a/src/test/java/com/xcong/excoin/WholeTest.java b/src/test/java/com/xcong/excoin/WholeTest.java
index 899aaf4..1123b19 100644
--- a/src/test/java/com/xcong/excoin/WholeTest.java
+++ b/src/test/java/com/xcong/excoin/WholeTest.java
@@ -1,5 +1,6 @@
 package com.xcong.excoin;
 
+import cn.hutool.core.collection.CollUtil;
 import com.alibaba.fastjson.JSONObject;
 import com.xcong.excoin.common.contants.AppContants;
 import com.xcong.excoin.common.enumerates.CoinTypeEnum;
@@ -12,9 +13,13 @@
 import com.xcong.excoin.modules.member.entity.MemberEntity;
 import com.xcong.excoin.modules.member.entity.MemberWalletContractEntity;
 import com.xcong.excoin.rabbit.pricequeue.OrderModel;
+import com.xcong.excoin.rabbit.pricequeue.OrderOperatePriceService;
+import com.xcong.excoin.rabbit.pricequeue.WebsocketPriceService;
 import com.xcong.excoin.rabbit.producer.OrderProducer;
 import com.xcong.excoin.utils.CalculateUtil;
+import com.xcong.excoin.utils.RedisUtils;
 import com.xcong.excoin.utils.ThreadPoolUtils;
+import lombok.SneakyThrows;
 import org.junit.jupiter.api.Test;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.boot.test.context.SpringBootTest;
@@ -22,7 +27,10 @@
 import javax.annotation.Resource;
 import java.math.BigDecimal;
 import java.util.ArrayList;
+import java.util.HashMap;
 import java.util.List;
+import java.util.Map;
+import java.util.concurrent.ConcurrentHashMap;
 
 /**
  * @author wzy
@@ -92,12 +100,110 @@
     @Autowired
     private OrderProducer orderProducer;
 
+
+    // 面值*(多单张数*多单开仓价-空单张数*空单开仓价)-余额-已实现盈亏 / 面值*(多单张数-空单张数)-(维持保证金率+TAKER手续费)*面值*(开多张数+开空张数)
+
+    /*
+    面值 : 0.1000 * 678
+    多单张数 : 300  开仓价 : 11400.53000000   -> 3420159
+    空单张数 : 300  开仓价 : 11398.27000000   -> 3419481
+    余额 : 562.92683993    -495.12
+
+    手续费率 : 0.0460
+
+
+     */
     @Test
-    public void sendMsg() {
-        List<OrderModel> list = new ArrayList<>();
-        OrderModel orderModel = new OrderModel(1L, RabbitPriceTypeEnum.ENTRUST_OPEN_MORE.getValue(), "111", "BTC");
-        list.add(orderModel);
-        orderProducer.sendLimitClose(JSONObject.toJSONString(list));
+    public void forceSetPriceTest() {
+        MemberEntity memberEntity = memberDao.selectById(15L);
+        System.out.println(CalculateUtil.getForceSetPriceForWhole("BTC/USDT", memberEntity));
+    }
+
+    @Test
+    public void profitOrLessTest() {
+        MemberEntity memberEntity = memberDao.selectById(15L);
+        ContractHoldOrderEntity contractHoldOrderEntity = contractHoldOrderDao.selectById(144L);
+        System.out.println(CalculateUtil.calProfitOrLoss(contractHoldOrderEntity, memberEntity));
+    }
+
+    @Resource
+    private RedisUtils redisUtils;
+
+    @Test
+    public void redisTest() {
+        for (int i = 827; i < 999; i++) {
+            redisUtils.del(AppContants.CLOSING_ORDER_PREFIX + i);
+        }
+    }
+
+    @Resource
+    private WebsocketPriceService websocketPriceService;
+
+    @Test
+    public void wholeBombTest() {
+        websocketPriceService.wholeBomb("BTC/USDT", "9000");
+    }
+
+    @Test
+    public void forceTest() {
+        MemberEntity memberEntity = memberDao.selectById(5L);
+        CalculateUtil.getForceSetPriceForWhole(null, memberEntity);
+    }
+
+    public static void main(String[] args) {
+        Map<String, String> map = new ConcurrentHashMap<>();
+        map.put("1", "1");
+        map.put("2", "2");
+        map.put("3", "3");
+        map.put("4", "4");
+        map.put("5", "5");
+
+        new Thread(new Runnable() {
+            @SneakyThrows
+            @Override
+            public void run() {
+                for (Map.Entry<String, String> entry : map.entrySet()) {
+                    System.out.println(entry.getKey() + " - " + entry.getValue());
+                    if (entry.getKey().equals("3")) {
+                        System.out.println(11);
+                        map.remove("3");
+                    }
+                    Thread.sleep(1000);
+                }
+
+                System.out.println(map.get("3"));
+            }
+        }).start();
+
+    }
+
+    @Test
+    public void mapTest() {
+//        websocketPriceService.wholeBomb();
+        OrderOperatePriceService.wholePriceDataOperation(63L);
+    }
+
+
+    @Test
+    public void wholeForceTest() {
+        // 8301.38608660
+//        System.out.println(new BigDecimal("9925.29996175").subtract(new BigDecimal("1623.91387515")));
+
+        BigDecimal aa = new BigDecimal("9925.29996175").subtract(new BigDecimal("8301.38608660").negate()).subtract(new BigDecimal("1623.91387515")).subtract(new BigDecimal("0.1").multiply(new BigDecimal(50)).multiply(new BigDecimal("32478.27750300")));
+        BigDecimal bb = new BigDecimal(50).multiply(new BigDecimal("0.1"));
+        BigDecimal divide = aa.divide(bb, 8, BigDecimal.ROUND_DOWN);
+        System.out.println(divide);
+        // -(账户权益-委托保证金-全仓维持保证金-全仓未实现盈利-数量*面值*开仓价格)/(数量*面值)
+        // 30818.00028568 --
+        // 29157.72306836 --
+    }
+
+    @Test
+    public void wholeForceNewTest() {
+        MemberEntity memberEntity = memberDao.selectById(15L);
+        ContractHoldOrderEntity holdOrder = contractHoldOrderDao.selectById(400L);
+
+        System.out.println(CalculateUtil.calForcePriceForWhole(memberEntity, holdOrder));
     }
 
 }

--
Gitblit v1.9.1