Esempio n. 1
0
    def test_01(self):
        """
        多单1单,空单1单,多单完全成交,空单部分成交,验证合约状态、用户余额
        """
        logger.info("用例编号:41-1---限价多单1单,限价空单1单,多单完全成交,空单部分成交,验证合约状态、用户余额")
        deal_num = 100000000
        sell_num = 200000000

        # 查询当前股价
        stock_price_dict = market_info_get(user=self.buyer, session=self.session, sda_id=sda_id)
        now_stock_price = stock_price_dict["stockPrice"]
        stock_unit = int(stock_price_dict["tradeUnit"])

        deal_price = int(int(now_stock_price) * 0.95)

        # 下一单多单、空单,完全成交
        buy_resp = self.session.post(url=base+sda_order_create_url, data=get_sda_order_create_param(
            sda_id=sda_id, order_type=多单, order_price_type=限价, order_price=deal_price, order_num=deal_num
        ))
        logger.info("用户:{0}--接口:{1}--状态:{2}--类型:多单--返回信息:{3}".format(
            self.buyer, sda_order_create_url, buy_resp.status_code, buy_resp.json()
        ))
        # time.sleep(2)
        sell_resp = self.sell_session.post(url=base+sda_order_create_url, data=get_sda_order_create_param(
            sda_id=sda_id, order_type=空单, order_price_type=限价, order_price=deal_price, order_num=sell_num
        ))
        sync_id = JMESPathExtractor().extract(query="syncLockKey", body=sell_resp.text)
        logger.info("用户:{0}--接口:{1}--状态:{2}--类型:空单--返回信息:{3}".format(
            self.seller, sda_order_create_url, sell_resp.status_code, sell_resp.json()
        ))
        sell_order_id = JMESPathExtractor().extract(query="OBJECT.orderId", body=sell_resp.text)

        # time.sleep(4)
        # 查询当前持仓中买卖方持仓数量、保证金、开仓均价
        after_buy_position_dict = query_account_position_get(user=self.buyer, session=self.session, sync_key=sync_id)
        after_sell_position_dict = query_account_position_get(user=self.seller, session=self.sell_session,
                                                              sync_key=sync_id)

        after_buy_sdaAveragePrice = after_buy_position_dict["sdaAveragePrice"]
        after_buy_sdaCount = after_buy_position_dict["sdaCount"]
        after_buy_currencyBalancePosition = int(after_buy_position_dict["currencyBalancePosition"])

        after_sell_sdaAveragePrice = after_sell_position_dict["sdaAveragePrice"]
        after_sell_sdaCount = after_sell_position_dict["sdaCount"]
        after_sell_currencyBalancePosition = after_sell_position_dict["currencyBalancePosition"]

        # 计算保证金
        buy_employ_balance = employBalance(price=deal_price, count=deal_num, unit=stock_unit, lever=1)
        print("buy_employ_balance", buy_employ_balance)
        print("after_buy")
        # 检验持仓均价,持仓量,保证金,
        price_flag = assert_one(int(deal_price), int(after_buy_sdaAveragePrice))
        num_flag = assert_one(int(deal_num), int(after_buy_sdaCount))
        after_buy_flag = assert_one(buy_employ_balance, after_buy_currencyBalancePosition)
        after_sell_flag = assert_list([int(deal_price), int(deal_num)], [int(after_sell_sdaAveragePrice), int(after_sell_sdaCount)])
        self.assertListEqual([True, True, True, True], [after_buy_flag, price_flag, num_flag,after_sell_flag])
