使用Safari中的WebDriver进行测试

启用WebDriver并运行测试。

概述 本文将指导您完成设置WebDriver和运行用Python编写的测试的过程。当测试调用一个命令时,该命令按照以下步骤执行:

  • 客户端库将每个命令翻译成REST API命令。
  • REST API命令向Safari的驱动程序托管的本地web服务器发送相应的HTTP请求。
  • 驱动程序验证HTTP请求的内容并将命令转发给适当的浏览器实例。
  • 当命令执行完毕后,驱动程序为REST API命令发送一个HTTP响应。客户端库解释HTTP响应并将结果返回给测试代码。

确保您有Safari的WebDriver Safari和Safari技术预览版各提供一个自己的safaridriver可执行文件。确保您的设备上已经有了这个可执行文件:

  • Safari的可执行文件位于/usr/bin/safaridriver。
  • Safari技术预览版的可执行文件是应用程序包内容的一部分。

每个safaridriver只能启动与其关联的Safari版本,并且两者可以同时运行。尽管您可以通过运行safaridriver可执行文件来手动启动safaridriver,但大多数Selenium库会自动启动驱动程序。请参阅您首选客户端库的文档以了解如何指定要使用的浏览器。

获取正确的Selenium库版本 获取Selenium开源项目的最近发布版本。从3.0.0-beta1版本开始,Selenium的Java和Python客户端库提供对Safari的原生驱动实现的支持。

重要

不要使用旧的SafariDriver实现,它不再受Selenium项目支持。由Apple开发的驱动程序是Selenium项目之前维护的旧版SafariDriver的替代品。

配置Safari以启用WebDriver支持 默认情况下,Safari对开发者的WebDriver支持是关闭的。启用方式取决于您的操作系统。

High Sierra及更高版本:

运行一次。(如果您是从以前的macOS版本升级,可能需要使用sudo。)

bash 复制代码
safaridriver --enable

Sierra及更早版本:

如果尚未这样做,请使Develop菜单可用。

  • 选择Safari > Preferences,在Advanced标签页中,选择"在菜单栏中显示Develop菜单"。有关详细信息,请参阅Safari帮助。
  • 选择Develop > Allow Remote Automation。

授权safaridriver启动托管本地web服务器的XPC服务。为此,手动运行一次,并遵循认证提示。

bash 复制代码
/usr/bin/safaridriver

编写WebDriver测试套件 一旦您获得了客户端库,就可以编写WebDriver测试并在Safari上运行。下面的示例使用Python WebDriver测试WebKit功能状态页面的重要功能。

注意

在Python WebDriver库中,每个方法调用同步阻塞进程,直到操作完成。其他WebDriver库可能提供异步API。

python 复制代码
#coding: utf-8 
from selenium.webdriver.common.by import By 
from selenium import webdriver
import unittest 
import time

def setup_module(module): 
    WebKitFeatureStatusTest.driver = webdriver.Safari()

def teardown_module(module): 
    WebKitFeatureStatusTest.driver.quit()

class WebKitFeatureStatusTest(unittest.TestCase):

    def test_feature_status_page_search(self):
        self.driver.get("https://webkit.org/status/")
        
        # 在搜索框中输入"CSS"。
        # 确保至少有一个结果出现在搜索中
        search_box = self.driver.find_element_by_id("search")
        search_box.send_keys("CSS")
        value = search_box.get_attribute("value")
        self.assertTrue(len(value) > 0)
        search_box.submit()
        time.sleep(1)
        # 计算应用过滤器后可见结果的数量
        # 以便最多只有一个结果出现在一个过滤器中
        feature_count = self.shown_feature_count()
        self.assertTrue(feature_count > 0)
    
    def test_feature_status_page_filters(self):
        self.driver.get("https://webkit.org/status/")
        
        time.sleep(1)
        filters = self.driver.execute_script("return document.querySelectorAll('.filter-toggle')")
        self.assertTrue(len(filters) is 7)
    
        # 确保每个过滤器都是关闭的。
        for checked_filter in filter(lambda f: f.is_selected(), filters):
            checked_filter.click()
    
        # 确保您可以选择每个过滤器。
        for filt in filters:
            filt.click()
            self.assertTrue(filt.is_selected())
            filt.click()

    def shown_feature_count(self):
        return len(self.driver.execute_script("return document.querySelectorAll('li.feature:not(.is-hidden)')"))


if name == "main":
 unittest.main() 

运行您的测试 将上面的测试代码复制并保存为test_webkit.py,然后运行以下命令:

python test_webkit.py

相关推荐
KaMeidebaby2 小时前
卡梅德生物技术快报|骆驼纳米抗体:从原核表达、高通量测序到分子对接全流程实现
前端·数据库·其他·百度·新浪微博
子兮曰4 小时前
Node.js v26.1.0 深度解读:FFI、后量子密码与调试器的进化
前端·后端·node.js
测试员周周4 小时前
【Appium 系列】第06节-页面对象实现 — LoginPage 实战
开发语言·前端·人工智能·python·功能测试·appium·测试用例
西洼工作室5 小时前
前端直传OSS服务端签名(Policy+Signature)/STS临时凭证
前端·文件上传·oss
你很易烊千玺6 小时前
日常练习-数组 字符串常用的场景
前端·javascript·字符串·数组
weixin199701080167 小时前
[特殊字符] RESTful API 接口规范详解:构建高效、可扩展的 Web 服务(附 Python 源码)
前端·python·restful
存在的五月雨7 小时前
Vue3项目一些语法
前端·javascript·react.js
nashane7 小时前
HarmonyOS 6学习:Web组件同层渲染事件处理与智能长截图实现
前端·学习·harmonyos·harmonyos 5
大家的林语冰7 小时前
Node 2026 发布,JS 三大新功能上线,最后一个奇偶版本
前端·javascript·node.js