热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

python自动化测试登录_Pythonselenium自动化测试框架入门实战登录测试案例

本文为Python自动化测试框架基础入门篇,主要帮助会写基本selenium测试代码又没有规划的同仁。本文应用到POM模型、selenium、unittest框架、c

本文为Python自动化测试框架基础入门篇,主要帮助会写基本selenium测试代码又没有规划的同仁。

本文应用到POM模型、selenium、unittest框架、configparser配置文件、smtplib邮件发送、HTMLTestRunner测试报告模块结合登录案例实现简单自动化测试框架

项目主要包括以下几个部分

conif.ini 放置配置文件

例如:

myunit.py文件放置的浏览器操作代码

import unittest

from selenium import webdriver

class MyTest(unittest.TestCase):

def setUp(self):

self.driver = webdriver.Chrome()

self.driver.implicitly_wait(10)

self.driver.maximize_window()

def tearDown(self):

self.driver.quit()

if __name__=='__main__':

unittest.main()

base.py中放置浏览器对象操作代码

from selenium.webdriver.support import expected_conditions as EC

from selenium.webdriver.support.wait import WebDriverWait

import os,configparser

class Page(object):

path = os.path.dirname(os.path.abspath("."))

cfpath = os.path.join(path, 'autoparker\config\conf.ini')

conf = configparser.ConfigParser()

conf.read(cfpath)

url=conf.get('base','url')

def __init__(self,driver,url=url):

self.driver=driver

self.url=url

def open(self):

self.driver.get(self.url)

def find_element(self,*loc):#传入参数为元组需要加*,本身就是元组的不需要*

#print(*loc)

try:

WebDriverWait(self.driver,10).until(EC.visibility_of_element_located(loc))

return self.driver.find_element(*loc)

except:

print('页面中未找到 %s 元素'%(self,loc))

def find_elements(self,*loc):

return self.driver.find_elements(*loc)

def send_keys(self,loc,value):

self.find_element(*loc).send_keys(value)

def click(self,loc):

self.find_element(*loc).click()

def clear(self,loc):

self.find_element(*loc).clear()

loginpage.py中放置通用登录模块代码(尽量避免重复代码)

from selenium.webdriver.common.by importByfrom time importsleepfrom objpage.base importPageclasslogin(Page):

username_loc=(By.NAME,'accounts')

password_loc=(By.NAME,'pwd')

login_button_loc=(By.XPATH,'/html/body/div[5]/div/form/fieldset/p/button')

login_error_loc=(By.XPATH,'//*[@id="common-prompt"]/p')deflogin_username(self,username):

self.find_element(*self.username_loc).clear()

self.find_element(*self.username_loc).send_keys(username)deflogin_password(self,password):

self.find_element(*self.password_loc).clear()

self.find_element(*self.password_loc).send_keys(password)deflogin_button(self):

self.find_element(*self.login_button_loc).click()#统一登录入口

defuser_login(self,username,password):

self.open()

self.login_username(username)

self.login_password(password)

self.login_button()

sleep(2)#登录提示信息

deflogin_error_text(self):return self.find_element(*self.login_error_loc).text

parker.py中放置公共元素操作代码(parker是我随便命名的,不纠结)

from selenium importwebdriverfrom selenium.webdriver.common.action_chains importActionChainsfrom selenium.webdriver.support.select importSelectclassParker(object):def __init__(self,browser='chrome'):if browser=='ie' or browser=='internet explorer':

driver=webdriver.Ie()elif browser=='firefox' or browser=='ff':

driver=webdriver.Firefox()elif browser=='chrome':

driver=webdriver.Chrome()try:

self.driver=driverexceptException:raise NameError('没有找到浏览器,请输入"ie","chrome","ff"')def wait(self,secs=5): #隐式等待

self.driver.implicitly_wait(secs)def to_element(self,key):#元素定位

if '->' not in key: #如果key里面不包含=就执行下列语句

raise NameError('参数类型输入错误')

by=key.split('->')[0] #通过分隔获取[0]对应的值

val=key.split('->')[1]#通过分隔获取[1]对应的值

if by=='id':

element=self.driver.find_element_by_id(val)elif by=='name':

element=self.driver.find_element_by_name(val)elif by=='class':

element=self.driver.find_element_by_class_name(val)elif by=='link_text':

element=self.driver.find_element_by_link_text(val)elif by=='xpath':

element=self.driver.find_element_by_xpath(val)elif by=='css':