Esempio n. 2
0
    def test_01(self):
        """
        大数成交测试
        :return:
        """
        warnings.simplefilter("ignore", ResourceWarning)
        lever = 100
        deal_num = 9999999900000
        # 查询当前股价
        stock_price_dict = market_info_get(user=self.buyer,
                                           session=self.session,
                                           sda_id=sda_id)
        now_stock_price = int(stock_price_dict["stockPrice"])
        stock_unit = int(stock_price_dict["tradeUnit"])

        deal_price = int(int(now_stock_price) * 0.95)

        # 下一单多单、空单,完全成交
        buy_resp = self.session.post(url=base + sda_order_create_url,
                                     data=get_sda_order_create_param(
                                         sda_id=sda_id,
                                         order_type=多单,
                                         order_price_type=限价,
                                         lever=lever,
                                         order_price=deal_price,
                                         order_num=deal_num))
        buy_sync_id = JMESPathExtractor().extract(query="syncLockKey",
                                                  body=buy_resp.text)
        logger.info("用户:{0}--接口:{1}--状态:{2}--类型:多单--返回信息:{3}".format(
            self.buyer, sda_order_create_url, buy_resp.status_code,
            buy_resp.json()))
        # time.sleep(3)
        sell_resp = self.sell_session.post(url=base + sda_order_create_url,
                                           data=get_sda_order_create_param(
                                               sda_id=sda_id,
                                               order_type=空单,
                                               order_price_type=限价,
                                               lever=lever,
                                               order_price=deal_price,
                                               order_num=deal_num))
        sell_sync_id = JMESPathExtractor().extract(query="syncLockKey",
                                                   body=sell_resp.text)
        logger.info("用户:{0}--接口:{1}--状态:{2}--类型:空单--返回信息:{3}".format(
            self.seller, sda_order_create_url, sell_resp.status_code,
            sell_resp.json()))
        buy_info_dict = account_info_sync(user=self.buyer,
                                          session=self.session,
                                          sda_id=sda_id,
                                          sync_id=sell_sync_id)
        # print(buy_info_dict)
        after_buy_balance = int(buy_info_dict["balance"])

        sell_info_dict = account_info_sync(user=self.seller,
                                           session=self.sell_session,
                                           sda_id=sda_id,
                                           sync_id=sell_sync_id)
        after_sell_balance = int(sell_info_dict["balance"])
        # print("stock price", deal_price)
        # print("stock unit", stock_unit)
        # employ_balance = deal_price / 100000000 * deal_num
        # print("employ balance", employ_balance)
        employ_balance = int(
            employBalance(price=deal_price,
                          count=deal_num,
                          unit=stock_unit,
                          lever=lever))
        # print("employ balance", employ_balance)
        buy_flag = assert_one(after_buy_balance,
                              int(self.sda_balance - employ_balance))
        sell_flag = assert_one(after_sell_balance,
                               int(self.sda_balance - employ_balance))
        self.assertListEqual([True, True], [buy_flag, sell_flag])
