接口自动化测试框架搭建(7、连接数据库提交sql方法以及打印日志方法封装)--python+HTMLTestRunnerCN+request+unittest+mock+db

基于之前文章:

1、环境的搭建:https://blog.csdn.net/Mojitoice/article/details/108992622?spm=1001.2014.3001.5501

2、配置文件的创建,封装配置文件的读取方法:https://blog.csdn.net/Mojitoice/article/details/109031074

3、excel读取方法的封装:https://blog.csdn.net/Mojitoice/article/details/109203605?spm=1001.2014.3001.5501

4、url拼接方法的封装:https://blog.csdn.net/Mojitoice/article/details/114400695

5、封装get,post请求方法:https://blog.csdn.net/Mojitoice/article/details/114402767

6、进行mock的方法封装:https://blog.csdn.net/Mojitoice/article/details/114403473

 

背景:

我们搞接口自动化测试框架,对数据库的操作必不可少,比如对比接口返回的数据是否正确,再某些请求参数需要从数据库中取,所以我们需要封装一个对数据库操作的方法。我这里只做了简单的封装。

now,献上代码:/Users/dongyue/Documents/framework/common/configDB.py

import pymysql
from testFile.readConfig import ReadConfig
from common.log import logger



class GetMysql():


    def __init__(self,dbname):
        #读取配置文件中需要的数据库(不同的需求需要链接不同的数据库,所以需要有数据库名字的入参)
        self.username = ReadConfig().get_db(dbname,"username")
        self.password = ReadConfig().get_db(dbname,"password")
        self.host = ReadConfig().get_db(dbname,"host")
        self.port = ReadConfig().get_db(dbname,"port")

    def connectdb(self):
        #连接数据库,创建游标对象
        con = pymysql.connect(host=self.host,
                               port=int(self.port),
                               user=self.username,
                               password=self.password,
                               charset="utf8",
                               cursorclass=pymysql.cursors.DictCursor
                               )
        cur = con.cursor()
        return cur

    def getone(self,sql):
        #提交sql语句。获取第一条返回结果
        try:
            cur = self.connectdb()
            cur.execute(sql)
            return cur.fetchone()
        except pymysql.Error as e:
            logger.debug("sql提交失败",e)

    def getall(self,sql):
        # 提交sql语句。获取全部返回结果,以列表形式返回
        try:
            cur = self.connectdb()
            cur.execute(sql)
            return cur.fetchall()
        except pymysql.Error as e:
            logger.debug("sql提交失败",e)



if __name__ == '__main__':
    print("ok")

在代码中读取了配置文件中数据库的配置:

[ecqc_DB]
username = ecqc_w
password = 0Oe*I*****iFIUt02CB
host = 10.225.76.*
port = 3306

数据库的操作,不要忘记try一下哈。其中的log.py。/Users/dongyue/Documents/framework/common/log.py

#作用:生成log方法,写入/result/logfile下
import os
import logging
from logging.handlers import TimedRotatingFileHandler
from getPath import GetPath

path = GetPath().getPath()
log_path = os.path.join(path, 'result/logfile')  # 存放log文件的路径


class Logger(object):
    def __init__(self, logger_name='logs…'):
        self.logger = logging.getLogger(logger_name)
        logging.root.setLevel(logging.NOTSET)
        self.log_file_name = 'logs'  # 日志文件的名称
        self.backup_count = 5  # 最多存放日志的数量
        # 日志输出级别
        self.console_output_level = 'WARNING'
        self.file_output_level = 'DEBUG'
        # 日志输出格式
        self.formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')

    def get_logger(self):
        """在logger中添加日志句柄并返回,如果logger已有句柄,则直接返回"""
        if not self.logger.handlers:  # 避免重复日志
            console_handler = logging.StreamHandler()
            console_handler.setFormatter(self.formatter)
            console_handler.setLevel(self.console_output_level)
            self.logger.addHandler(console_handler)

            # 每天重新创建一个日志文件,最多保留backup_count份
            file_handler = TimedRotatingFileHandler(filename=os.path.join(log_path, self.log_file_name), when='D',
                                                    interval=1, backupCount=self.backup_count, delay=True,
                                                    encoding='utf-8')
            file_handler.setFormatter(self.formatter)
            file_handler.setLevel(self.file_output_level)
            self.logger.addHandler(file_handler)
        return self.logger


logger = Logger().get_logger()

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Pythonunittest库提供了一种基于单元测试的测试框架,是一个方便易用的Python测试框架。使用unittest库进行接口自动化测试可以提高测试效率和质量,本文将分享如何使用Python unittest搭建接口自动化测试框架。 第一步:安装Python unittest库 首先需要安装Python unittest库,Python unittest库是默认安装在Python中的,无需单独安装。 第二步:安装requests模块 接口自动化测试需要使用requests模块来发送HTTP请求、获取响应等操作,因此需要安装requests模块。使用pip安装requests命令如下: pip install requests 第三步:编写测试用例 使用unittest框架编写测试用例,首先需要导入unittest库并创建测试类,编写测试方法方法名必须以test开头,并使用assert断言方法进行验证。例如: import unittest import requests class TestApi(unittest.TestCase): def test_get_users(self): url = 'http://localhost:8080/api/users' res = requests.get(url) self.assertEqual(res.status_code, 200) self.assertIsNotNone(res.json()) 第四步:执行测试用例 使用unittest框架执行测试用例,使用unittest.main()方法运行所有测试用例。例如: if __name__ == '__main__': unittest.main() 执行测试用例后,将输出测试结果,包括测试用例总数、成功数、失败数等。 第五步:持续集成 持续集成可以帮助实现自动化测试,可以将上述步骤集成到自动化测试框架中,提高测试效率和质量。使用持续集成工具,例如Jenkins,可以实现自动化测试的调度和执行,定期输出测试报告,是测试自动化化的不二选择。 在以上步骤中,请求地址和验证方法需要根据具体需求进行更改,但是编写测试用例的方法是类似的,熟练掌握unittest库可以快速搭建接口自动化测试框架,提高测试效率和质量。 ### 回答2: Python unittest requests 接口自动化测试框架搭建教程博客是指一篇博客文章,介绍如何使用Python unittestrequests库搭建接口自动化测试框架。该教程博客有如下几个方面: 1. 简单介绍Python unittestrequests库,以及它们在接口自动化测试中的使用; 2. 详细讲解如何安装Python unittestrequests库,并编写测试用例; 3. 讲解如何通过使用Python unittest的setUp()和tearDown()方法,在测试用例执行前后进行一些操作,以便更好地进行测试; 4. 介绍如何运行测试用例,并查看测试结果,以及如何进行测试报告生成; 5. 提供一些实例,展示如何使用Python unittestrequests库搭建接口自动化测试框架。 通过这篇教程博客,读者可以学习如何使用Python unittestrequests库搭建接口自动化测试框架,并且能够快速了解并掌握这种接口自动化测试方法的流程和基本方法。此外,该教程博客也提供一些实例,帮助读者更好地理解和应用这种方法。因此,这篇教程博客对于想要学习接口自动化测试以及深入了解Python unittestrequests库的读者来说,是一篇非常有价值的文章。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值