元素的定位

id定位 find_element_by_id("kw") 注:有些id值动态变化

class_name定位 find_element_by_class_name("s_ipt") 注:classname有可能重复

tag_name定位 find_element_by_tag_name("input") 注:tagname最容易重复

name定位 find_element_by_name("wd") 注:name有可能重复

link文字精确定位 find_element_by_link_text("登录")

link文字模糊定位 find_element_by_partial_link_text("登")

CSS定位

标签名定位 find_element_by_css_selector("input")

id定位 find_element_by_css_selector("#kw")

class定位 find_element_by_css_selector(".s_ipt")

属性定位 find_element_by_css_selector("[name=‘wd‘]") find_element_by_css_selector("[maxlength=‘255‘]")

父子定位 find_element_by_css_selector("span>input")

组合定位 右击-复制-CSS路径 find_element_by_css_selector("input#kw") find_element_by_css_selector("input.s_ipt") find_element_by_css_selector("input[name=‘wd‘]") find_element_by_css_selector("span>input.s_ipt")

XPath定位 右击-复制-XPath

属性定位 find_element_by_xpath("//标签名[@属性=‘属性值‘]")

标签名定位 find_element_by_xpath("//input")

父子定位 find_element_by_xpath("//span/input")

元素内容定位 find_element_by_xpath("//标签名[contains(text(),‘内容‘)]")

组合定位 find_element_by_xpath("//input[@class=‘s_ipt‘ and @name=‘wd‘]")

webdriver对象的方法