Esempio n. 3
0
    def tet_04(self):
        """
        随机成交测试
        :return:
        """
        warnings.simplefilter("ignore", ResourceWarning)
        lever = 100
        # deal_num = 100000000
        # buy_num = 9*100000000
        # 查询当前股价
        stock_price_dict = market_info_get(user=self.buyer,
                                           session=self.session,
                                           sda_id=sda_id)
        now_stock_price = int(stock_price_dict["stockPrice"])
        stock_unit = int(stock_price_dict["tradeUnit"])

        deal_price = int(int(now_stock_price) * 0.95)

        before_buy_info_dict = account_info(user=self.buyer,
                                            session=self.session,
                                            sda_id=sda_id)
        before_buy_balance = int(before_buy_info_dict["balance"])
        print("before buy balance", before_buy_balance)

        before_sell_info_dict = account_info(user=self.seller,
                                             session=self.sell_session,
                                             sda_id=sda_id)
        before_sell_balance = int(before_sell_info_dict["balance"])
        print("before sell balance", before_sell_balance)

        # random_price = random.randint(1, 99) * 100000000
        random_num = random.randint(1, 999999) * 100000000

        # 下一单多单、空单,完全成交
        for i in range(1000):
            buy_resp = self.session.post(url=base + sda_order_create_url,
                                         data=get_sda_order_create_param(
                                             sda_id=sda_id,
                                             order_type=多单,
                                             order_price_type=限价,
                                             lever=lever,
                                             order_price=now_stock_price,
                                             order_num=random_num))
            # buy_sync_id = JMESPathExtractor().extract(query="syncLockKey", body=buy_resp.text)
            logger.info("用户:{0}--接口:{1}--状态:{2}--类型:多单--返回信息:{3}".format(
                self.buyer, sda_order_create_url, buy_resp.status_code,
                buy_resp.json()))
            # time.sleep(3)
            sell_resp = self.sell_session.post(url=base + sda_order_create_url,
                                               data=get_sda_order_create_param(
                                                   sda_id=sda_id,
                                                   order_type=空单,
                                                   order_price_type=市价,
                                                   lever=lever,
                                                   order_price=now_stock_price,
                                                   order_num=random_num))
            sell_sync_id = JMESPathExtractor().extract(query="syncLockKey",
                                                       body=sell_resp.text)
            logger.info("用户:{0}--接口:{1}--状态:{2}--类型:空单--返回信息:{3}".format(
                self.seller, sda_order_create_url, sell_resp.status_code,
                sell_resp.json()))
            buy_info_dict = account_info_sync(user=self.buyer,
                                              session=self.session,
                                              sda_id=sda_id,
                                              sync_id=sell_sync_id)
            # print(buy_info_dict)
            after_buy_balance = int(buy_info_dict["balance"])

            sell_info_dict = account_info_sync(user=self.seller,
                                               session=self.sell_session,
                                               sda_id=sda_id,
                                               sync_id=sell_sync_id)
            after_sell_balance = int(sell_info_dict["balance"])
            # print("stock price", deal_price)
            # print("stock unit", stock_unit)
            buy_employ_balance = int(
                employBalance(price=now_stock_price,
                              count=random_num,
                              unit=stock_unit,
                              lever=lever))
            employ_balance = int(
                employBalance(price=now_stock_price,
                              count=random_num,
                              unit=stock_unit,
                              lever=lever))
            print("buy employ balance", buy_employ_balance)
            buy_flag = assert_one(after_buy_balance,
                                  int(before_buy_balance - buy_employ_balance))
            sell_flag = assert_one(after_sell_balance,
                                   int(before_sell_balance - employ_balance))
            self.assertListEqual([True, True], [buy_flag, sell_flag])

            # 平仓
            time.sleep(0.1)
            buy_resp = self.session.post(url=base + sda_order_create_url,
                                         data=get_sda_order_create_param(
                                             sda_id=sda_id,
                                             order_type=平多,
                                             order_price_type=限价,
                                             lever=lever,
                                             order_price=now_stock_price,
                                             order_num=random_num))
            # buy_sync_id = JMESPathExtractor().extract(query="syncLockKey", body=buy_resp.text)
            logger.info("用户:{0}--接口:{1}--状态:{2}--类型:多单--返回信息:{3}".format(
                self.buyer, sda_order_create_url, buy_resp.status_code,
                buy_resp.json()))
            time.sleep(0.1)
            sell_resp = self.sell_session.post(url=base + sda_order_create_url,
                                               data=get_sda_order_create_param(
                                                   sda_id=sda_id,
                                                   order_type=平空,
                                                   order_price_type=市价,
                                                   lever=lever,
                                                   order_price=now_stock_price,
                                                   order_num=random_num))
            # sell_sync_id = JMESPathExtractor().extract(query="syncLockKey", body=sell_resp.text)
            logger.info("用户:{0}--接口:{1}--状态:{2}--类型:空单--返回信息:{3}".format(
                self.seller, sda_order_create_url, sell_resp.status_code,
                sell_resp.json()))
