来自T先生

今天我们开始讲讲behave的厉害的地方。

Tag文件的使用

在behave里面,如何来控制哪些case需要run,哪些case不需要run,这个时候就用Tag来控制。好了,接下来我用Tag文件来实现同一个脚本可以用firefox,chrome和ie三种不同的浏览器来测试。

一、在feature文件里面新建example04文件,然后新建environment.py文件,代码如下:

from selenium import webdriver  
import sys

def
before_all(context):
    reload(sys)
  
 sys.setdefaultencoding('utf-8')
    context.baidu_url =
'http://www.baidu.com'
    
def before_tag(context, tag):
    if
tag.startswith("browser."):
        browser_type = tag.replace("browser.",
"", 1)
        if browser_type == "firefox":
           context.driver =
webdriver.Firefox()
        elif browser_type == "chrome":
          
context.driver = webdriver.Chrome()
        else:
          
context.driver = webdriver.Ie()

def after_tag(context, tag):
   
context.driver.close()

二、在example04文件夹里面新建example04.feature文件,代码如下:

Feature:Search behave results in baidu
    
  
 @browser.firefox
    Scenario: Search behave results in baidu with firefox
browser
        Given Access baidu website
        When Input behave
characters
        Then There are more than 1 results displaying
      
 
    @browser.chrome
    Scenario: Search behave results in baidu with
chrome browser
        Given Access baidu website
        When Input
behave characters
        Then There are more than 1 results displaying
  
     
    @browser.ie
    Scenario: Search behave results in baidu with ie
browser
        Given Access baidu website
        When Input behave
characters
        Then There are more than 1 results displaying

三、在example04文件夹里面新建steps文件夹,然后在steps文件夹里面新建example04.py, 代码如下:

# This Python file uses the following encoding: utf-8
#../feature/example04/steps/example04.py

from selenium import
webdriver
from selenium.webdriver.support.ui import WebDriverWait
from
selenium.webdriver.support import expected_conditions
from
selenium.webdriver.common.by import By