browser.save_screenshot(‘.//baidu.png‘) 屏幕快照

切换窗口

"""

浏览器打开两个窗口,每个窗口都有控制句柄handles

handles的值是列表list,handles[0]代表第1个窗口,handles[1]代表第2个窗口

"""

handles = browser.window_handles

browser.switch_to.window(handles[1]) # 切换到第2个窗口

print(browser.title) # 打印第2个窗口的标题

# 切换到frame子页面

browser.switch_to.frame(‘iframeResult‘)

time.sleep(3)

browser.find_element_by_xpath(‘/html/body/a‘).click()

#browser.find_element_by_link_text(‘这是一个链接使用了 href 属性‘).click()

time.sleep(3)

# 切回父页面(必须执行)

browser.switch_to.default_content()

#browser.find_element_by_css_selector(‘html body a‘).click()

#time.sleep(3)

browser.quit()

警告框

browser.switch_to.frame(‘iframeResult‘)

browser.find_element_by_css_selector(‘html body input‘).click()

time.sleep(3)

info = browser.switch_to.alert.text # 显示警告框的内容

print(info)

time.sleep(3)

browser.switch_to.alert.accept() # 点击确定

#browser.switch_to.alert.dismiss() # 点击取消

time.sleep(3)

browser.quit()

下拉框

browser.switch_to.frame(‘iframeResult‘)

select_element = browser.find_element_by_name(‘cars‘)

Select(select_element).select_by_index(1) # 按索引选择

time.sleep(3)

Select(select_element).select_by_visible_text(‘Audi‘) # 按内容选择

time.sleep(3)

Select(select_element).select_by_value(‘fiat‘) # 按value属性值选择

time.sleep(3)

# is_select() 记录控件是否被选中,如果被选中,则返回true;如果没被选中,则返回false.

is_select = browser.find_element_by_name(‘cars‘).is_selected()

if is_select == False:

browser.find_element_by_name(‘cars‘).click()

time.sleep(3)

browser.quit()

悬浮框

drviver.get(‘https://www.baidu.com‘)

button = drviver.find_element_by_css_selector(‘#u1>a.bri‘)

# 将鼠标移至更多产品上

ActionChains(drviver).move_to_element(button).perform()

# 点击音乐

drviver.find_element_by_xpath(‘/html/body/div[1]/div[1]/div/div[4]/div/div[2]/div[1]/div/a[2]/span‘).click()

time.sleep(3)

drviver.quit()

显示隐藏

from selenium import webdriver

import unittest

from selenium.webdriver.support.wait import WebDriverWait

from selenium.webdriver.support import expected_conditions as EC

from selenium.webdriver.common.by import By

class Content(unittest.TestCase):

def testShow(self):

self.browser = webdriver.Chrome()

self.browser.get("https://www.baidu.com")

self.element = WebDriverWait(self.browser, 5, 1).until(EC.presence_of_element_located((By.ID, "kw")))

self.browser.quit()

def testHidden(self):

self.browser = webdriver.Chrome()

self.browser.implicitly_wait(5)

self.browser.get("https://www.baidu.com")

self.browser.quit()

if __name__ == ‘__main__‘:

unittest.main(verbosity=2)

常规参数化全过程用例(只有登录)

from selenium import webdriver

import time

import unittest

import csv

# 创建一个类继承unittest.TestCase

class Login(unittest.TestCase):

# 打开浏览器

def setUp(self) -> None:

self.browser = webdriver.Chrome()

self.browser.get("http://192.168.159.1:8082/")

# 结束关闭浏览器

def tearDown(self) -> None:

self.browser.quit()

# 参数化登录信息

def login(self, username, password):

self.browser.find_element_by_xpath("//*[@id=‘shop_header‘]/div[2]/ul/li[7]/a").click()

time.sleep(3)

self.browser.find_element_by_id("user_name").send_keys(username)

self.browser.find_element_by_id("user_password").send_keys(password)

self.browser.find_element_by_xpath("//*[@id=‘login_form‘]/div[4]/div/button[1]").click()

time.sleep(3)

def logout(self):

self.browser.find_element_by_link_text(‘退出‘).click()

def testLogin(self):

file = open("login.csv", mode="r", encoding="utf-8")

logins = csv.reader(file)

for login in logins:

try:

username = login[0]

password = login[1]

self.login(username, password)

self.assertTrue(self.browser.find_element_by_link_text("退出"))

self.logout()

except Exception as Error:

print(Error)

file.close()

if __name__ == ‘__main__‘:

unittest.main(verbosity=2)

改良版本全功能测试用例(缩短代码量)

# 登录模块

from selenium import webdriver

import unittest

import time

import csv

class Login(unittest.TestCase):

def setUp(self) -> None:

self.browser=webdriver.Chrome()

self.browser.get("http://192.168.159.1:8082/")

time.sleep(3)

def tearDown(self) -> None:

self.browser.quit()

# 定义登录带参函数

def login(self,username,password):

self.browser.find_element_by_xpath("//*[@id=‘shop_header‘]/div[2]/ul/li[7]/a").click()

time.sleep(3)

self.browser.find_element_by_id("user_name").send_keys(username)

self.browser.find_element_by_id("user_password").send_keys(password)

self.browser.find_element_by_xpath("//*[@id=‘login_form‘]/div[4]/div/button[1]").click()

time.sleep(3)

# 定义退出函数

def loginOut(self):

self.browser.find_element_by_link_text("退出").click()

# 登录成功测试

def testLoginSuccess(self):

self.login("wupeng","123456")

# 用户名为1测试

def testUserNull(self):

self.login("","123456")

# self.assertTrue(self.browser.find_element_by_xpath("//*[@id=‘login_form‘]/div[2]/div/label").text=="请输入会员登录名称!")

info=self.browser.find_element_by_xpath("//*[@id=‘login_form‘]/div[2]/div/label").text

self.assertIn("请输入会员登录名称",info)

if __name__ == ‘__main__‘:

unittest.main(verbosity=2)

# 搜索模块

from login import dbSlogin

import unittest

import time

class Search(unittest.TestCase):

myself=dbSlogin.Login

myself.setUp(myself)

myself.login(myself,"wupeng","123456")

# 输入正确搜索字段搜索

def testSearch(self):

self.myself.browser.find_element_by_xpath("//*[@id=‘shop_top_search‘]/form/div/input").send_keys("苹果")

self.myself.browser.find_element_by_xpath("//*[@id=‘shop_top_search‘]/form/div/button").click()

time.sleep(3)

self.myself.tearDown(self.myself)

if __name__ == ‘__main__‘:

unittest.main(verbosity=2)

生成报告

在测试用例文件同目录下添加9run_all_testcases.py文件

在测试用例文件同目录下添加HTMLTestReport.py文件

python自动化功能测试_python、selenium自动化功能测试相关推荐

  1. java自动化分页_Python+Selenium自动化实现分页(pagination)处理

    selenium怎么应对网页分页的情况 什么是分页?是指frame么?selenium有处理frame的机制.driver.switchTo().frame("frame name" ...

  2. 怎么用python自动注册_python selenium自动化(二)自动化注册流程

    需求:使用python selenium来自动测试一个网站注册的流程. 假设这个网站的注册流程分为三步,需要提供比较多的信息: 在这个流程里面,需要用户填入信息.在下拉菜单中选择.选择单选的radio ...

  3. python selenium自动化断言_python+selenium自动化登录测试,设计不同场景进行登录,两种方式断言,截图保存...

    # coding : utf-8 # date :2019/1/7 # 根据不同场景做自动化登录测试 # 正确账号密码.正确账户错误密码.等其他场景 from selenium import webd ...

  4. python 网页自动化框架_python+selenium自动化框架

    项目以前的UI自动化大概是这样分层的 1.Common功能层:一些经常被调用的基本常用操作,用来完成某项具体的功能,与具体的业务无关.比如常用的封装: --将元素定位方法重新封装 --封装上下左右滑动 ...

  5. python 自动点击网页上按钮_python selenium自动化(一)点击页面链接测试

    需求:现在有一个网站的页面,我希望用python自动化的测试点击这个页面上所有的在本窗口跳转,并且是本站内的链接,前往到链接页面之后在通过后退返回到原始页面. 要完成这个需求就必须实现3点: 1. 找 ...

  6. dnf自动刷图python脚本_python+selenium自动化登录dnf11周年活动界面领取奖励登录部分采坑总结[1]...

    背景: Dnf的周年庆活动之一,游戏在6月22日 06:00~6月23日 06:00之间登陆过游戏后可以于6月25日 16:00~7月04日 06:00领取奖励 目标:连续四天自动运行脚本,自动领取所 ...

  7. python自动化流程概念_python selenium 自动化流程的一些总结与思考

    首先要考虑的项目为什么要做自动化测试?(主要从自动化测试的优点着手) 其次是什么项目才适合做自动化测试? 自动化测试覆盖率要达到什么样的程度?因为都知道不可能达到100%的,不然脚本太臃肿,反而会失去 ...

  8. python接口测试框架与自动化实战_Python接口自动化从设计到开发,测试框架实战与自动化进阶视频课程...

    Python接口自动化从设计到开发,测试框架实战与自动化进阶视频课程21套高级软件测试,性能测试,功能测试,自动化测试,接口测试,移动端测试,手机测试,WEB测试,渗透测试,测试用例设计,黑盒测试,白 ...

  9. python自动化控制_python用于自动化控制编程

    Python自动化是做什么的 软件测试里面有Python自动化测试这个课程吗? 在人工智能+大数据的飞速发展的大环境下,Python开发语言日渐火爆,Python自动化测试也将逐渐取代传统的软件测试, ...

  10. android select下拉列表_Python+selenium自动化之下拉列表操作(一)

    下拉列表操作中分为两种:select.非select 非select下拉列表操作 非select下拉列表的操作与其他元素的操作一致,定位元素,设置等待,操作元素. 下面还是以腾讯邮箱为例,查看一封邮件 ...

最新文章

  1. python【蓝桥杯vip练习题库】ALGO-90出现次数最多的整数(sys)
  2. 老男孩最近几年常用的免费的开源软件
  3. java ee技术_Java EE 6与Spring Framework:技术决策过程
  4. 爱课程c语言函数2的作业答案,C语言程序设计
  5. java test20006_Java单例7种测试实践
  6. j循环赋予li id_《Science》子刊:超强Li-S电池诞生!硫负载量高达15mg·cm-2
  7. jQuery 获取当前节点的html包含当前节点的方法
  8. java list 取第一个,从Java LinkedList获取第一个和最后一个元素
  9. 一种永不止步的进取精神的勤奋
  10. html在ie浏览器中中文为什么是乱码
  11. Linux权限详解(chmod、600、644、700、711、755、777、4755、6755、7755)
  12. 2.04 标志寄存器
  13. 基于esp8266的Arduino网络时钟
  14. 如何定义对战详情的数据结构
  15. 【雷达与对抗】【2009.08】脉冲多普勒雷达系统的多普勒频率估计
  16. c语言作文的题目_高中信息技术招聘C语言编程题精选
  17. SQL Server--嵌套查询
  18. 内存计算技术应对大数据挑战
  19. OC基础学习 调用方式
  20. 基于flask框架web代码pyinstaller打包

热门文章

  1. matlab mbuild setup,关于mbuild的一个问题
  2. 【队列】队列的基本操作总结
  3. Android检查网络状态步骤
  4. 字符转换属性text-tranform改变大小写
  5. spring boot配置文件:application.yml (yml与properties文件优缺对比)
  6. python计角_最小角python算法
  7. 自动添加html结束标志,XHTML标签都有一个结束标记
  8. php去除中间空格,php删除字符串中间空格的方法
  9. java oscache 使用_OScache的使用(Java对象)
  10. spring boot security ajax_Spring 和 SpringBoot 之间到底有啥区别?