From bb4e25fa2855f45021847d00edc1a908505d2cc3 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Tue, 30 Mar 2021 18:28:45 +0800
Subject: [PATCH] Merge branch 'activity' of http://120.27.238.55:7000/r/exchange into activity

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

diff --git a/src/test/java/com/xcong/excoin/WholeTest.java b/src/test/java/com/xcong/excoin/WholeTest.java
index 9d52d39..36b5d9d 100644
--- a/src/test/java/com/xcong/excoin/WholeTest.java
+++ b/src/test/java/com/xcong/excoin/WholeTest.java
@@ -13,6 +13,7 @@
 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;
@@ -114,8 +115,15 @@
      */
     @Test
     public void forceSetPriceTest() {
-        MemberEntity memberEntity = memberDao.selectById(21L);
-        CalculateUtil.getForceSetPriceForWhole("BTC/USDT", memberEntity);
+        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
@@ -171,7 +179,47 @@
 
     @Test
     public void mapTest() {
-        websocketPriceService.wholeBomb();
+//        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() {
+        String symbol = "BTC/USDT";
+        MemberEntity memberEntity = memberDao.selectById(15L);
+        ContractHoldOrderEntity holdOrder = contractHoldOrderDao.selectById(144L);
+        List<ContractHoldOrderEntity> wholeOrders = contractHoldOrderDao.selectHoldOrderListForWholeByMemberIdAndSymbol(memberEntity.getId(), null);
+        MemberWalletContractEntity wallet = memberWalletContractDao.findWalletContractByMemberIdAndSymbol(memberEntity.getId(), CoinTypeEnum.USDT.name());
+        if (CollUtil.isNotEmpty(wholeOrders)) {
+            BigDecimal totalProfitOrLoss = BigDecimal.ZERO;
+            BigDecimal otherSymbolBond = BigDecimal.ZERO;
+            for (ContractHoldOrderEntity wholeOrder : wholeOrders) {
+                BigDecimal profitOrLoss = CalculateUtil.calProfitOrLoss(wholeOrder, memberEntity);
+                totalProfitOrLoss = totalProfitOrLoss.add(profitOrLoss);
+                if (!wholeOrder.getId().equals(holdOrder.getId())) {
+                    otherSymbolBond = otherSymbolBond.add(wholeOrder.getBondAmount());
+                }
+            }
+
+            BigDecimal bond = wallet.getTotalBalance().add(totalProfitOrLoss).subtract(otherSymbolBond);
+            System.out.println(bond);
+            System.out.println(CalculateUtil.getForceSetPrice(bond, holdOrder.getOpeningPrice(), holdOrder.getSymbolCntSale(), holdOrder.getSymbolSku(), holdOrder.getOpeningType(), memberEntity));
+        }
     }
 
 }

--
Gitblit v1.9.1