受け入れテストにRSpec2とCapybaraを使用しています。
カピバラではリンクが無効になっているかどうかを断言したいと思います。これどうやってするの?
リンクを無効にする方法は?追加するクラスですか?属性ですか?
# Check for a link that has a "disabled" class:
page.should have_css("a.my_link.disabled")
page.should have_xpath("//a[@class='disabled']")
# Check for a link that has a "disabled" attribute:
page.should have_css("a.my_link[disabled]")
page.should have_xpath("//a[@class='disabled' and @disabled='disabled']")
# Check that the element is visible
find("a.my_link").should be_visible
find(:xpath, "//a[@class='disabled']").should be_visible
実際のxpathセレクタは間違っている可能性があります。私はxpathを頻繁に使用しません!
別の簡単な解決策は、[]
で探しているHTML属性にアクセスすることです。
find('#my_element')['class']
# => "highlighted clearfix some_other_css_class"
find('a#my_element')['href']
# => "http://example.com
# or in general, find any attribute, even if it does not exist
find('a#my_element')['no_such_attribute']
# => ""
Capybara
は、非同期リクエストが終了するのを自動的に待機しようとしますが、場合によっては動作しない可能性があることに注意してください。
非同期に更新される要素のアサーションに問題がある場合の回避策の1つを次に示します。
正しいxpathを見つけるのは少し面倒でした。正しいものはここにあります。
カピバラ0.4.1.1を使用
# <a href="/clowns?ordered_by=clumsyness" class="weep">View Clowns</a>
page.should have_xpath("//a[@class='weep'][@href='/clowns?ordered_by=clumsyness']", :text => "View Clowns")
クラスのないリンクしかない場合は、
page.should have_link('View Clowns', :href => '/clowns?ordered_by=clumsyness')
悲しいことに、このようなものは機能しません:
page.should have_link('This will not work!', :href => '/clowns?ordered_by=clumsyness', :class => "weep")
クラスオプションは無視されます。
_have_link
_とfind_link(name)[:disabled]
を2つの別々のアサーションで使用することをお勧めします。 2番目のアサーションのみを実行する方が簡単ですが、これにより、リンクの欠落に関するエラーメッセージが見やすくなり、テスト結果が読みやすくなります。
_expect(page).to have_link "Example"
expect(find_link("Example")[:disabled]).to be false
_
_"Example"
_はリンクの名前またはIDに変更できることに注意してください。
可能な限り、ドライバー全体でより一貫して動作するCapybara提供のラッパーを使用するようにしてください。
disabled
の特定の場合、2.1でラッパーが導入されました: https://github.com/jnicklas/capybara/blob/fc56557a5463b9d944207f2efa401faa5b49d9ef/History.md#version-21
これを使用すると、RackTestとPoltergeistの両方で適切な結果が得られます。
HTML:
<input type="text" id="disabled-false" ></div>
<input type="text" id="disabled-true" disabled></div>
<input type="text" id="disabled-js-true" ></div>
<input type="text" id="disabled-js-false" disabled></div>
<script>
document.getElementById('disabled-js-true').disabled = true
document.getElementById('disabled-js-false').disabled = false
</script>
テスト:
!all(:field, 'disabled-false', disabled: false).empty? or raise
all(:field, 'disabled-false', disabled: true ).empty? or raise
all(:field, 'disabled-true', disabled: false).empty? or raise
!all(:field, 'disabled-true', disabled: true ).empty? or raise
all(:field, 'disabled-js-true', disabled: true ).empty? or raise
all(:field, 'disabled-js-false', disabled: false).empty? or raise
Capybara.current_driver = :poltergeist
!all(:field, 'disabled-false', disabled: false).empty? or raise
all(:field, 'disabled-false', disabled: true ).empty? or raise
all(:field, 'disabled-true', disabled: false).empty? or raise
!all(:field, 'disabled-true', disabled: true ).empty? or raise
!all(:field, 'disabled-js-true', disabled: true ).empty? or raise
!all(:field, 'disabled-js-false', disabled: false).empty? or raise
CSSセレクターの代わりにこれを使用することにより、Js対応ドライバーを使用し始めた場合に、Javascriptテストが変更なしで機能することに注意してください。
実行可能なテストファイル ここ 。
page.should have_link('It will work this way!', {:href => '/clowns?ordered_by=clumsyness', :class => "smile"})
have_linkは、何も指定しない場合は空のオプションのハッシュを期待します。リンクに必要な属性を指定できます。すべてのオプションを1つのハッシュで渡すようにしてください。
お役に立てれば
PS:data-methodのような属性の場合、属性名を文字列として渡す必要があります。これは、ハイフンが記号を分割するためです。
ドキュメント によると、[属性]アクセサー構文を使用できます。
find('#selector')['class'] => "form-control text optional disabled"
無効の場合は、次のこともできます。
expect(find('#selector').disabled?).to be(true)
Rspec3の構文を使用して、私はこのようにしました:
expect(page).not_to have_selector(:link_or_button, 'Click here')
単純にpage.has_css?
メソッドを使用できます
page.has_css?('.class_name')
要素が存在する場合、これはtrue
を返します。
検証に基づいて何らかのアクションを実行します。
page.has_css?('.class_name') do
#some code
end
bowsersenior、ヒントをありがとう
もう1つの簡単な解決策は、[]で探しているHTML属性にアクセスすることです
以下に例を示します。
let(:action_items) { page.find('div.action_items') }
it "action items displayed as buttons" do
action_items.all(:css, 'a').each do |ai|
expect(ai[:class]).to match(/btn/)
end
end