Selenium Python 框架之 BasePage页面封装写法

简介: Selenium Python 框架之 BasePage页面封装写法
# -*- coding:utf-8 -*-
# @Time   : 2019-10-25
# @Author : carl_dj
from public.common.log import Logger
from config import globalparam
from selenium.common.exceptions import NoSuchElementException
import os
import time
logger = Logger(logger='BasePage').getlog()
class BasePage:
    """测试基类"""
    def __init__(self, driver):
        self.driver = driver
    @staticmethod
    def isdisplayed(element):
        """元素是否存在"""
        value = element.is_displayed()
        return value
    @staticmethod
    def sleep(secondes):
        """强制等待"""
        time.sleep(secondes)
        logger.info('Sleep for %d seconds' % secondes)
    def open_url(self,url):
        self.driver.get(url)
    def forward(self):
        """浏览器前进"""
        self.driver.forward()
        logger.info("Click forward on current page.")
    def back(self):
        """浏览器后退"""
        self.driver.back()
        logger.info("Click back on current page.")
    def wait(self,seconds):
        """隐式等待"""
        self.driver.implicitly_wait(seconds)
        logger.info("wait for %d seconds." % seconds)
    def close(self):
        """关闭当前窗口"""
        try:
            self.driver.close()
            logger.info("Closing and quit the browser.")
        except NameError as e:
            logger.info("Faile to quit the browser with %s" %e)
    def get_img(self):
        """截图"""
        rq = time.strftime('%Y%m%d%H%M%S', time.localtime(time.time()))
        screen_name = os.path.join(globalparam.test_img_path,'%s.png' % rq)
        # noinspection PyBroadException
        try:
            self.driver.get_screenshot_as_file(screen_name)
            logger.info("Had take screenshot and save to folder : /screenshots")
        except NameError as e:
            logger.error("Failed to take screenshot! %s" % e)
            self.get_img()
    def find_element(self, selector):
        """定位元素"""
        by = selector[0]
        value = selector[1]
        element = None
        if by in ['id', 'name', 'class', 'tag', 'link', 'plink', 'css', 'xpath']:
            # noinspection PyBroadException
            try:
                if by == 'id':
                    element = self.driver.find_element_by_id(value)
                elif by == 'name':
                    element = self.driver.find_element_by_name(value)
                elif by == 'class':
                    element = self.driver.find_element_by_class_name(value)
                elif by == 'tag':
                    element = self.driver.find_element_by_tag_name(value)
                elif by == 'link':
                    element = self.driver.find_element_by_link_text(value)
                elif by == 'plink':
                    element = self.driver.find_element_by_partial_link_text(value)
                elif by == 'css':
                    element = self.driver.find_element_by_css_selector(value)
                elif by == 'xpath':
                    element = self.driver.find_element_by_xpath(value)
                else:
                    logger.error('Not find the element')
                logger.info("Had  find the element! ,by %s via value :%s " %(by,value))
                # logger.info('元素定位成功。定位方式:%s,使用的值%s:' % (by, value))
                return element
            except NoSuchElementException as e:
                logger.error("NoSuchElementException %s " %e)
                self.get_img()  # 调用截图
        else:
            logger.error('Please enter a valid type of targeting elements')
    def type(self, selector, value):
        """输入内容"""
        element = self.find_element(selector)
        # element.clear()
        logger.info('clear input_box')
        # noinspection PyBroadException
        try:
            element.send_keys(value)
            logger.info('input is:%s' % value)
        except BaseException:
            logger.error('Failed to type in input box', exc_info=1)
            self.get_img()
    #输入并确认
    def type_enter(self,selector,value):
        try:
            element = self.find_element(selector)
            element.send_keys(value)
            time.sleep(1)
            element.send_keys(Keys.ENTER)
        except Exception as e:
            logger.info("Failed to type_and_enter with %s" % e)
            self.get_img()
            raise
    def click(self, selector):
        """点击元素"""
        element = self.find_element(selector)
        # noinspection PyBroadException
        try:
            element.click()
            logger.info('"The element \' %s \' was clicked." % element.text')
        except BaseException:
            display = self.isdisplayed(element)
            if display is True:
                self.sleep(3)
                element.click()
                logger.info('The element was clicked')
            else:
                self.get_img()
                logger.error('Failed to click the element', exc_info=1)
    def right_click(self,selector):
        """右击元素"""
        element = self.find_element(selector)
        try:
            ActionChains(self.driver).context_click(element).perform()
            logger.info("The element \' %s \' was clicked." % element.text)
        except NameError as e:
            logger.error("Failed to right_click the element with %s" % e)
            self.get_img()
    def double_click(self,selector):
        """双击"""
        element = self.find_element(selector)
        try:
            ActionChains(self.driver).double_click(element).perform()
        except Exception as e:
            logger.info("Failed to double_click the element with %s" % e)
            self.get_img()
            raise
    def move_to_element(self,selector):
        """鼠标移到元素上"""
        try:
            element = self.find_element(selector)
            ActionChains(self.driver).move_to_element(element).perform()
        except Exception as e:
            logger.info("Failed to move_to_element the element with %s" % e)
            self.get_img()
            raise
    def drag_and_drop(self, element_selector,ta_selector):
        """拖拽"""
        try:
            element_drag = self.find_element(element_selector)
            taget_drop = self.find_element(ta_selector)
            ActionChains(self.driver).drag_and_drop(element_drag,taget_drop).perform()
        except Exception as e:
            logger.info("Failed to drag_and_drop the element with %s" % e)
            self.get_img()
            raise
    def refresh(self):
        """刷新"""
        self.driver.refresh()
    def submit(self,selector):
        """submit"""
        try:
            element = self.find_element(selector)
            element.submit()
        except Exception as e:
            logger.info("Failed to submit the element with %s" % e)
            self.get_img()
    def get_attribute(self,selector,attribute):
        """获取元素属性"""
        try:
            element = self.find_element(selector)
            return element.get_attribute(attribute)
        except Exception as e:
            logger.info("Failed to get_attribute  with %s" % e)
            self.get_img()
            raise
    def get_text(self,selector):
        """获取元素的文本信息"""
        try:
            return self.find_element(selector).text
        except Exception as e:
            logger.info("Failed to get_text  with %s" % e)
            self.get_img()
    def dismiss_alert(self):
        """弹窗 alert——取消"""
        self.driver.switch_to.alert.dismiss()
    def clear(self,selector):
        """清除文本框"""
        element = self.find_element(selector)
        try:
            element.clear()
            logger.info("Clear text in input box before typing.")
        except NameError as e:
            logger.error("Failed to clear in input box with %s" % e)
            self.get_img()
    def use_js(self, js):
        """调用js"""
        # noinspection PyBroadException
        try:
            self.driver.execute_script(js)
            logger.info('successful,js contents is:%s' % js)
        except BaseException:
            logger.error('js error', exc_info=1)
    def switch_menue(self, parentelement, secelement, targetelement):
        """三级菜单切换"""
        self.sleep(3)
        # noinspection PyBroadException
        try:
            self.driver.switch_to_default_content()
            self.click(parentelement)
            logger.info('成功点击一级菜单:%s' % parentelement)
            self.click(secelement)
            logger.info('成功点击二级菜单:%s' % secelement)
            self.click(targetelement)
            logger.info('成功点击三级菜单:%s' % targetelement)
        except BaseException:
            logger.error('切换菜单报错', exc_info=1)
    def switch_ifarme(self, selector):
        """切换ifarme"""
        element = self.find_element(selector)
        # noinspection PyBroadException
        try:
            self.driver.switch_to.frame(element)
            logger.info('Successful to switch_to_frame! ')
        except BaseException:
            logger.error('Failed to  switch_to_frame', exc_info=1)
    def quit_iframe(self):
        """退出当前iframe"""
        self.driver.switch_to_default_content()
    def get_title(self):
        """获取title"""
        title = self.driver.title
        logger.info('Current page title is:%s' % title)
        return title
    def quit(self):
        """关闭浏览器"""
        self.driver.quit()
        logger.info('quit the browser')