element=self.driver.find_element_by_css_selector(val)else:raise NameError('请输入正确的定位方式:id,name,class,link_text,xpath,css')returnelementdef open(self,url):#打开一个URL

self.driver.get(url)def max_window(self):#最大化窗口(浏览器)

self.driver.maximize_window()def set_windows(self,wide,high):#设置窗口大小

self.driver.set_window_size(wide,high)def input(self,key,text):#对文本框进行输入

el=self.to_element(key)

el.send_keys(text)def click(self,key):#点击

el=self.to_element(key)

el.click()def clear(self,key):#清除文本框内容

el=self.to_element(key)

el.clear()def right_click(self,key):#右键操作

el=self.to_element(key)

ActionChains(self.driver).context_click(el).perform()def move_to_element(self,key):#鼠标悬停

el=self.to_element(key)

ActionChains(self.driver).move_to_element(el).perform()def drag_and_drop(self,el_key,ta_key):#拖拽 从一个元素拖到另外一个元素

el=self.to_element(el_key)

target=self.to_element(ta_key)

ActionChains(self.driver).drag_and_drop(el,target).perform()defclick_text(self,text):

self.driver.find_element_by_partial_link_text(text).click()def close(self):#关闭当前浏览器窗口

self.driver.close()def quit(self):#退出浏览器

self.driver.quit()def submit(self,key):#提交事件

el=self.to_element(key)

el.submit()def F5(self):#刷新

self.driver.refresh()def js(self,script):#执行js

self.driver.execute_script(script)def get_attribute(self,key,attribute):#获取元素属性

el=self.to_element(key)returnel.get_attribute(attribute)def get_text(self,key):#获取text

el=self.to_element(key)returnel.textdef get_title(self):#获取title

returnself.driver.titledef get_url(self):#获取url

returnself.driver.current_urldef to_frame(self,key):#窗口切换

el=self.to_element(key)

self.driver.switch_to.frame(el)def alert_accept(self):#对话框确认操作

self.driver.switch_to.alert.accept()def alert_dismiss(self):#对话框取消操作

self.driver.switch_to.alert.dismiss()def img(self,fp):#截图

self.driver.get_screenshot_as_file(fp)def select_by_value(self,key,value):#下拉框操作

el=self.to_element(key)

Select(el).select_by_value(value)

send_email.py放置邮件发送代码

importsmtplibfrom email.mime.text importMIMETextfrom email.mime.multipart importMIMEMultipartimportconfigparserimportosdefsendEmail(file_path):

path=os.path.dirname(os.path.abspath("."))

cfpath=os.path.join(path,'autoparker\config\conf.ini')

conf=configparser.ConfigParser()

conf.read(cfpath)

smtpserver= conf.get('emailqq','smtpserver')

sender= conf.get('emailqq','sender')

pwd= conf.get('emailqq','pwd')

receiver=[]

email_to=conf.get('emailqq','receiver')

email_array=email_to.split(';')for i inrange(len(email_array)):

receiver.append(email_array[i])print(receiver)

with open(file_path,'rb') as fp:

mail_boby=fp.read()

msg=MIMEMultipart()

msg['From']=sender

msg['To']=",".join(receiver)

msg['Subject']='我曾把完整的镜子打碎'body=MIMEText(mail_boby,'html','utf-8')

msg.attach(body)

att=MIMEText(mail_boby,'html','utf-8')

att['Content-Type']='application/octet-stream'att['Content-Disposition']='attachment;filename="test_reuslt.html"'msg.attach(att)try:

smtp=smtplib.SMTP()

smtp.connect(smtpserver)

smtp.login(sender,pwd)except:

smtp=smtplib.SMTP_SSL(smtpserver,465)

smtp.login(sender,pwd)

smtp.sendmail(sender,receiver,msg.as_string())

smtp.quit()

sendEmail('D:\\report.html')

最后main.py文件放置的就是运行代码(执行这个文件进行测试就可以)

importHTMLTestRunnerimportunittestfrom test_case.login importloginTestfrom public.send_email importsendEmailif __name__=='__main__':

testunit=unittest.TestLoader().loadTestsFromTestCase(loginTest)

suite=unittest.TestSuite(testunit)

file_path="D:\\html_report.html"fp=open(file_path,'wb')

runner=HTMLTestRunner.HTMLTestRunner(stream=fp,title='登录测试',description='测试执行结果')

runner.run(suite)

fp.close()

sendEmail(file_path)

