css - 使用 capybara 检查 CSS 是否已更新

标签 css ruby selenium capybara

我目前正在编写一个基于用户输入更新其页面 CSS 的网络应用程序。我一切正常,但我无法让我的自动化测试确认 CSS 确实已更新。

基本上,我只想验证 <style> 的内容文档中的标记 <head>已更新为某个值。我正在使用 capybara (带有 selenium 驱动程序)进行测试,代码如下:

styles = page.all('style')
styles.length.should == 1
styles[0].text.should == style

一切都按预期进行,直到最后一行失败,因为它似乎是 styles[0].text总是 ””。我也试过 .value但它总是nil .我很确定 CSS 实际上正在更新,因为我可以在运行测试的 firefox 窗口中看到更改。

那么,有没有办法获取 <style> 的内容?使用 capybara 标记?

最佳答案

似乎 Capybara(至少使用 Selenium,我没有尝试任何其他驱动程序)不会向您展示这个,我想是因为样式内容包含在 HTML 注释中,所以它会被忽略,例如:

<STYLE type="text/css">
    <!--
    .newfont { color:red; font-style:italic }
    -->
</STYLE>

但是,您可以使用 page.source 访问页面的源代码,因此您可以使用它来获取样式内容。源代码只是一个大字符串,因此深入研究它的一种方法是使用 Nokogiri 对其进行解析(这是 Capybara 所必需的,因此您已经拥有它):

page = Nokogiri::HTML.parse(page.source)
page.css('style').first.text

# => "\n&lt;!--\n.newfont { color:red; font-style:italic }\n--&gt;\n"

如果您针对可自定义的样式进行断言,并且无论如何您都在使用 Selenium,则另一种解决方案可能涉及使用 Javascript 来确定元素的计算样式,似乎有 no shortage有关执行此操作的信息。您可以使用 Capybara 的 page.evaluate_script 方法来调用一段 Javascript,它会告诉您特定元素的实际外观,并且可能比比较 CSS 文本更可靠(例如,如果它得到由应用缩小)。

关于css - 使用 capybara 检查 CSS 是否已更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12130984/

相关文章:

java - 我如何返回以 Ex : TC00 in java 开头的完整文件路径

javascript - 页面开始加载时是否可以使用 Ruby 的 selenium-webdriver 执行 script

html - 滚动图像的 CSS 和视差问题

html - 当 div 具有动态高度内容时,如何将 div 粘贴在其他粘性 div 下方?

Javascript、getElementById 和样式不起作用 : Uncaught TypeError: Cannot read property 'style' of null

javascript - 如何使用 JavaScript 隐藏正文但保持图像显示

ruby - 删除散列中不在数组中的键

ruby - Profound Grid 找不到clearfix

javascript - 将 Javascript 库 (jsPDF) 与 Ruby-on-Rails View 结合使用

python - Selenium 页面源缺少元素