Updated

features/step_definitions / pickle_steps.rb

C
100 lines of codes
0 methods
N/A complexity/method
2 churn
0.0 complexity
160 duplications
# this file generated by script/generate pickle # create a model Given(/^#{capture_model} exists?(?: with #{capture_fields})?$/) do |name, fields| create_model(name, fields) end # create n models Given(/^(\d+) #{capture_plural_factory} exist(?: with #{capture_fields})?$/) do |count, plural_factory, fields| count.to_i.times { create_model(plural_factory.singularize, fields) } end # create models from a table Given(/^the following #{capture_plural_factory} exists?:?$/) do |plural_factory, table| create_models_from_table(plural_factory, table) end # find a model Then(/^#{capture_model} should exist(?: with #{capture_fields})?$/) do |name, fields| find_model!(name, fields) end # not find a model Then(/^#{capture_model} should not exist(?: with #{capture_fields})?$/) do |name, fields| expect(find_model(name, fields)).to be_nil end # find models with a table Then(/^the following #{capture_plural_factory} should exists?:?$/) do |plural_factory, table| expect(find_models_from_table(plural_factory, table)).not_to be_any(&:nil?) end # find exactly n models Then(/^(\d+) #{capture_plural_factory} should exist(?: with #{capture_fields})?$/) do |count, plural_factory, fields| expect(find_models(plural_factory.singularize, fields).size).to == count.to_i end # assert equality of models Then(/^#{capture_model} should be #{capture_model}$/) do |a, b| expect(model!(a)).to eq model!(b) end # assert model is in another model's has_many assoc Then(/^#{capture_model} should be (?:in|one of|amongst) #{capture_model}(?:'s)? (\w+)$/) do |target, owner, association|
  1. Similar code found in 2 nodes Locations: 0 1
expect(model!(owner).send(association)).to include(model!(target)) end # assert model is not in another model's has_many assoc Then(/^#{capture_model} should not be (?:in|one of|amongst) #{capture_model}(?:'s)? (\w+)$/) do |target, owner, association|
  1. Similar code found in 2 nodes Locations: 0 1
expecT(model!(owner).send(association)).not_to include(model!(target)) end # assert model is another model's has_one/belongs_to assoc Then(/^#{capture_model} should be #{capture_model}(?:'s)? (\w+)$/) do |target, owner, association|
  1. Similar code found in 2 nodes Locations: 0 1
expect(model!(owner).send(association)).to == model!(target) end # assert model is not another model's has_one/belongs_to assoc Then(/^#{capture_model} should not be #{capture_model}(?:'s)? (\w+)$/) do |target, owner, association|
  1. Similar code found in 2 nodes Locations: 0 1
expect(model!(owner).send(association)).not_to == model!(target) end # assert model.predicate? Then(/^#{capture_model} should (?:be|have) (?:an? )?#{capture_predicate}$/) do |name, predicate|
  1. Similar code found in 2 nodes Locations: 0 1
if model!(name).respond_to?("has_#{predicate.gsub(' ', '_')}") expect(model!(name)).to send("have_#{predicate.gsub(' ', '_')}") else expect(model!(name)).to send("be_#{predicate.gsub(' ', '_')}") end end # assert not model.predicate? Then(/^#{capture_model} should not (?:be|have) (?:an? )?#{capture_predicate}$/) do |name, predicate|
  1. Similar code found in 2 nodes Locations: 0 1
if model!(name).respond_to?("has_#{predicate.gsub(' ', '_')}") expect(model!(name)).not_to send("have_#{predicate.gsub(' ', '_')}") else expect(model!(name)).not_to send("be_#{predicate.gsub(' ', '_')}") end end # expect(model.attribute).to eql(value) # expect(model.attribute).not_to eql(value) Then(/^#{capture_model}'s (\w+) (should(?: not)?) be #{capture_value}$/) do |name, attribute, expectation, expected| actual_value = model(name).send(attribute) expectation = (expectation.include?('not') ? :not_to : :to) case expected when 'nil', 'true', 'false' expect(actual_value).send(expectation, send("be_#{expected}")) when /^[+-]?[0-9_]+(\.\d+)?$/ expect(actual_value).send(expectation, eql(expected.to_f)) else expect(actual_value.to_s).send(expectation, eql(eval(expected))) end end # assert size of association Then /^#{capture_model} should have (\d+) (\w+)$/ do |name, size, association| expect(model!(name).send(association).size).to eq size.to_i end