今天就先到这里,一个入门级的自动化测试框架,由于是非专业开发自学,拿出来给大家分享,编程代码可能有点不规范,命名也很随意。大家先将就着看吧!回头慢慢完善。

还要多向大佬们学习。

备注:有想一起自学的朋友可以看配置文件代码,一起交流。三人行必有我师焉



推荐阅读
  • Python 程序转换为 EXE 文件:详细解析 .py 脚本打包成独立可执行文件的方法与技巧
    在开发了几个简单的爬虫 Python 程序后,我决定将其封装成独立的可执行文件以便于分发和使用。为了实现这一目标,首先需要解决的是如何将 Python 脚本转换为 EXE 文件。在这个过程中,我选择了 Qt 作为 GUI 框架,因为之前对此并不熟悉,希望通过这个项目进一步学习和掌握 Qt 的基本用法。本文将详细介绍从 .py 脚本到 EXE 文件的整个过程,包括所需工具、具体步骤以及常见问题的解决方案。 ... [详细]
  • 本文详细介绍了如何使用Python的多进程技术来高效地分块读取超大文件,并将其输出为多个文件。通过这种方式,可以显著提高读取速度和处理效率。 ... [详细]
  • 本文节选自《NLTK基础教程——用NLTK和Python库构建机器学习应用》一书的第1章第1.2节,作者Nitin Hardeniya。本文将带领读者快速了解Python的基础知识,为后续的机器学习应用打下坚实的基础。 ... [详细]
  • 本文详细介绍了Java反射机制的基本概念、获取Class对象的方法、反射的主要功能及其在实际开发中的应用。通过具体示例,帮助读者更好地理解和使用Java反射。 ... [详细]
  • 本文介绍如何使用OpenCV和线性支持向量机(SVM)模型来开发一个简单的人脸识别系统,特别关注在只有一个用户数据集时的处理方法。 ... [详细]
  • Spring – Bean Life Cycle
    Spring – Bean Life Cycle ... [详细]
  • 最详尽的4K技术科普
    什么是4K?4K是一个分辨率的范畴,即40962160的像素分辨率,一般用于专业设备居多,目前家庭用的设备,如 ... [详细]
  • 在多线程并发环境中,普通变量的操作往往是线程不安全的。本文通过一个简单的例子,展示了如何使用 AtomicInteger 类及其核心的 CAS 无锁算法来保证线程安全。 ... [详细]
  • 本文介绍如何使用 Python 的 DOM 和 SAX 方法解析 XML 文件,并通过示例展示了如何动态创建数据库表和处理大量数据的实时插入。 ... [详细]
  • 解决问题:1、批量读取点云las数据2、点云数据读与写出3、csf滤波分类参考:https:github.comsuyunzzzCSF论文题目ÿ ... [详细]
  • 在尝试对 QQmlPropertyMap 类进行测试驱动开发时,发现其派生类中无法正常调用槽函数或 Q_INVOKABLE 方法。这可能是由于 QQmlPropertyMap 的内部实现机制导致的,需要进一步研究以找到解决方案。 ... [详细]
  • Python 序列图分割与可视化编程入门教程
    本文介绍了如何使用 Python 进行序列图的快速分割与可视化。通过一个实际案例,详细展示了从需求分析到代码实现的全过程。具体包括如何读取序列图数据、应用分割算法以及利用可视化库生成直观的图表,帮助非编程背景的用户也能轻松上手。 ... [详细]
  • 本文详细解析了使用C++实现的键盘输入记录程序的源代码,该程序在Windows应用程序开发中具有很高的实用价值。键盘记录功能不仅在远程控制软件中广泛应用,还为开发者提供了强大的调试和监控工具。通过具体实例,本文深入探讨了C++键盘记录程序的设计与实现,适合需要相关技术的开发者参考。 ... [详细]
  • Python多线程编程技巧与实战应用详解 ... [详细]
  • Python全局解释器锁(GIL)机制详解
    在Python中,线程是操作系统级别的原生线程。为了确保多线程环境下的内存安全,Python虚拟机引入了全局解释器锁(Global Interpreter Lock,简称GIL)。GIL是一种互斥锁,用于保护对解释器状态的访问,防止多个线程同时执行字节码。尽管GIL有助于简化内存管理,但它也限制了多核处理器上多线程程序的并行性能。本文将深入探讨GIL的工作原理及其对Python多线程编程的影响。 ... [详细]
author-avatar
邵元星_246
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有