Esempio n. 4
0
    def test_01(self):
        """
        限价多单1单,杠杆5倍,限价空单1单,杠杆1倍,完全成交,验证合约状态、用户余额
        """
        logger.info(
            "用例编号:119-1---限价多单1单,杠杆50倍,限价空单1单,杠杆1倍,完全成交,验证保证金、开仓手续费、预估爆仓价")
        deal_num = 10 * 100000000
        lever = 50

        # 查询当前股价
        stock_price_dict = market_info_get(user=self.buyer,
                                           session=self.session,
                                           sda_id=sda_id)
        now_stock_price = int(stock_price_dict["stockPrice"])
        stock_unit = int(stock_price_dict["tradeUnit"])

        deal_price = int(int(now_stock_price) * 0.95)
        # deal_price = 18*100000000

        before_buy_dict = account_info(user=self.buyer,
                                       session=self.session,
                                       sda_id=sda_id)
        before_buy_balance = before_buy_dict["balance"]

        # 下一单多单、空单,完全成交
        buy_resp = self.session.post(url=base + sda_order_create_url,
                                     data=get_sda_order_create_param(
                                         sda_id=sda_id,
                                         order_type=多单,
                                         order_price_type=限价,
                                         lever=lever,
                                         order_price=deal_price,
                                         order_num=deal_num))
        buy_sync_id = JMESPathExtractor().extract(query="syncLockKey",
                                                  body=buy_resp.text)
        logger.info("用户:{0}--接口:{1}--状态:{2}--类型:多单--返回信息:{3}".format(
            self.buyer, sda_order_create_url, buy_resp.status_code,
            buy_resp.json()))
        # time.sleep(3)
        sell_resp = self.sell_session.post(url=base + sda_order_create_url,
                                           data=get_sda_order_create_param(
                                               sda_id=sda_id,
                                               order_type=空单,
                                               order_price_type=限价,
                                               lever=lever,
                                               order_price=deal_price,
                                               order_num=deal_num))
        sell_sync_id = JMESPathExtractor().extract(query="syncLockKey",
                                                   body=sell_resp.text)
        logger.info("用户:{0}--接口:{1}--状态:{2}--类型:空单--返回信息:{3}".format(
            self.seller, sda_order_create_url, sell_resp.status_code,
            sell_resp.json()))

        # 计算仓位保证金
        buy_employ_balance = employBalance(price=deal_price,
                                           count=deal_num,
                                           unit=stock_unit,
                                           lever=lever)
        print(buy_employ_balance)
        # 计算开仓手续费
        open_stock_cost = openStockCost(price=deal_price,
                                        count=deal_num,
                                        doMore=True,
                                        unit=stock_unit,
                                        stockPrice=now_stock_price)

        # 计算未实现盈亏
        buy_real_less = int(
            unRealLoss(holdAvgPrice=deal_price,
                       count=deal_num,
                       unit=stock_unit,
                       doMore=True,
                       holdCharge=open_stock_cost,
                       stock_price=now_stock_price))

        # 计算爆仓价
        buy_crash_price = crashPrice(holdAvgPrice=deal_price,
                                     holdCount=deal_num,
                                     totalBalance=self.sda_balance -
                                     open_stock_cost,
                                     unit=stock_unit,
                                     doMore=True)
        time.sleep(0.1)
        buy_position_get_dict = query_account_position_get(
            user=self.buyer, session=self.session, sync_key=sell_sync_id)
        buy_bust_price = int(buy_position_get_dict["sdaBustPrice"])  # 预估爆仓价
        buy_balance_position = int(
            buy_position_get_dict["currencyBalancePosition"])  # 仓位保证金
        buy_unrealized_PNL = int(
            buy_position_get_dict["unrealizedPNL"])  # 未实现盈亏

        balance_flag = assert_one(buy_balance_position,
                                  buy_employ_balance)  # 检验保证金
        bust_flag = assert_one(buy_bust_price, buy_crash_price)  # 检验爆仓
        pnl_flag = assert_one(buy_unrealized_PNL, buy_real_less)  # 检验未实现盈亏
        self.assertListEqual([True, True, True],
                             [bust_flag, pnl_flag, balance_flag])
