学习搭建api自动化测试框架(pytest):python3+request+allure(一)

最近学习python的接口自动化,看了许多,决定使用pytest框架,还有好看的测试报告,在网上看到有介绍较完整的测试框架,在此基础上修改成符合自己习惯的方式,不需要的删去等等,学习中遇到很多坑,在此记录一下几个印象深刻的问题,附上参考学习的框架:https://www.jianshu.com/p/e31c54bf15ee

1.环境安装,安装python3后,需要安装的模块:

pytest
PyYAML
requests
configparser
allure-pytest
requests-toolbelt
pytest-rerunfailures

2.参考文章中对于框架的各个模块已做介绍。

3.学习中,遇到的坑:

1)Session.py中获取cookie时:response.cookies.get_dict() 在调试时总是返回空,后修改为:

login_url = 'http://' + self.config.loginHost_release
parm = self.config.loginInfo_release  # 这是从配置文件里取到的参数类型为str

session_debug = requests.session()
# 前面的parm需要转为dict,否则cookie为空
response = session_debug.post(login_url, eval(parm), headers=headers)
cookies = requests.utils.dict_from_cookiejar(session_debug.cookies)
self.log.debug('cookies: %s' % cookies)
return cookies

2)通过yaml文件获取接口参数后,通过request.py发送请求,总是返回url异常,原因是从yaml文件里获取的接口参数data格式有问题,原yaml文件:

Basic:
  dec: "基础设置"
  parameters:
    -
      url: /postLogin
      data:
        -
          email: wangjuan@user.com
          password: 123456
          auth: admin
      header: {
                 "User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_6) AppleWebKit/537.36 (KHTML, like Gecko)\
                  Chrome/67.0.3396.99 Safari/537.36",
                 "Content-Type": "application/x-www-form-urlencoded"
              }

注意上面data下面的“-”,在yaml里代表list,获取后返回的为:[[{'canshu1':'value1', 'canshu2':'value2'}]],有两个[],而在TestCase下的测试用例里取参数时为:response = request.get_request(api_url, params[0], headers[0]),而params[0]为[{'canshu1':'value1', 'canshu2':'value2'}],还有一个[],不是dict形式,所以请求失败,params[0]修改为params[0][0],或者,将yaml文件修改为:

# 去掉-,为dict形式
data:
  email: wangjuan@user.com
  password: 123456
  auth: admin

3)request.py中,def __init__(self, env): 有个参数env,在Testcase里的测试用例中调用request时,为request = Request.Request(action),action为测试用例的参数,,在conftest.py中定义好的测试环境(config.ini中的debug或release环境),将“debug”或“release”作为action传入测试用例,在request时获取特定环境的cookie。

4)生成allure报告时,只能执行一次,第二次执行后,html里的index.html内容其实是上一次的内容,用终端命令

allure generate ./Report/xml -o ./Report/html

调试后发现,报错:

Allure: Target directory ./Report/html for the report is already in use, add a '--clean' option to overwrite

意思是需要在执行前清空上一次的报告,因此,在run.py里,将生成报告的命令改为如下:每次运行前将上一次的xml和html报告都清空。

# 定义测试集
# --clean-alluredir清空上一次的xml报告
args = ['-s', '-q', 'TestCase/test_Case.py', '--alluredir', xml_report_path, '--clean-alluredir']    
pytest.main(args)    
# --clean清空上一次的html报告
cmd = 'allure generate %s -o %s --clean' % (xml_report_path, html_report_path)  
shell.invoke(cmd)

5)生成的html报告在本地打开全是404,但通过pycharm在浏览器打开就没问题,原因还未找到,有大神知道望解答。

本地直接用浏览器打开:

通过pycharm在浏览器打开:

6)未研究框架中的email模块,需要时在学习

7)allure有很丰富的用法,后续继续研究如何丰富测试用例,比如接口依赖,场景测试等。

  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,我会继续回答你的问题。 在上一个问题中,我们已经介绍了如何使用 pytest 和 Page Object 模式编写自动化测试框架。在这个问题中,我们将介绍如何使用 Allure 生成测试报告。 Allure 是一个测试报告生成工具,它可以生成漂亮、交互式的测试报告,支持多种语言和测试框架。 下面是使用 Python + pytest + Page Object 模式 + Allure 编写自动化测试框架的步骤: 1. 安装 pytest、selenium 和 allure-pytest 库 使用以下命令安装: ``` pip install pytest selenium pytest-allure-adaptor ``` 2. 创建测试用例 在项目中创建一个 test 目录,然后在该目录下创建一个 test_example.py 文件,编写测试用例。 例如: ```python import pytest from pages.login_page import LoginPage @pytest.mark.usefixtures("setup") class TestLogin: def test_valid_login(self): login_page = LoginPage(self.driver) login_page.login("username", "password") assert "Welcome" in login_page.get_title() def test_invalid_login(self): login_page = LoginPage(self.driver) login_page.login("invalid_username", "invalid_password") assert "Invalid username or password" in login_page.get_error_message() ``` 在上面的示例中,我们使用了 pytest 的装饰器 @pytest.mark.usefixtures("setup"),它用于指定测试用例执行前的前置条件。 我们还使用了 Page Object 模式,将登录页面的操作封装在了 LoginPage 类中。 3. 创建页面对象 在项目中创建一个 pages 目录,然后在该目录下创建一个 login_page.py 文件,编写 LoginPage 类。 例如: ```python from selenium.webdriver.common.by import By class LoginPage: def __init__(self, driver): self.driver = driver self.username_input = (By.ID, "username") self.password_input = (By.ID, "password") self.login_button = (By.ID, "login_button") self.error_message = (By.ID, "error_message") def login(self, username, password): self.driver.find_element(*self.username_input).send_keys(username) self.driver.find_element(*self.password_input).send_keys(password) self.driver.find_element(*self.login_button).click() def get_title(self): return self.driver.title def get_error_message(self): return self.driver.find_element(*self.error_message).text ``` 在上面的示例中,我们使用了 Selenium 的 By 模块来定位页面元素,将页面元素的定位与操作分离开来,使得测试脚本更加简洁、易于维护。 4. 创建 conftest.py 文件 在项目根目录下创建一个 conftest.py 文件,用于定义测试固件。 例如: ```python import pytest from selenium import webdriver from selenium.webdriver.chrome.options import Options @pytest.fixture(scope="session") def setup(request): chrome_options = Options() chrome_options.add_argument("--headless") driver = webdriver.Chrome(options=chrome_options) driver.maximize_window() request.cls.driver = driver yield driver.quit() ``` 在上面的示例中,我们使用了 pytest 的装饰器 @pytest.fixture,它用于定义测试固件。在该示例中,我们定义了一个名为 setup 的测试固件,它会在测试用例执行前启动 Chrome 浏览器,并将 driver 对象传递给测试用例。 我们还使用了 Selenium 的 ChromeOptions 类来设置 Chrome 浏览器的无头模式。 5. 运行测试用例 在项目根目录下打开终端,运行以下命令: ``` pytest --alluredir=allure-report test/ ``` 其中,--alluredir 表示生成 Allure 报告所需要的数据文件。 6. 生成测试报告 在终端中运行以下命令: ``` allure serve allure-report ``` 该命令会在浏览器中打开 Allure 报告。 完成上述步骤后,我们就可以编写一个完整的自动化测试框架了,同时使用 Allure 生成漂亮、交互式的测试报告。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值