メインコンテンツまでスキップ

satisfy マッチャー

satisfy マッチャーは非常に柔軟で、ほとんどの要件を指定することができます。提供されたブロックが true を返す場合に合格します。

expect(10).to satisfy { |v| v % 5 == 0 }
expect(7).not_to satisfy { |v| v % 5 == 0 }

デフォルトの失敗メッセージ ("expected [actual] to satisfy block") はあまり具体的で役に立ちません。説明を追加するために、引数として独自の説明を提供することができます。

expect(10).to satisfy("be a multiple of 5") do |v|
v % 5 == 0
end

基本的な使用方法

次の内容で "satisfy_matcher_spec.rb" という名前のファイルがあるとします:

RSpec.describe 10 do
it { is_expected.to satisfy { |v| v > 5 } }
it { is_expected.not_to satisfy { |v| v > 15 } }

# deliberate failures
it { is_expected.not_to satisfy { |v| v > 5 } }
it { is_expected.to satisfy { |v| v > 15 } }
it { is_expected.to_not satisfy("be greater than 5") { |v| v > 5 } }
it { is_expected.to satisfy("be greater than 15") { |v| v > 15 } }
end

rspec satisfy_matcher_spec.rb を実行すると、

以下のすべてが出力に含まれるはずです:

| 6 つの例、4 つの失敗 | | expected 10 not to satisfy expression v > 5 | | expected 10 to satisfy expression v > 15 | | expected 10 not to be greater than 5 | | expected 10 to be greater than 15 |