Esempio n. 5
0
    def test_06(self):
        """
        限价空单,循环下单,验证可用余额、委托保证金
        :return:
        """
        logger.info("用例编号:6-6---限价空单,循环下单,验证可用余额、委托保证金")
        sda_balance = 9999999900000000
        ConnectMysql(_type=mysql_type).sda_clear_open_empty_close_multi_order(
            user_id=self.user_id, contract_id=sda_id, status=2)
        ConnectMysql(_type=mysql_type).sda_clear_open_multi_close_open_order(
            user_id=self.user_id, contract_id=sda_id, status=2)
        ConnectRedis(_type=redis_type).sda_clear_order(sda_id=sda_id)
        ConnectRedis(_type=redis_type,
                     db=4).sda_clear_user_balance(user_id=self.user_id,
                                                  keys=sda_id)
        ConnectMysql(_type=mysql_type).sda_update_user_balance(
            user_id=self.user_id, sda_id=sda_id, sda_balance=sda_balance)

        # 查询当前股价
        stock_price_dict = market_info_get(user=self.buyer,
                                           session=self.session,
                                           sda_id=sda_id)
        now_stock_price = stock_price_dict["stockPrice"]
        stock_unit = int(stock_price_dict["tradeUnit"])
        price = int(int(now_stock_price) * 0.95)

        # 查询可用余额
        info_dict = account_info(user=self.buyer,
                                 session=self.session,
                                 sda_id=sda_id,
                                 price=1000000000)
        before_balance = info_dict["balance"]

        # 下限价委托
        amount_list = []
        sync_flag_list = []
        employ_balance_list = []
        for i in range(50):
            amount = random.randint(1, 100) * 100000000
            amount_list.append(amount)
            order_resp = self.session.post(url=base + sda_order_create_url,
                                           data=get_sda_order_create_param(
                                               sda_id=sda_id,
                                               order_type=空单,
                                               order_price_type=限价,
                                               order_price=price,
                                               order_num=amount,
                                           ))
            sync_id = JMESPathExtractor().extract(query="syncLockKey",
                                                  body=order_resp.text)
            sync_flag = sda_sync_lock(session=self.session, sync_id=sync_id)
            sync_flag_list.append(sync_flag)
            logger.info("接口:{0}---返回信息:{1}".format(sda_order_create_url,
                                                   order_resp.json()))
            # time.sleep(0.1)
            employ_balance = employBalance(price=price,
                                           count=amount,
                                           unit=stock_unit,
                                           lever=1)
            employ_balance_list.append(employ_balance)

        # 查询下委托后的可用余额
        # time.sleep(3)
        for v in sync_flag_list:
            if "OK" != v:
                raise SyncException("sync lock 异常")
        else:
            after_info_dict = account_info(user=self.buyer,
                                           session=self.session,
                                           sda_id=sda_id,
                                           price=1000000000)
            after_balance = after_info_dict["balance"]

        flag_one = assert_one(int(before_balance),
                              int(after_balance) + sum(employ_balance_list))
        self.assertTrue(flag_one)
Esempio n. 6
0
    def test_01(self):
        """
        限价多单委托,正常下单。
        """
        logger.info("用例编号:6-1---限价多单委托,正常下单。")
        price = 100000000
        num = 100000000
        stock_price_dict = market_info_get(user=self.buyer,
                                           session=self.session,
                                           sda_id=sda_id)
        now_stock_price = int(stock_price_dict["stockPrice"])
        stock_unit = int(stock_price_dict["tradeUnit"])

        ConnectMysql(_type=mysql_type).sda_clear_open_empty_close_multi_order(
            user_id=self.user_id, contract_id=sda_id, status=2)
        ConnectMysql(_type=mysql_type).sda_clear_open_multi_close_open_order(
            user_id=self.user_id, contract_id=sda_id, status=2)
        ConnectRedis(_type=redis_type).sda_clear_order(sda_id=sda_id)
        ConnectRedis(_type=redis_type,
                     db=4).sda_clear_user_balance(user_id=self.user_id,
                                                  keys=sda_id)
        ConnectMysql(_type=mysql_type).sda_update_user_balance(
            user_id=self.user_id, sda_id=sda_id, sda_balance=990000000000)

        # 查询可用余额
        info_dict = account_info(user=self.buyer,
                                 session=self.session,
                                 sda_id=sda_id,
                                 price=1000000000)
        before_balance = info_dict["balance"]

        # 下限价委托
        order_resp = self.session.post(url=base + sda_order_create_url,
                                       data=get_sda_order_create_param(
                                           sda_id=sda_id,
                                           order_type=多单,
                                           order_price_type=限价,
                                           order_price=price,
                                           order_num=num,
                                       ))
        logger.info("下单:{}".format(order_resp.text))
        msg = JMESPathExtractor().extract(query="MSG", body=order_resp.text)
        status = JMESPathExtractor().extract(query="STATUS",
                                             body=order_resp.text)
        order_id = JMESPathExtractor().extract(query="OBJECT.orderId",
                                               body=order_resp.text)
        sync_id = JMESPathExtractor().extract(query="syncLockKey",
                                              body=order_resp.text)

        # 查询当前委托
        # time.sleep(1)
        get_open_dict = query_order_get_open(user=self.buyer,
                                             session=self.session,
                                             order_id=order_id)
        order_quantity = get_open_dict["orderQuantity"]  # 委托数量
        order_price = get_open_dict["orderPrice"]  # 委托价格
        order_status = get_open_dict["orderStatus"]  # 委托状态

        # 查询下委托后的可用余额
        time.sleep(5)
        after_info_dict = account_info_sync(sync_id=sync_id,
                                            user=self.buyer,
                                            session=self.session,
                                            sda_id=sda_id,
                                            price=1000000000)
        after_balance = after_info_dict["balance"]

        employ_balance = employBalance(price=price,
                                       count=num,
                                       unit=stock_unit,
                                       lever=1)

        flag_one = assert_one(int(before_balance),
                              int(after_balance) + int(employ_balance))
        flag_two = assert_list(
            [int(order_quantity),
             int(order_price), order_status], [num, price, "0"])
        flag_three = assert_list([200, "SUCCESS", "0"],
                                 [order_resp.status_code, msg, status])
        self.assertListEqual([True, True, True],
                             [flag_one, flag_two, flag_three])
