Class: Remi::BusinessRules::DataFieldCollection

Inherits:
Object
  • Object
show all
Includes:
Enumerable
Defined in:
lib/remi/cucumber/business_rules.rb

Instance Method Summary collapse

Constructor Details

#initializeDataFieldCollection

Returns a new instance of DataFieldCollection.



362
363
364
# File 'lib/remi/cucumber/business_rules.rb', line 362

def initialize
  @fields = {}
end

Instance Method Details

#[](field_name) ⇒ Object



366
367
368
# File 'lib/remi/cucumber/business_rules.rb', line 366

def [](field_name)
  @fields[field_name]
end

#add_field(subject, field_name) ⇒ Object



382
383
384
# File 'lib/remi/cucumber/business_rules.rb', line 382

def add_field(subject, field_name)
  @fields[field_name] = DataField.new(subject.data_obj, field_name) unless @fields.include? field_name
end

#each(&block) ⇒ Object



370
371
372
# File 'lib/remi/cucumber/business_rules.rb', line 370

def each(&block)
  @fields.each(&block)
end

#keysObject



374
375
376
# File 'lib/remi/cucumber/business_rules.rb', line 374

def keys
  @fields.keys
end

#namesObject



378
379
380
# File 'lib/remi/cucumber/business_rules.rb', line 378

def names
  @fields.values.map(&:name)
end

#onlyObject



386
387
388
389
# File 'lib/remi/cucumber/business_rules.rb', line 386

def only
  raise "Multiple subject fields defined: #{keys}" if @fields.size > 1
  @fields.values.first
end

#valuesObject

All values get tested as strings



392
393
394
# File 'lib/remi/cucumber/business_rules.rb', line 392

def values
  @fields.map { |field_name, field| field.values.map(&:to_s) }.transpose
end