我试图断言所有结果是值A还是值b。我的设置如下:
def results
all('.results li')
end
def apply_filter(filter)
filter_by(filter)
end
def have_product_type(type)
have_selector('.type', text: type)
end现在,我需要断言所有的结果要么是A型,要么是B型。
我想做这样的事:
apply_filter('A')
apply_filter('B')
expect(results).to all(have_product_type('A').or have_product_type('B'))别以为在水豚里还不支持复式匹配。它一次只适用于一个断言。例如,这起作用是:
expect(results).to all(have_product_type('A'))我也尝试了正常的RSpec匹配,但后来水豚链不适合它。
例如,这也不起作用,因为这些方法是通过config.include包含在特性规范中的助手方法。当have_product_type方法位于全局命名空间时,我会得到未定义的方法错误。
expect(results.all {|result| result.have_product_type('A') or result.have_product_type('B')}.to be_truthy我如何测试这两种情况?
发布于 2016-04-15 20:34:54
在Capybara支持复合匹配,只要您在Capybaras matchers之前确保“rspec/ ensure”是必需的。有一点要注意的是,在你的例子中
expect(results).to all(have_product_type('A').or have_product_type('B'))卡比巴拉的等待行为可能会使你的这部分测试非常缓慢。这可能是因为have_product_type( 'A‘)会等到Capybara.default_max_wait_time秒后,结果中的每个元素都会出现匹配的’A‘元素,所以如果大多数元素实际上与'B’匹配,则延迟可能很长。在这种情况下,您可能想要检查页面上的更改,该更改指示已应用了筛选器,然后将wait: false传递给预期中使用的have_selector匹配器(或在using_wait_time(0){ expect ... }块中执行期望)。
注意:您也可以使用regex版本的:text选项来实现您想要实现的内容,如下所示
expect(results).to all(have_product_type(/^(A|B)$/'))https://stackoverflow.com/questions/36655274
复制相似问题