Esempio n. 7
0
    def test_05(self):
        """
        限价多单,循环多次下单,验证可用余额
        :return:
        """
        logger.info("用例编号:6-5--限价多单,循环多次下单,验证可用余额")
        price = 100000000
        sda_balance = 9999999900000000
        # 查询当前股价
        stock_price_dict = market_info_get(user=self.buyer,
                                           session=self.session,
                                           sda_id=sda_id)
        now_stock_price = stock_price_dict["stockPrice"]
        stock_unit = int(stock_price_dict["tradeUnit"])

        ConnectMysql(_type=mysql_type).sda_clear_open_empty_close_multi_order(
            user_id=self.user_id, contract_id=sda_id, status=2)
        ConnectMysql(_type=mysql_type).sda_clear_open_multi_close_open_order(
            user_id=self.user_id, contract_id=sda_id, status=2)
        ConnectRedis(_type=redis_type).sda_clear_order(sda_id=sda_id)
        ConnectRedis(_type=redis_type,
                     db=4).sda_clear_user_balance(user_id=self.user_id,
                                                  keys=sda_id)
        ConnectMysql(_type=mysql_type).sda_update_user_balance(
            user_id=self.user_id, sda_id=sda_id, sda_balance=sda_balance)

        # 查询可用余额
        info_dict = account_info(user=self.buyer,
                                 session=self.session,
                                 sda_id=sda_id,
                                 price=1000000000)
        before_balance = info_dict["balance"]

        # 下单前查询用户的余额
        buy_balance = self.session.post(
            url=base + sda_account_asset_detail_get_url,
            data=get_sda_account_asset_detail_get_param())
        buy_balance_value = JMESPathExtractor().extract(
            query="OBJECT.PNLList[0].availableMargin", body=buy_balance.text)
        buy_entrust_value = JMESPathExtractor().extract(
            query="OBJECT.PNLList[0].entrustMargin", body=buy_balance.text)
        logger.info(
            "用户:{0}---接口:{1}---状态:{2}---下单前可用保证金:{3}--委托保证金:{4}".format(
                self.buyer, sda_account_asset_detail_get_url,
                buy_balance.status_code, buy_balance_value, buy_entrust_value))

        # 下限价委托
        amount_list = []
        sync_flag_list = []
        employ_balance_list = []
        for i in range(200):
            amount = random.randint(1, 100) * 100000000
            amount_list.append(amount)
            order_resp = self.session.post(url=base + sda_order_create_url,
                                           data=get_sda_order_create_param(
                                               sda_id=sda_id,
                                               order_type=多单,
                                               order_price_type=限价,
                                               order_price=price,
                                               order_num=amount))
            sync_id = JMESPathExtractor().extract(query="syncLockKey",
                                                  body=order_resp.text)
            logger.info("接口:{0}---返回信息:{1}".format(sda_order_create_url,
                                                   order_resp.json()))
            sync_flag = sda_sync_lock(session=self.session, sync_id=sync_id)
            sync_flag_list.append(sync_flag)
            # time.sleep(0.1)
            # 计算每次下单所使用的保证金
            employ_balance = employBalance(price=price,
                                           count=amount,
                                           unit=stock_unit,
                                           lever=1)
            employ_balance_list.append(employ_balance)

        # 查询下委托后的可用余额
        # time.sleep(2)
        for v in sync_flag_list:
            if "OK" != v:
                raise SyncException("sync lock 异常")
        else:
            after_info_dict = account_info(user=self.buyer,
                                           session=self.session,
                                           sda_id=sda_id,
                                           price=1000000000)
            after_balance = after_info_dict["balance"]

        # 查询用户余额,然后判断下单前后的用户余额
        after_buy_balance = self.session.post(
            url=base + sda_account_asset_detail_get_url,
            data=get_sda_account_asset_detail_get_param())
        after_buy_balance_value = JMESPathExtractor().extract(
            query="OBJECT.PNLList[0].availableMargin",
            body=after_buy_balance.text)
        after_buy_entrust_value = JMESPathExtractor().extract(
            query="OBJECT.PNLList[0].entrustMargin",
            body=after_buy_balance.text)
        logger.info(
            "用户:{0}---接口:{1}---状态:{2}---下单后可用保证金:{3}---下单后委托保证金:{4}".format(
                self.buyer, sda_account_asset_detail_get_url,
                after_buy_balance.status_code, after_buy_balance_value,
                after_buy_entrust_value))

        flag_one = assert_one(int(before_balance),
                              int(after_balance) + sum(employ_balance_list))
        # flag_two = assert_one(int(buy_entrust_value), int(after_buy_entrust_value) + sum(amount_list))
        self.assertTrue(flag_one)
