From d23645e976981bc9b670eea1d469fe8a36be309c Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Wed, 17 Apr 2024 17:19:53 +0800
Subject: [PATCH] 55测试环境

---
 src/test/java/com/xcong/excoin/WholeTest.java |   39 ++++++++++++++++++++++++++++++++++++---
 1 files changed, 36 insertions(+), 3 deletions(-)

diff --git a/src/test/java/com/xcong/excoin/WholeTest.java b/src/test/java/com/xcong/excoin/WholeTest.java
index 1123b19..a366bfc 100644
--- a/src/test/java/com/xcong/excoin/WholeTest.java
+++ b/src/test/java/com/xcong/excoin/WholeTest.java
@@ -17,6 +17,7 @@
 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.CoinTypeConvert;
 import com.xcong.excoin.utils.RedisUtils;
 import com.xcong.excoin.utils.ThreadPoolUtils;
 import lombok.SneakyThrows;
@@ -200,10 +201,42 @@
 
     @Test
     public void wholeForceNewTest() {
-        MemberEntity memberEntity = memberDao.selectById(15L);
-        ContractHoldOrderEntity holdOrder = contractHoldOrderDao.selectById(400L);
+        BigDecimal newPrice = new BigDecimal(redisUtils.getString(CoinTypeConvert.convertToKey("BTC/USDT")));
 
-        System.out.println(CalculateUtil.calForcePriceForWhole(memberEntity, holdOrder));
+        MemberEntity memberEntity = memberDao.selectById(19L);
+        ContractHoldOrderEntity holdOrder = contractHoldOrderDao.selectById(932L);
+
+        System.out.println(CalculateUtil.calWholePriceTwo(memberEntity, holdOrder, 2));
+    }
+
+    @Test
+    public void wholeForceNewTest2() {
+        BigDecimal holdBond = new BigDecimal("1161.8951");
+
+        BigDecimal sku = new BigDecimal("0.1");
+        BigDecimal openPrice = new BigDecimal("58094.75");
+        int cnt = 50;
+        BigDecimal total = new BigDecimal("9866.3820");
+        // 成本 数量*面值*开仓价
+        BigDecimal cost = sku.multiply(openPrice).multiply(new BigDecimal(cnt));
+        // 费率
+        BigDecimal ratio = openPrice.multiply(new BigDecimal("0.005"));
+        // 总账户 - 维持保证金
+        BigDecimal orderProfitOrLoss = total.subtract(holdBond);
+        // 权益
+        BigDecimal qy = BigDecimal.ZERO;
+
+        BigDecimal prefix = cost.subtract(ratio);
+        BigDecimal divideChild;
+//        if (ContractHoldOrderEntity.OPENING_TYPE_MORE == contractHoldOrderEntity.getOpeningType()) {
+            divideChild = prefix.subtract(orderProfitOrLoss).subtract(qy);
+//        } else {
+//            divideChild = prefix.add(orderProfitOrLoss).add(qy);
+//        }
+//            BigDecimal divideChild = walletContract.getTotalBalance().add(totalProfitOrLoss).subtract(holdBond).subtract(cost).add(newPrice.multiply(new BigDecimal("0.005")));
+        BigDecimal divideParent = sku.multiply(new BigDecimal(cnt));
+
+        System.out.println(divideChild.divide(divideParent, 8, BigDecimal.ROUND_DOWN));
     }
 
 }

--
Gitblit v1.9.1