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

python自动化脚本_Python语言web自动化通用脚本

web自动化脚本中有一部分代码是可以借鉴的,我们只需要将这个框架移植到当前项目中,修改部分参数即可。比如日志类、driver对象、元素基本操作等。以商

web自动化脚本中有一部分代码是可以借鉴的,我们只需要将这个框架移植到当前项目中,修改部分参数即可。比如日志类、driver对象、元素基本操作等。

以商城项目为例,以下就是相关代码。

base包(内含日志、driver对象、页面元素操作):

页面元素操作(base.py):

import time

from time import sleep

import page

from selenium.webdriver.support.wait import WebDriverWait

from base.get_logger import GetLogger

# 获取log日志器

log = GetLogger().get_logger()

class Base:

def __init__(self, driver):

log.info("[base]: 正在获取初始化driver对象:{}".format(driver))

self.driver = driver

# 查找元素方法 封装

def base_find(self, loc, timeout=30, poll=0.5):

log.info("[base]: 正在定位:{} 元素,默认定位超时时间为: {}".format(loc, timeout))

# 使用显示等待 查找元素

return WebDriverWait(self.driver,

timeout=timeout,

poll_frequency=poll).until(lambda x:x.find_element(*loc))

# 点击元素 方法封装

def base_click(self, loc):

log.info("[base]: 正在对:{} 元素实行点击事件".format(loc))

self.base_find(loc).click()

# 输入元素 方法封装

def base_input(self, loc, value):

# 获取元素

el = self.base_find(loc)

# 清空

log.info("[base]: 正在对:{} 元素实行清空".format(loc))

el.clear()

# 输入

el.send_keys(value)

# 获取文本信息 方法封装

def base_get_text(self, loc):

log.info("[base]: 正在获取:{} 元素文本值".format(loc))

return self.base_find(loc).text

# 截图 方法封装

def base_get_image(self):

log.info("[base]: 断言出错,调用截图")

self.driver.get_screenshot_as_file("../image/{}.png".format(time.strftime("%Y_%m_%d %H_%M_%S")))

# 判断元素是否存在 方法封装

def base_element_is_exist(self, loc):

try:

self.base_find(loc, timeout=2)

log.info("[base]: {} 元素查找成功,存在页面".format(loc))

return True # 代表元素存在

except:

log.info("[base]: {} 元素查找失败,不存在当前页面".format(loc))

return False # 代表元素不存在

# 回到首(页购物车、下订单、支付)都需要用到此方法

def base_index(self):

sleep(2)

self.driver.get(page.URL)

# 切换frame表单方法

def base_switch_frame(self, name):

self.driver.switch_to.frame(name)

# 回到默认目录方法

def base_default_content(self):

self.driver.switch_to.default_content()

# 切换窗口 方法 调用此方法

def base_switch_to_window(self, title):

log.info("正在执行切换title值为:{}窗口 ".format(title))

self.driver.switch_to.window(self.base_get_title_handle(title))

# 获取指定title页面的handle方法

def base_get_title_handle(self, title):

# 获取当前页面所有的handles

for handle in self.driver.window_handles:

log.info("正在遍历handles:{}-->{}".format(handle, self.driver.window_handles))

# 切换 handle

self.driver.switch_to.window(handle)

log.info("切换 :{} 窗口".format(handle))

# 获取当前页面title 并判断 是否等于 指定参数title

log.info("判断当前页面title:{} 是否等于指定的title:{}".format(self.driver.title, title))

if self.driver.title == title:

log.info("条件成立! 返回当前handle{}".format(handle))

# 返回 handle

return handle

driver对象(get_driver.py):

from selenium import webdriver

import page

class GetDriver:

driver = None

# 获取 driver

@classmethod

def get_driver(cls):

if cls.driver is None:

# 获取driver

cls.driver = webdriver.Firefox()

# 最大化浏览器

cls.driver.maximize_window()

# 打开url

cls.driver.get(page.URL)

# 返回 driver

return cls.driver

# 关闭driver

@classmethod

def quit_driver(cls):

if cls.driver:

cls.driver.quit()

# 必须置空操作

cls.driver = None

if __name__ == ‘__main__‘:

GetDriver().quit_driver()

日志对象(get_logger.py):

import logging.handlers

class GetLogger:

logger = None

# 在最外侧运行

# filename = "./log/xxxx.log"

# 获取 logger

@classmethod

def get_logger(cls):

# 如果 logger为空

if cls.logger is None:

# 获取日志器

cls.logger = logging.getLogger()

# 设置日志器默认级别

cls.logger.setLevel(logging.INFO)

# 获取处理器 控制台

sh = logging.StreamHandler()

# 获取处理 文件(时间)

th = logging.handlers.TimedRotatingFileHandler(filename="../log/xxxx.log",

when="midnight",

interval=1,

backupCount=30,

encoding="utf-8")

# 获取格式器

fm = "%(asctime)s %(levelname)s [%(name)s] [%(filename)s (%(funcName)s:%(lineno)d] - %(message)s"

fmt = logging.Formatter(fm)

