# 8.test_class_auto_incre

# 使用ddt
import requests
import unittest
from p2p_project_7.tools.http_request import HttpRequest
from p2p_project_7.tools.get_data import GetData
from p2p_project_7.tools.do_excel_auto_incre_by_fanshe_2 import DoExcel
from p2p_project_7.tools import project_path
from p2p_project_7.tools.do_mysql_class import DoMysql
from p2p_project_7.tools.write_log_class import MyLog
from ddt import ddt, data

test_data = DoExcel().get_data(project_path.test_case_path)
my_logger = MyLog()

@ddt
class TestLogin(unittest.TestCase):
    def setUp(self):
        print("start testing...")

    def tearDown(self):
        print("case end.")

    @data(*test_data)
    def test_api(self, item):
        # print("self.method: {}, type:{}".format(self.method, type(self.method)))
        # print("self.data: {}".format(self.data))
        # print("cookie是:", GetCookie.Cookie)

        # 替换loan_id
        my_logger.info("开始执行用例{0}:{1}".format(item["case_id"], item["tittle"]))
        if item["data"]["id"].find("${loan_id}") != -1:
            # 在数据库中根据借款人账号找到标id,使用max是因为如果测试账号,可能有多个人同时使用用来加标
            query_sql = "select max(Id) from loan where MemberID={0}".format(getattr(GetData, "loan_member_id"))
            loan_id = DoMysql().do_mysql(query_sql)[0][0]
            item["data"] = item["data"].replace("${loan_id}", str(loan_id))
            # 把标id的值存到反射,也可以不存,不使用反射,每次都直接在数据库中取值;
            # 使用反射的原因是多个人用同一个账号进行加标,不能保证每次取到的都是自己加的那个标,所以用反射把自己加的标id存起来
            setattr(GetData, "LoanId", loan_id)
            my_logger.info("标id是:{0}".format(loan_id))
        else:
            # loan_id有值的话就直接使用反射进行替换
            my_logger.info("标id是:{0}".format(getattr(GetData, "LoanId")))
            item["data"] = item["data"].replace("${loan_id}", str(getattr(GetData, "LoanId")))
        my_logger.info("获取到的请求数据是:{0}".format(item["data"]))
        my_logger.info("----------------开始接口请求-----------------")

        if item["sheet_name"] in getattr(GetData, "check_list"):
            # 充值请求之前查询余额
            # 查询数据库
            query_sql = "select LeaveAmount from member where  mobile={0}".format(item["data"]["mobile"])
            BeforeAmount = DoMysql().do_mysql(query_sql, 1)[0]
            res = HttpRequest().http_request(item["url"], item["method"], item["data"], cookie=GetData.Cookie)
            # 充值请求之后校验余额
            query_sql = "select LeaveAmount from member where  mobile={0}".format(item["data"]["mobile"])
            AfterAmount = DoMysql().do_mysql(query_sql, 1)[0]
            # 61-64 行代码:不是所有的用例都这么检查,因为有的用例不涉及充值,优化做法是在excel中定义好哪些用例需要查余额
            if abs(BeforeAmount - AfterAmount) == eval(item["data"])["amount"]:
                check_res = "金额正确"
            else:
                check_res = "金额不对"

        # print("哪出错了")
        # print(res.text)
        r = res.json()["errorCode"]

        # 如果GetCookie.Cookie没有值,就把响应的cookie值赋给GetCookie.Cookie,以便下次请求使用
        if GetData.Cookie is None:
            setattr(GetData, "Cookie", res.cookies)
        #  如果GetCookie.Cookie不为空,就把新获得的res.cookies添加到原有的cookie中
        else:
            GetData.Cookie.update(res.cookies)
        try:
            self.assertEqual(r, item["expected"])
            test_result = "PASS"  # 用例成功
        except AssertionError as e:
            test_result = "FAILED"  # 用例失败
            print("there is an error: {}".format(e))
            raise e
        # 无论是否异常,finally后面都要执行。这里是写入响应结果和测试结论
        finally:
            DoExcel().write_back(project_path.test_case_path, item["sheet_name"], item["case_id"] + 1, str(res.json()), test_result)
            print(res.json())

配置文件:

测试数据:

对需要检查余额的用例写入SQL语句:

