• 行为驱动模型-Behave


    行为驱动开发英文名为Behave Driven Development,简称BDD,是一种敏捷开发方法,主要是从用户的需求出发强调系统行为。将此模型借鉴到自动化测试中称其为行为驱动测试模型,它是一种通过使用自然描述语言确定自动化测试脚本的模型。也就是说,用例的写法基本和功能测试用例的写法类似,具有良好协作的益处。这种测试模型使每个人都可以参与到行为开发中,而不仅仅是程序员。每个测试场景都是一个独立的行为,以避免重复,并且已有的行为可以重复使用。

    目前在Python中最流行的 BDD 框架是Behave(这也是我们本节要讲解的重点),它与其他基于 Gherkin 的 Cucumber 框架非常相似,当然还有其他BDD框架,比如pytest-bdd和radish等。

    1、安装Behave

    Behave是Python语言的一个库,在使用时需要导入行为库Behave,可以使用Python的导入第三方库命令安装Behave,即pip install behave。

    C:UsersTynamYang>pip install behave
    Collecting behave
      Downloading https://files.pythonhosted.org/packages/a8/6c/ec9169548b6c4cb877aaa6773408ca08ae2a282805b958dbc163cb19822d/behave-1.2.6-py2.py3-none-any.whl (136kB)
         100% |██████████████████████████████████| 143kB 139kB/s
    Requirement already satisfied: six>=1.11 in c:users	ynamyangappdatalocalprogramspythonpython37-32libsite-packages (from behave) (1.13.0)
    Collecting parse-type>=0.4.2
      Downloading https://files.pythonhosted.org/packages/1b/81/2a168b41acb57f1ea8e1e09937f585a0b9105557b13562ff8655fea81c09/parse_type-0.5.2-py2.py3-none-any.whl
    Collecting parse>=1.8.2
      Downloading https://files.pythonhosted.org/packages/4a/ea/9a16ff916752241aa80f1a5ec56dc6c6defc5d0e70af2d16904a9573367f/parse-1.14.0.tar.gz
    Installing collected packages: parse, parse-type, behave
        Running setup.py install for parse ... done
    Successfully installed behave-1.2.6 parse-1.14.0 parse-type-0.5.2
    
    C:UsersTynamYang>

    安装完成后可以使用命令behave --lang-list查看支持的语言:

    C:UsersTyanmYang>behave --lang-list
    Languages available:
    ar: العربية / Arabic
    bg: български / Bulgarian
    ca: català / Catalan
    cs: Česky / Czech
    cy-GB: Cymraeg / Welsh
    da: dansk / Danish
    de: Deutsch / German
    en: English / English
    en-Scouse: Scouse / Scouse
    en-au: Australian / Australian
    en-lol: LOLCAT / LOLCAT
    en-pirate: Pirate / Pirate
    en-tx: Texan / Texan
    eo: Esperanto / Esperanto
    es: español / Spanish
    et: eesti keel / Estonian
    fi: suomi / Finnish
    fr: français / French
    gl: galego / Galician
    he: עברית / Hebrew
    hr: hrvatski / Croatian
    hu: magyar / Hungarian
    id: Bahasa Indonesia / Indonesian
    is: Íslenska / Icelandic
    it: italiano / Italian
    ja: 日本語 / Japanese
    ko: 한국어 / Korean
    lt: lietuvių kalba / Lithuanian
    lu: Lëtzebuergesch / Luxemburgish
    lv: latviešu / Latvian
    nl: Nederlands / Dutch
    no: norsk / Norwegian
    pl: polski / Polish
    pt: português / Portuguese
    ro: română / Romanian
    ru: русский / Russian
    sk: Slovensky / Slovak
    sr-Cyrl: Српски / Serbian
    sr-Latn: Srpski (Latinica) / Serbian (Latin)
    sv: Svenska / Swedish
    tr: Türkçe / Turkish
    uk: Українська / Ukrainian
    uz: Узбекча / Uzbek
    vi: Tiếng Việt / Vietnamese
    zh-CN: 简体中文 / Chinese simplified
    zh-TW: 繁體中文 / Chinese traditional
    C:UsersTyanmYang>

    在编写测试用例时需要依靠这些关键字,下面会做具体说明。

    2、Behave的使用

    我们以登录页面为例说明Behave的使用。因为行为驱动模型主要在国外运用,国内使用的还比较少,所以本节只做成功登录测试的示例演示。

    1.搭建工程结构

    首先,搭建一个基本的行为驱动工程结构,如图所示。

     

    说明:

    l  features:存放场景文件。

    l  steps:features目录下场景 .feature文件对应的执行文件。

    l  environment.py:环境配置文件。

    l  report:存放测试报告文件。

    l  result:存放测试数据JSON文件。

    工程中各个目录的作用将会在下文做具体说明。

     

    2.编写feature文件

    在features目录下新建login. feature文件,作为登录场景测试用例,在文件中编写测试用例。

    根据登录的操作步骤,测试用例可写成如下的形式:

    Feature: 登录功能测试
    
        Scenario: 进入登录页面
            When 打开登录页面【url】
            Then 进入登录页面
    
        Scenario: 用户成功登录
            When 输入邮箱地址【邮箱地址】和密码【密码】并且登录
            Then 登录成功

    上面示例中用到的关键字说明如下:

    l  Feature:功能测试名称

    l  Scenario:场景名称

    l  When:可以理解为测试步骤

    l  Then:预期结果

    在测试场景中经常还会用到given(测试前提条件)和and(测试步骤和when类似)关键字。上面示例中的【url】、【邮箱地址】和【密码】是动态变化的,所以需要以参数的形式传入。

    3.配置enviroment.py文件

    environment.py文件主要用来定义一些测试执行前后的操作,比如启动和退出浏览器,类似于单元测试框架里的测试前置条件setUp和测试销毁tearDown。例如,before_step(context, step) 和after_step(context, step) 是在每一个测试步骤之前和之后执行一次;before_scenario(context, scenario)和after_scenario(context, scenario) 是在每一个测试场景之前和之后执行一次;before_feature(context, feature)和after_feature(context, feature)是在每一个测试feature文件之前和之后执行一次;before_all(context) 和after_all(context) 是在所有的测试之前和之后执行一次。

    针对本示例,在测试feature文件之前和之后添加预置条件和测试销毁内容。使用方法before_feature(context, feature) 添加测试用例执行前的操作,使用方法after_feature(context, feature) 添加测试用例执行后的操作。

    # -*- coding: utf-8 -*-
    
    from selenium import webdriver
    
    
    def before_feature(context, feature):
        context.driver = webdriver.Chrome()
        context.driver.maximize_window()
    
    def after_feature(context, feature):
        context.driver.quit()

    上述代码,将浏览器启动并且最大化放在测试用例执行前的方法before_featrue中,将退出浏览器放在测试用例执行后的方法after_featrue中。在函数中有一个参数context,用于存储信息以及在不同的step中分享信息,可以理解为超级全局变量。 context在given、when和then三个level中都会运行,并且由Behave自动管理。

    4.编写steps

    在steps目录下新建login_steps.py文件,用于存放登录页面的操作,且所有的测试steps都必须放在steps目录下,命名没有要求。steps是通过修饰符来进行匹配的,修饰符是一串字符串,如果feature文件中scenario下使用的关键字和字符串与steps中某一个step关键字和字符串一致,则执行对应的step下的函数。

    如下代码定义了打开登录页面{url}、进入登录页面、输入邮箱地址{email}和密码{password}并且登录,登录成功4个step,与feature文件中操作步骤的语言字符串相匹配。

    # -*- coding: utf-8 -*-
    
    import time
    from behave import *
    
    
    @When('打开登录页面"{url}"')
    def step_open(context, url):
        context.driver.get(url)
        time.sleep(10)
    
    @Then('进入登录页面')
    def step_assert_open(context):
        title = context.driver.title
        assert title == "第一个项目"
    
    @When('输入邮箱地址"{email}"和密码"{password}"并且登录')
    def step_login(context, email, password):
        time.sleep(1)
        email_element = context.driver.find_element_by_id('email')
        email_element.send_keys(email)
    
        time.sleep(1)
        password_element = context.driver.find_element_by_name('password')
        password_element.send_keys(password)
    
        time.sleep(1)
        login_button_element = context.driver.find_element_by_id('btn-login')
        login_button_element.click()
    
    @Then('登录成功')
    def step_assert_login(context):
        time.sleep(1)
        login_text = context.driver.switch_to.alert.text
        assert login_text == "登录成功"

    修饰符@given、@when、@then下的方法名以step_xxx命名方式实现,传递参数以大括号{参数名}来表示,当然还可以使用正则表达式来匹配。

    根据steps的操作修改feature文件,给对应的参数赋值,结果如下:

    Feature: 登录功能测试
    
        Scenario: 进入登录页面
            When 打开登录页面" http://localhost:63342/projectAutoTest/projectHtml/chapter1/period2/index.html"
            Then 进入登录页面
    
        Scenario: 用户成功登录
            When 输入邮箱地址"tynam@test.com"和密码"123"并且登录
            Then 登录成功

    3、运行

    在命令行模式下进入到BddTest目录,直接运行behave命令,结果如下:

    C:UsersTynamYangBddTest>behave
    Feature: 登录功能测试 # login.feature:1
    
      Scenario: 进入登录页面                                                                                      # login.feature:3
        When 打开登录页面"http://localhost:63342/projectAutoTest/projectHtml/chapter1/period2/index.html" # steps/login_steps.py:7 10.403s
        Then 进入登录页面                                                                                         # steps/login_steps.py:13 0.011s
    
      Scenario: 用户成功登录                          # login.feature:7
        When 输入邮箱地址"tynam@test.com"和密码"123"并且登录 # steps/login_steps.py:19 3.408s
        Then 登录成功                               # steps/login_steps.py:34 1.008s
    
    1 feature passed, 0 failed, 0 skipped
    2 scenarios passed, 0 failed, 0 skipped
    4 steps passed, 0 failed, 0 skipped, 0 undefined
    Took 0m14.830s
    C:UsersTynamYangBddTest>

    从运行结果中可以看出:

    (1)测试功能Feature以及测试场景Scenario和测试步骤When、Then。

    (2)测试每一步骤的耗时时间,总的耗时时间。

    (3)每一个行代码在哪个文件中的哪一行。

    (4)测试结果统计,即feature、scenarios、steps通过、失败及跳过。

     4、生成测试报告

    Behave库可以很好地与Allure结合生成测试报告,操作也很简单,在本书6.6 Allure测试报告一节中有过详细说明,使用方法都是相同的,在此就不做详细说明。

    生成测试报告时需要导入allure-behave,使用pip命令:

    pip install allure-behave

    使用命令生成JSON格式的测试数据并保存在result目录下,即behave -f allure_behave.formatter:AllureFormatter -o result ./features。

    C:UsersTynamYangBddTest>behave -f allure_behave.formatter:AllureFormatter -o result ./features
    1 feature passed, 0 failed, 0 skipped
    2 scenarios passed, 0 failed, 0 skipped
    4 steps passed, 0 failed, 0 skipped, 0 undefined
    Took 0m14.876s
    C:UsersTynamYangBddTest>

    在result目录下生成JSON数据文件,如图11-3所示。

    使用命令将result目录下的JSON格式的测试数据转换成测试报告并且保存在report目录下:allure generate ./result/ -o ./report/ --clean

    C:UsersTynamYangBddTest>allure generate ./result/ -o ./report/ --clean
    Report successfully generated to ./report
    C:UsersTynamYangBddTest>

    在report目录下生成测试报告文件,如图11-4所示。

    打开index.html查看生成的测试报告,如图11-5所示。

    以上内容来源于《Python Web自动化测试入门与实战,从入门到入行》第11章第七节

    读书购买地址:https://item.jd.com/12656245.html

     

  • 相关阅读:
    week02 线性表
    week01绪论
    第一周作业
    C语言第二次实验作业
    C语言实验报告
    博客作业06--图
    博客作业05--查找
    博客作业04--树
    博客作业03--栈和队列
    博客作业2---线性表
  • 原文地址:https://www.cnblogs.com/tynam/p/13441495.html
Copyright © 2020-2023  润新知