# 将格式器 设置 处理器中

sh.setFormatter(fmt)

th.setFormatter(fmt)

# 将处理器 添加到 日志器中

cls.logger.addHandler(sh)

cls.logger.addHandler(th)

# 返回 日志器

return cls.logger

定义测试套件(run_main.py直接放在项目目录下):

# 导包

import unittest

import time

from tool.HTMLTestRunner import HTMLTestRunner

# 定义测试套件 在scripts中 运行

# suite = unittest.defaultTestLoader.discover("./")

# 在最外侧运行

suite = unittest.defaultTestLoader.discover("./scripts")

# 报告生成目录及文件名称

dir_path = "./report/{}.html".format(time.strftime("%Y_%m_%d %H_%M_%S"))

# 获取文件流并调用run运行

with open(dir_path, "wb") as f:

HTMLTestRunner(stream=f, title="Tpshop商城自动化测试报告", description="操作系统:win7").run(suite)

在工具包(tools)中存放HTMLTestRunner.py文件

以上就是Python语言web自动化脚本常用的代码,按需使用。

原文地址:https://www.cnblogs.com/ray-mr-huang/p/11526426.html



推荐阅读
  • Cookie学习小结
    Cookie学习小结 ... [详细]
  • 本文介绍如何使用 Python 的 DOM 和 SAX 方法解析 XML 文件,并通过示例展示了如何动态创建数据库表和处理大量数据的实时插入。 ... [详细]
  • 包含phppdoerrorcode的词条 ... [详细]
  • 一、Tomcat安装后本身提供了一个server,端口配置默认是8080,对应目录为:..\Tomcat8.0\webapps二、Tomcat8.0配置多个端口,其实也就是给T ... [详细]
  • C#实现文件的压缩与解压
    2019独角兽企业重金招聘Python工程师标准一、准备工作1、下载ICSharpCode.SharpZipLib.dll文件2、项目中引用这个dll二、文件压缩与解压共用类 ... [详细]
  • 为什么多数程序员难以成为架构师?
    探讨80%的程序员为何难以晋升为架构师,涉及技术深度、经验积累和综合能力等方面。本文将详细解析Tomcat的配置和服务组件,帮助读者理解其内部机制。 ... [详细]
  • 浅析python实现布隆过滤器及Redis中的缓存穿透原理_python
    本文带你了解了位图的实现,布隆过滤器的原理及Python中的使用,以及布隆过滤器如何应对Redis中的缓存穿透,相信你对布隆过滤 ... [详细]
  • 用阿里云的免费 SSL 证书让网站从 HTTP 换成 HTTPS
    HTTP协议是不加密传输数据的,也就是用户跟你的网站之间传递数据有可能在途中被截获,破解传递的真实内容,所以使用不加密的HTTP的网站是不 ... [详细]
  • Spring – Bean Life Cycle
    Spring – Bean Life Cycle ... [详细]
  • 深入解析HTML5字符集属性:charset与defaultCharset
    本文将详细介绍HTML5中新增的字符集属性charset和defaultCharset,帮助开发者更好地理解和应用这些属性,以确保网页在不同环境下的正确显示。 ... [详细]
  • 本文详细介绍了 InfluxDB、collectd 和 Grafana 的安装与配置流程。首先,按照启动顺序依次安装并配置 InfluxDB、collectd 和 Grafana。InfluxDB 作为时序数据库,用于存储时间序列数据;collectd 负责数据的采集与传输;Grafana 则用于数据的可视化展示。文中提供了 collectd 的官方文档链接,便于用户参考和进一步了解其配置选项。通过本指南,读者可以轻松搭建一个高效的数据监控系统。 ... [详细]
  • 开发日志:高效图片压缩与上传技术解析 ... [详细]
  • Keepalived 提供了多种强大且灵活的后端健康检查机制,包括 HTTP_GET、SSL_GET、TCP_CHECK、SMTP_CHECK 和 MISC_CHECK 等多种检测方法。这些健康检查功能确保了高可用性环境中的服务稳定性和可靠性。通过合理配置这些检查方式,可以有效监测后端服务器的状态,及时发现并处理故障,从而提高系统的整体性能和可用性。 ... [详细]
  • 本文探讨了 Kafka 集群的高效部署与优化策略。首先介绍了 Kafka 的下载与安装步骤,包括从官方网站获取最新版本的压缩包并进行解压。随后详细讨论了集群配置的最佳实践,涵盖节点选择、网络优化和性能调优等方面,旨在提升系统的稳定性和处理能力。此外,还提供了常见的故障排查方法和监控方案,帮助运维人员更好地管理和维护 Kafka 集群。 ... [详细]
  • 本文深入探讨了 hCalendar 微格式在事件与时间、地点相关活动标记中的应用。作为微格式系列文章的第四篇,前文已分别介绍了 rel 属性用于定义链接关系、XFN 微格式增强链接的人际关系描述以及 hCard 微格式对个人和组织信息的描述。本次将重点解析 hCalendar 如何通过结构化数据标记,提高事件信息的可读性和互操作性。 ... [详细]
author-avatar
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有