@Given('Access baidu
website')
def step_impl(context):
  
 context.driver.get(context.baidu_url)

@when('Input behave
characters')
def step_impl(context):
    context.ele_input =
context.driver.find_element_by_xpath("//input[@id = 'kw']")
  
 context.ele_input.send_keys("behave")
    context.ele_btn =
context.driver.find_element_by_xpath("//input[@id = 'su']")
  
 context.ele_btn.click()
    
@Then('There are more than 1 results
displaying')
def step_impl(context):
    context.sign_link =
WebDriverWait(context.driver, 60).until(
           
expected_conditions.presence_of_element_located((By.CSS_SELECTOR,
"div.nums")))
    context.ele_results =
context.driver.find_element_by_css_selector("div.nums")
  
 context.expected_results = '相关结果'
    if context.expected_results in
context.ele_results.text:
        assert True
    else:
        assert
False

四、打开cmd,cd到相应的路径,然后输入behave,你会发现代码分别会在firefox, chrome和IE中分别执行。
但是如果你想要只在firefox中执行,你可以使用命令 behave
--tags=browser.firefox
,然后你会发现仅仅打开了firefox。

扩展: 通过tag, 你可以给一个scenario加上N个tag, 每个tag之间用空格隔开就ok,
这样的的话你也可以给scenario加上regression使其变成回归测试的。

除了给scenario加上tag,你还可以给feature加上tag. 
behave的脚本都是会把所有的feature文件放在同一个feature文件夹目录下面,然后会在steps里面放所有feature文件对应的py文件。

然后最终的基本目录是这样子的。

Behave + Selenium(Python) 四的更多相关文章

  1. Behave + Selenium(Python) 三

    来自T先生 通过之前的2篇文章,大家都了解了如果利用behave和selenium打开网页和进行基本的操作,但是这些对于项目来说,却是往往不够的. 如果对junit或者TestNG熟悉的人都知道有@B ...

  2. Behave + Selenium(Python) 二

    介绍feature, py文件和之间关系: example01.feature文件包括5行: Feature行: 介绍这个feature用来干什么的: Scenario行:介绍这个scenario用来 ...

  3. Behave + Selenium(Python)一:

    Behave 介绍:(来自T先生) 最近一个项目用了behave来做测试,因为之前没有接触过,所以写下最近的心得总结. 做自动化的人估计对selenium已经不是很陌生了,但是对于Behave工具,估 ...

  4. selenium+python环境的搭建的自动化测试

    一.安装python: 我安装的是2.7.13版本的:可以在CMD下 运行python命令查看是否安装python,以及安装版本: 在https://www.python.org/getit/这个地址 ...

  5. selenium python grid

    学习自动化一直都是在本机操作,感觉这样能够减少工作量确实很少.最近研究了一下分布式操作. 开始的想法是,我在一台机器上启动脚本,然后让脚本在不同机器的不同版本的浏览器上进行跑脚本. 需要准备的东西: ...

  6. python爬虫积累(一)--------selenium+python+PhantomJS的使用(转)

    阅读目录 一.Selenium介绍 二.爬虫为什么要用selenium? 三.PhantomJS介绍 四.PhantomJS安装 五.操作实战 六.在此推荐虫师博客的学习资料 selenium + p ...

  7. 自动化测试基础篇--Selenium Python环境搭建

    学习selenium python需要的工具: 1.浏览器 2.Python 3.Selenium 4.FireBug(Firefox) 5.chromedriver.IEDriverServer.g ...

  8. python爬虫积累(一)--------selenium+python+PhantomJS的使用

    最近按公司要求,爬取相关网站时,发现没有找到js包的地址,我就采用selenium来爬取信息,相关实战链接:python爬虫实战(一)--------中国作物种质信息网 一.Selenium介绍 Se ...

  9. 引用 自动化测试基础篇--Selenium Python环境搭建

    原文链接:https://www.cnblogs.com/sanzangTst/p/7452922.html 鸣谢参藏法师. 学习selenium python需要的工具: 1.浏览器 2.Pytho ...

随机推荐

  1. markdownPad2 绿色破解版安装

    markdownpad2,默认为markdown传统风格,不能编辑分行的代码段,可以在设置里改为Github 风格,但需要付费激活,以下是绿色安装包,附激活方法 下载地址 https://pan.ba ...

  2. 数据挖掘、目标检测中的cnn和cn---卷积网络和卷积神经网络

    content 概述 文字识别系统LeNet-5 简化的LeNet-5系统 卷积神经网络的实现问题 深度神经网路已经在语音识别,图像识别等领域取得前所未有的成功.本人在多年之前也曾接触过神经网络.本系 ...

  3. VI使用说明 (转)

    vi使用方法(ZT)         vi编辑器是所有Unix及Linux系统下标准的编辑器,它的强大不逊色于任何最新的文本编辑器,这里只是简单地介绍一下它的用法和一小部分指令.由于对Unix及Lin ...

  4. ios中实现对UItextField,UITextView等输入框的字数限制

    本文转载至 http://blog.sina.com.cn/s/blog_9bf272cf01013lsd.html 2011-10-05 16:48 533人阅读 评论(0) 收藏 举报 1.    ...

  5. Filebeat+ELK

    Filebeat+ELK filebeat是logstash的升级版,从功能上来说肯定不如logstash,但是logstah比较耗费资源: filebeat安装 暂时依托于window系统 下载fi ...

  6. Vue中div高度自适应

    Vue中尽量不使用dom的高度计算 <template> <div :style="conheight"> </template> <sc ...

  7. 性能测试--初识Jmeter

    初识Jmeter Apache JMeter是Apache组织开发的基于Java的压力测试工具.用于对软件做压力测试,它最初被设计用于Web应用测试,但后来扩展到其他测试领域. 它可以用于测试静态和动 ...

  8. ABAP 设置单元格颜色

    http://blog.163.com/ronanchen@126/blog/static/172254750201161811040488/ http://blog.csdn.net/lhx20/a ...

  9. 【shell】判断一个变量是否为空

    #!/bin/bash argv=" if [ -z "$argv" ] then echo "argv is empty" else echo &q ...

  10. Docker实践中遇到的坑

    1.docker容器中后台运行退出执行curl+p+q,再次进入执行命令docker attach 容器id. 2.容器中exit退出后,还原方法为docker ps -a 查看历史运行容器,dock ...