unittest(22)- p2p项目实战(8)-test_class_auto_incre的更多相关文章

  1. unittest(22)- p2p项目实战(7)-do_mysql

    # 7. do_msql.py import mysql.connector from p2p_project_2020_1_21.tools import project_path from p2p ...

  2. unittest(22)- p2p项目实战(4)-read_config

    # 4. read_config.py import configparser class ReadConfig: @staticmethod def get_config(file_path, se ...

  3. unittest(22)- p2p项目实战(3)-project_path

    # 3. project_path.py # 用来读取文件的路径 import os # os.path.split(path)使用: # 1.path如果是具体到文件名,则返回最后层级的文件,和文件 ...

  4. unittest(22)- p2p项目实战(2)-http_request

    # 2. http_request.py import requests from learn_logging_5.write_log_class import MyLog my_logger = M ...

  5. selenium3 web自动化测试框架 四:Unittest介绍及项目实战中的运用

    unittest介绍及运用,可以参考之前写的文章,除了未结合web自动化演示,基础知识都有了 https://www.cnblogs.com/wuzhiming/p/8858305.html unit ...

  6. 移动端自动化测试Appium 从入门到项目实战Python版☝☝☝

    移动端自动化测试Appium 从入门到项目实战Python版 (一个人学习或许会很枯燥,但是寻找更多志同道合的朋友一起,学习将会变得更加有意义✌✌)  说到APP自动化测试,Appium可是说是非常流 ...

  7. angularJs项目实战!02:前端的页面分解与组装

    自从上一篇文章到现在已经有将近一个月的时间,我将精力放在了前端页面分解与组装,和angularjs如何与jquery.bootstrap.D3等一系列其他类库结合使用的经验总结上.由于公司新招了一些员 ...

  8. angularJs项目实战!01:模块划分和目录组织

    近日来我有幸主导了一个典型的web app开发.该项目从产品层次来说是个典型的CRUD应用,故而我毫不犹豫地采用了grunt + boilerplate + angularjs + bootstrap ...

  9. Spark大型项目实战:电商用户行为分析大数据平台

    本项目主要讲解了一套应用于互联网电商企业中,使用Java.Spark等技术开发的大数据统计分析平台,对电商网站的各种用户行为(访问行为.页面跳转行为.购物行为.广告点击行为等)进行复杂的分析.用统计分 ...

随机推荐

  1. 2Python-DAY2模块

    1.模块 标准模块:不需要安装,可以直接导入的模块(库) 创建名为sys.py文件,执行该文件: import sys print(sys.path)打印环境变量 (python2中执行这个命令会报错 ...

  2. mongodb的常见使用命令行

    由于cms工程要连接mongodb所以需要在在cms服务端工程添加如下依赖:项目使用spring data mongodb操作mongodb数据库 <dependency> <gro ...

  3. gradle问题

    1, my gradle version is 4.6 . in project.gradle : change dependencies { classpath 'com.android.tools ...

  4. C - Monitor CodeForces - 846D (二维前缀和 + 二分)

    Recently Luba bought a monitor. Monitor is a rectangular matrix of size n × m. But then she started ...

  5. java和数据库中所有的锁都在这了

    1.java中的锁 1.1 锁的种类 公平锁/非公平锁 可重入锁/不可重入 独享锁/共享锁 读写锁 分段锁 偏向锁/轻量级锁/重量级锁 自旋锁 1.2 锁详细介绍 1.2.1 公平锁,非公平锁 公平锁 ...

  6. 主流消息队列rocketMq,rabbitMq比对使用

    首先整理这个文章是因为我正好有机会实战了一下rocketmq,阿里巴巴的一个开源消息中间件.所以就与以往中rabbitmq进行小小的比较一下.这里主线的根据常见面试问题进行整理. 一.消息队列常用的场 ...

  7. CSP2019爆零记

    Upd:2019.10.19 初赛 Day 0 CSP-S膜你赛(然而只考一个小时xs) 写(xia)完(xie)有51.5 很虚,很慌 不过CSP-J的模拟有90?(所以CSP-S模拟的码风怎么这么 ...

  8. 非线性支持向量机SVM

    非线性支持向量机SVM 对于线性不可分的数据集, 我们引入了核(参考:核方法·核技巧·核函数) 线性支持向量机的算法如下: 将线性支持向量机转换成非线性支持向量机只需要将变为核函数即可: 非线性支持向 ...

  9. Spring加载xml配置文件的方式

    梳理Spring的流程 xml是最常见的spring 应用系统配置源.Spring中的几种容器都支持使用xml装配bean,包括: XmlBeanFactory,ClassPathXmlApplica ...

  10. JavaScript 的 URL 对象是什么?

    如果我们自己编写从URL中分析和提取元素的代码,那么有可能会比较痛苦和麻烦.程序员作为这个社会中最“懒”的群体之一,无休止的重复造轮子必然是令人难以容忍的,所以大多数浏览器的标准库中都已经内置了URL ...