Esempio n. 8
0
    def test_01(self):
        """
        大数极限测试类
        """
        logger.info("用例编号:110-1---大数极限测试类")
        deal_num = 90000000000*100000000
        lever = 100

        # 查询当前股价
        stock_price_dict = market_info_get(user=self.buyer, session=self.session, sda_id=sda_id)
        now_stock_price = stock_price_dict["stockPrice"]
        stock_unit = int(stock_price_dict["tradeUnit"])

        deal_price = int(int(now_stock_price) * 1)
        # deal_price = now_stock_price
        print("stock price", now_stock_price)
        before_buy_dict = account_info(user=self.buyer, session=self.session, sda_id=sda_id)
        before_buy_balance = before_buy_dict["balance"]

        # 下一单多单、空单,完全成交
        buy_resp = self.session.post(url=base+sda_order_create_url, data=get_sda_order_create_param(
            sda_id=sda_id, order_type=多单, order_price_type=限价, lever=lever, order_price=deal_price,order_num=deal_num
        ))
        buy_sync_id = JMESPathExtractor().extract(query="syncLockKey", body=buy_resp.text)
        logger.info("用户:{0}--接口:{1}--状态:{2}--类型:多单--返回信息:{3}".format(
            self.buyer, sda_order_create_url, buy_resp.status_code, buy_resp.json()
        ))
        # time.sleep(3)
        sell_resp = self.sell_session.post(url=base+sda_order_create_url, data=get_sda_order_create_param(
            sda_id=sda_id, order_type=空单, order_price_type=限价, lever=lever, order_price=deal_price,order_num=deal_num
        ))
        sell_sync_id = JMESPathExtractor().extract(query="syncLockKey", body=sell_resp.text)
        logger.info("用户:{0}--接口:{1}--状态:{2}--类型:空单--返回信息:{3}".format(
            self.seller, sda_order_create_url, sell_resp.status_code, sell_resp.json()
        ))

        # time.sleep(5)
        # 查询当前持仓中买卖方持仓数量、保证金、开仓均价
        after_buy_position_dict = query_account_position_get(sync_key=sell_sync_id, user=self.buyer,
                                                             session=self.session)
        after_sell_position_dict = query_account_position_get(sync_key=sell_sync_id, user=self.seller,
                                                              session=self.sell_session)

        after_buy_sdaAveragePrice = after_buy_position_dict["sdaAveragePrice"]
        after_buy_sdaCount = after_buy_position_dict["sdaCount"]
        after_buy_currencyBalancePosition = after_buy_position_dict["currencyBalancePosition"]

        after_sell_sdaAveragePrice = after_sell_position_dict["sdaAveragePrice"]
        after_sell_sdaCount = after_sell_position_dict["sdaCount"]
        after_sell_currencyBalancePosition = after_sell_position_dict["currencyBalancePosition"]

        # 计算保证金
        buy_currency_balance = employBalance(price=deal_price, count=deal_num, unit=stock_unit, lever=lever)

        # 检验持仓均价,持仓量,保证金
        balance_flag = assert_one(int(after_buy_currencyBalancePosition), int(buy_currency_balance))
        self.assertTrue(balance_flag)

        price_flag = assert_one(int(deal_price), int(after_buy_sdaAveragePrice))
        num_flag = assert_one(int(deal_num), int(after_buy_sdaCount))
        # after_buy_flag = assert_one(buy_currency_balance, int(after_buy_currencyBalancePosition))
        after_sell_flag = assert_list([int(deal_price), int(deal_num)], [int(after_sell_sdaAveragePrice), int(after_sell_sdaCount)])
        self.assertListEqual([True, True, True], [price_flag, num_flag,after_sell_flag])
