• selenium封装


    import configparser
    from Logs.log import log1
    from selenium.common.exceptions import NoSuchElementException
    import getcwd
    import os
    import time
    from selenium import webdriver
    
    #config配置,提供配置文件路径
    path = getcwd.get_cwd()
    config_path = os.path.join(path, 'Config/config.ini')
    config = configparser.ConfigParser()
    config.read(config_path,encoding="utf-8-sig")
    
    
    class BasePage:
        """测试基类"""
    
        def __init__(self, driver):
            self.driver = driver
    
        @staticmethod
        def isdisplayed(element):
            """元素是否存在"""
            value = element.is_displayed()
            return value
    
        @staticmethod
        def my_sleep(secondes):
            """强制等待"""
            time.sleep(secondes)
            log1.info('暂停%d秒' % secondes)
    
        def get_img(self):
            """截图"""
            path = os.path.join(getcwd.get_cwd(), 'screenshots/')  # 拼接截图保存路径
            rq = time.strftime('%Y%m%d%H%M', time.localtime(time.time()))  # 按格式获取当前时间
            screen_name = path + rq + '.png'  # 拼接截图文件名
            # noinspection PyBroadException
            try:
                self.driver.get_screenshot_as_file(screen_name)
                log1.info("截图保存成功")
            except BaseException:
                log1.error("截图失败", exc_info=1)
    
        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:
                        log1.error('没有找到元素')
                    log1.info('元素定位成功。定位方式:%s,使用的值%s:' % (by, value))
                    return element
                except NoSuchElementException:
                    log1.error("报错信息:", exc_info=1)
                    self.get_img()  # 调用截图
            else:
                log1.error('输入的元素定位方式错误')
    
        def type(self, selector, value):
            """输入内容"""
            element = self.find_element(selector)
            element.clear()
            log1.info('清空输入内容')
            # noinspection PyBroadException
            try:
                element.send_keys(value)
                log1.info('输入的内容:%s' % value)
            except BaseException:
                log1.error('内容输入报错', exc_info=1)
                self.get_img()
    
        def click(self, selector):
            """点击元素"""
            element = self.find_element(selector)
            # noinspection PyBroadException
            try:
                element.click()
                log1.info('点击元素成功')
            except BaseException:
                display = self.isdisplayed(element)
                if display is True:
                    self.my_sleep(3)
                    element.click()
                    log1.info('点击元素成功')
                else:
                    self.get_img()
                    log1.error('点击元素报错', exc_info=1)
    
        def use_js(self, js):
            """调用js"""
            # noinspection PyBroadException
            try:
                self.driver.execute_script(js)
                log1.info('js执行成功,js内容为:%s' % js)
            except BaseException:
                log1.error('js执行报错', exc_info=1)
    
        def switch_menue(self, parentelement, secelement, targetelement):
            """三级菜单切换"""
            self.my_sleep(3)
            # noinspection PyBroadException
            try:
                self.driver.switch_to_default_content()
                self.click(parentelement)
                log1.info('成功点击一级菜单:%s' % parentelement)
                self.click(secelement)
                log1.info('成功点击二级菜单:%s' % secelement)
                self.click(targetelement)
                log1.info('成功点击三级菜单:%s' % targetelement)
            except BaseException:
                log1.error('切换菜单报错', exc_info=1)
    
        def switch_ifarme(self, selector):
            """切换farm"""
            element = self.find_element(selector)
            # noinspection PyBroadException
            try:
                self.driver.switch_to.frame(element)
                log1.info('切换frame成功')
            except BaseException:
                log1.error('切换frame报错', exc_info=1)
    
        def get_title(self):
            """获取title"""
            title = self.driver.title
            log1.info('当前窗口的title是:%s' % title)
            return title
    
        def my_quit(self):
            """关闭浏览器"""
            self.driver.quit()
            log1.info('关闭浏览器')
    
        #添加全局变量config配置
        #封装配置文件的增删改查
        '''
        ConfigParser模块在写入时会把注释给清空掉。所以如果要实现配置文件去控制想要测试哪个环境信息,只能配置一个开关。没办法通过去掉注释这种方法。
    
        environment是配置一些开关,比如browser用来配置浏览器,可以设定0是谷歌浏览器,1是火狐浏览器。switch是环境开关,0是测试环境,1是生产环境
    
        test放一些关于测试环境用到的信息
    
        prod放一些关于生产环境用到的信息
        '''
        def config_get(self,key,section=None):
            '''读取配置文件字段的值并返回'''
            switch = config.get('environment', 'switch')
            if section==None and switch == str(0):
                section = 'test'
            elif section==None and switch == str(1):
                section = 'prod'
            config_get = config.get(section,key)
            return  config_get
    
        #写入配置文件
        def config_write(self,key = None,value = None,section = None):
            '''往配置文件写入键值'''
            switch = config.get('environment', 'switch')
            if section == None and switch == str(0):
                section = 'test'
            elif section == None and switch == str(1):
                section = 'prod'
            if key is not None and value is not None:
                config.set(section,key,value)
                log1.info('在section:%s下写入%s=%s' %(section,key,value))
                with open(config_path,'w',encoding='utf-8')as f :
                    config.write(f)
            else:
                config.add_section(section)
                log1.info('新增section:%s' % section)
                with open(config_path,'w',encoding='utf-8')as f :
                    config.write(f)
    
        def config_delete(self,key = None,section = None):
            '''删除配置文件字段'''
            switch = config.get('environment', 'switch')
            if section == None and switch == str(0):
                section = 'test'
            elif section == None and switch == str(1):
                section = 'prod'
            if key is not None :
                config.remove_option(section,key)
                log1.info('删除section:%s下key为:%s的记录' % (section,key))
                with open(config_path,'w',encoding='utf-8')as f :
                    config.write(f)
            else:
                config.remove_section(section)
                log1.info('删除section:%s' % section)
                with open(config_path,'w',encoding='utf-8')as f :
                    config.write(f)
    
        #封装浏览器
        def open_browser(self):
            browser = self.config_get('browser','environment')
            log1.info('读取浏览器配置')
            url = self.config_get('url')
            log1.info('读取url:%s' % url)
            try:
                if browser == str(0) :
                    self.driver = webdriver.Chrome()
                    log1.info('打开的浏览器为chrome')
                elif browser == str(1) :
                    self.driver = webdriver.Firefox()
                    log1.info('打开的浏览器为firefox')
                self.driver.get(url)
                self.driver.maximize_window()
                log1.info('浏览器最大化')
                self.driver.implicitly_wait(10)
                log1.info('设置静态等待时间10秒')
                return self.driver
            except BaseException:
                log1.error('浏览器打开报错')
    
        #邮箱配置
        def config_options(self, section):
            '''读取配置文件某section下所有键'''
            config = configparser.ConfigParser()
            config.read(config_path, encoding="utf-8-sig")
            username = config.options(section)
            return username
    
        def get_addkey(self, user):
            '''遍历获得配置文件收件人email'''
            sum = 0
            L = []
            for i in user:
                if sum < len(user):
                    emails = self.config_get(i, 'addressed')
                    L.append(emails)
                    sum += 1
            return L
  • 相关阅读:
    iOS 代码规范
    Clang Format
    PullToRefreshListView手动刷新问题
    android不依赖具体activity弹出Dialog对话框,即全局性对话框
    我的手机华为荣耀7,运行android程序不输出Log
    Android从imageview中获得bitmap
    Fragment里面的ViewPager嵌套subFragment,主Fragment切换的时候subFragment出现空白Fragment的Bug
    解决某些手机RadioGroup中的RadioButton不居中的问题
    Android权限大全
    UML类图
  • 原文地址:https://www.cnblogs.com/xiaochuichui/p/13281035.html
Copyright © 2020-2023  润新知