前言
Splinter 是用 Python 开发的一个开源web自动化测试的工具集。 它可以帮你自动化浏览器的行为,比如浏览 URLs 并和页面进行交互。
快速上手
安装
从终端运行:
1 | pip install splinter |
安装相应的浏览器驱动
Chrome浏览器驱动:https://sites.google.com/a/chromium.org/chromedriver/downloads
Firefox浏览器驱动:https://github.com/mozilla/geckodriver/releases
根据相应的浏览器下载对应的驱动版本,并将驱动所在的路径加入环境变量。
创建一个 Browser 实例
1 | from splinter import Browser |
提示: 如果你不为 Browser 指定 driver, 那么会默认使用 firefox。
访问百度搜索页面
使用 browser.visit
方法可访问任意网站. 让我们访问一下百度搜索页面:
1 | browser.visit('http://baidu.com') |
输入搜索关键词
页面加载完毕后,你能进行一系列的交互,比如点击,输入框填充字段,选择单选按钮和复选框。让我们在百度搜索框中填充 splinter - python acceptance testing for web applications
。
1 | browser.fill('wd', 'splinter - python acceptance testing for web applications') |
点击搜索按钮
告诉 Splinter 哪一个按钮需要点击。这个按钮 - 或任意其他元素 - 可以通过它的css, xpath, id, tag 或 name来识别。
通过以下操作找到百度搜索按钮:
1 | button = browser.find_by_xpath('//input[@type="submit"]') |
提示一下,这个 xpath 语法所在的按钮 会在百度搜索页面的源码中被找到。
找到按钮后,我们就可以进行点击操作:
1 | button.click() |
提示: 以上展示的两步可以结合为一行代码,如下所示:
1 | browser.find_by_xpath('//input[@type="submit"]').click() |
查看 Splinter 官方网站是否在搜索结果中
点击搜索按钮后,你可以通过以下步骤检测 Splinter 官方网站是否在搜索结果中。
1 | if browser.is_text_present('splinter.readthedocs'): |
在这个小例子中, 我们只是打印出了结果. 当写测试的时候,你需要使用断言。
关闭浏览器
结束测试后,我们需要使用 browser.quit 关闭浏览器:
1 | browser.quit() |
总结
最后完整的代码如下所示:
1 | from splinter import Browser |
翻译计划
上述的介绍是来自于我近期翻译的 Splinter 文档中快速上手部分,非常感谢一叶染秋加入翻译计划。我们目前只是翻译了一小部分,还有很多没有翻译,如果你想加入翻译计划可以给 Github 上的Splinter 中文文档项目提交PR,翻译前请先私信我你想翻译的章节,避免大家重复翻译。如果有翻译不对或者不好的地方也欢迎大家多多提建议。
彩蛋
最早的时候大家都会使用 Phantomjs 来实现headless,但是多多少少会有一些不足的地方。现在 Chrome 和 Firefox 都已经提供了相应的 headless 模式,而且 Splinter 也已经集成。
1 | from splinter import Browser |
通过一个简单的参数即可启用 headless 模式,赶快去试试吧!(Ps: 我为这个功能做了一点微小的工作)