Esempio n. 9
0
    def tet_03(self):
        """
        限价空单1单,50倍杠杆,限价多单1单,1倍杠杆,完全成交,验证合约状态、用户余额
        """
        logger.info("用例编号:200-2---限价空单1单,50倍杠杆,限价多单1单,1倍杠杆,完全成交,验证合约状态、用户余额")

        for i in range(100):
            deal_num = random.randint(1, 10) * 100000000
            lever = 50

            # 查询当前股价
            stock_price_dict = market_info_get(user=self.buyer, session=self.session, sda_id=sda_id)
            now_stock_price = stock_price_dict["stockPrice"]

            deal_price = int(int(now_stock_price) * 0.95)

            # 交易前查询用户余额
            before_buy_dict = account_info(user=self.buyer, session=self.session, sda_id=sda_id)
            before_buy_balance = before_buy_dict["balance"]

            # 下一单多单、空单,完全成交
            buy_resp = self.session.post(url=base+sda_order_create_url, data=get_sda_order_create_param(
                sda_id=sda_id, order_type=空单, order_price_type=限价, lever=lever, order_price=deal_price,order_num=deal_num
            ))
            logger.info("用户:{0}--接口:{1}--状态:{2}--类型:空单--返回信息:{3}".format(
                self.buyer, sda_order_create_url, buy_resp.status_code, buy_resp.json()
            ))
            # time.sleep(3)
            sell_resp = self.sell_session.post(url=base+sda_order_create_url, data=get_sda_order_create_param(
                sda_id=sda_id, order_type=多单, order_price_type=限价, lever=lever, order_price=deal_price, order_num=deal_num
            ))
            logger.info("用户:{0}--接口:{1}--状态:{2}--类型:多单--返回信息:{3}".format(
                self.seller, sda_order_create_url, sell_resp.status_code, sell_resp.json()
            ))

            time.sleep(10)
            # 查询当前持仓中买卖方持仓数量、保证金、开仓均价
            after_buy_position_dict = query_account_position_get(user=self.buyer, session=self.session)
            after_sell_position_dict = query_account_position_get(user=self.seller, session=self.sell_session)

            after_buy_sdaAveragePrice = after_buy_position_dict["sdaAveragePrice"]
            after_buy_sdaCount = after_buy_position_dict["sdaCount"]
            after_buy_currencyBalancePosition = after_buy_position_dict["currencyBalancePosition"]

            after_sell_sdaAveragePrice = after_sell_position_dict["sdaAveragePrice"]
            after_sell_sdaCount = after_sell_position_dict["sdaCount"]
            after_sell_currencyBalancePosition = after_sell_position_dict["currencyBalancePosition"]

            # 计算保证金
            buy_currency_balance = (deal_num * deal_price / 100000000) / lever
            buy_currency_balance_2 = employBalance(price=deal_price, count=deal_num, unit=1, lever=lever)
            # sell_currency_balance = make_currency_balance(num=deal_num, price=deal_price)

            # 检验持仓均价,持仓量,保证金
            balance_flag = assert_one(int(after_buy_currencyBalancePosition), int(buy_currency_balance_2))
            print(after_buy_currencyBalancePosition)
            print(buy_currency_balance_2)
            self.assertTrue(balance_flag)

            price_flag = assert_one(int(deal_price), int(after_buy_sdaAveragePrice))
            num_flag = assert_one(int(deal_num), int(after_buy_sdaCount))
            # after_buy_flag = assert_one(buy_currency_balance, int(after_buy_currencyBalancePosition))
            after_sell_flag = assert_list([int(deal_price), int(deal_num)], [int(after_sell_sdaAveragePrice),
                                                                             int(after_sell_sdaCount)])
            self.assertListEqual([True, True, True], [price_flag, num_flag,after_sell_flag])