目录
相关文章
|
11天前
|
Web App开发 前端开发 JavaScript
探索Python科学计算的边界:利用Selenium进行Web应用性能测试与优化
【10月更文挑战第6天】随着互联网技术的发展,Web应用程序已经成为人们日常生活和工作中不可或缺的一部分。这些应用不仅需要提供丰富的功能,还必须具备良好的性能表现以保证用户体验。性能测试是确保Web应用能够快速响应用户请求并处理大量并发访问的关键步骤之一。本文将探讨如何使用Python结合Selenium来进行Web应用的性能测试,并通过实际代码示例展示如何识别瓶颈及优化应用。
42 5
|
2天前
|
JSON 搜索推荐 API
Python的web框架有哪些?小项目比较推荐哪个?
【10月更文挑战第15天】Python的web框架有哪些?小项目比较推荐哪个?
10 1
|
5天前
|
安全 数据库 C++
Python Web框架比较:Django vs Flask vs Pyramid
Python Web框架比较:Django vs Flask vs Pyramid
13 4
|
7天前
|
安全 数据库 C++
Python Web框架比较:Django vs Flask vs Pyramid
【10月更文挑战第10天】本文比较了Python中三个最受欢迎的Web框架:Django、Flask和Pyramid。Django以功能全面、文档完善著称,适合快速开发;Flask轻量灵活,易于上手;Pyramid介于两者之间,兼顾灵活性和安全性。选择框架时需考虑项目需求和个人偏好。
18 1
|
10天前
|
数据采集 Web App开发 数据可视化
Python爬虫教程:Selenium可视化爬虫的快速入门
Python爬虫教程:Selenium可视化爬虫的快速入门
|
11天前
|
安全 数据库 C++
Python Web框架比较:Django vs Flask vs Pyramid
【10月更文挑战第6天】本文比较了Python中三个最受欢迎的Web框架:Django、Flask和Pyramid。Django功能全面,适合快速开发;Flask灵活轻量,易于上手;Pyramid介于两者之间,兼顾灵活性和可扩展性。文章分析了各框架的优缺点,帮助开发者根据项目需求和个人偏好做出合适的选择。
21 4
|
12天前
|
数据采集 人工智能 自然语言处理
Python实时查询股票API的FinanceAgent框架构建股票(美股/A股/港股)AI Agent
金融领域Finance AI Agents方面的工作,发现很多行业需求和用户输入的 query都是和查询股价/行情/指数/财报汇总/金融理财建议相关。如果需要准确的 金融实时数据就不能只依赖LLM 来生成了。常规的方案包括 RAG (包括调用API )再把对应数据和prompt 一起拼接送给大模型来做文本生成。稳定的一些商业机构的金融数据API基本都是收费的,如果是以科研和demo性质有一些开放爬虫API可以使用。这里主要介绍一下 FinanceAgent,github地址 https://github.com/AI-Hub-Admin/FinanceAgent
|
12天前
|
JSON 测试技术 数据库
Python的Flask框架
【10月更文挑战第4天】Python的Flask框架
|
2月前
|
测试技术 索引 Python
Python接口自动化测试框架(练习篇)-- 数据类型及控制流程(一)
本文提供了Python接口自动化测试中的编程练习,包括计算器、猜数字、猜拳和九九乘法表等经典问题,涵盖了数据类型、运算、循环、条件控制等基础知识的综合应用。
38 1
|
2月前
|
IDE 测试技术 开发工具
Python接口自动化测试框架(基础篇)-- 不只是txt的文件操作
本文介绍了Python中的文件操作方法,包括使用open()打开文件、close()关闭文件、read()读取内容、readline()读取单行、readlines()读取多行、write()写入内容以及writelines()写入多行的方法。同时,探讨了文件操作模式和编码问题,并扩展了上下文管理器with...as的使用,以及对图片和音频文件操作的思考和练习。
26 1
Python接口自动化测试框架(基础篇)-- 不只是txt的文件操作