Class: FactoryGirl::Evaluator Private
- Inherits:
-
Object
- Object
- FactoryGirl::Evaluator
- Defined in:
- lib/factory_girl/evaluator.rb
This class is part of a private API. You should avoid using this class if possible, as it may be removed or be changed in the future.
Class Method Summary collapse
- .attribute_list ⇒ Object private
- .define_attribute(name, &block) ⇒ Object private
Instance Method Summary collapse
- #__override_names__ ⇒ Object private
- #association(factory_name, overrides = {}) ⇒ Object private
-
#initialize(build_class, build_strategy, overrides = {}) ⇒ Evaluator
constructor
private
A new instance of Evaluator.
- #instance=(object_instance) ⇒ Object private
- #method_missing(method_name, *args, &block) ⇒ Object private
Constructor Details
#initialize(build_class, build_strategy, overrides = {}) ⇒ Evaluator
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Returns a new instance of Evaluator.
13 14 15 16 17 18 19 20 21 22 |
# File 'lib/factory_girl/evaluator.rb', line 13 def initialize(build_class, build_strategy, overrides = {}) @build_class = build_class @build_strategy = build_strategy @overrides = overrides @cached_attributes = overrides @overrides.each do |name, value| singleton_class.define_attribute(name) { value } end end |
Dynamic Method Handling
This class handles dynamic methods through the method_missing method
#method_missing(method_name, *args, &block) ⇒ Object
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
37 38 39 40 41 42 43 |
# File 'lib/factory_girl/evaluator.rb', line 37 def method_missing(method_name, *args, &block) if @instance.respond_to?(method_name) @instance.send(method_name, *args, &block) else SyntaxRunner.new.send(method_name, *args, &block) end end |
Class Method Details
.attribute_list ⇒ Object
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
49 50 51 52 53 54 55 |
# File 'lib/factory_girl/evaluator.rb', line 49 def self.attribute_list AttributeList.new.tap do |list| attribute_lists.each do |attribute_list| list.apply_attributes attribute_list.to_a end end end |
.define_attribute(name, &block) ⇒ Object
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
57 58 59 60 61 62 63 64 65 |
# File 'lib/factory_girl/evaluator.rb', line 57 def self.define_attribute(name, &block) define_method(name) do if @cached_attributes.key?(name) @cached_attributes[name] else @cached_attributes[name] = instance_exec(&block) end end end |
Instance Method Details
#__override_names__ ⇒ Object
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
45 46 47 |
# File 'lib/factory_girl/evaluator.rb', line 45 def __override_names__ @overrides.keys end |
#association(factory_name, overrides = {}) ⇒ Object
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
26 27 28 29 30 31 |
# File 'lib/factory_girl/evaluator.rb', line 26 def association(factory_name, overrides = {}) strategy_override = overrides.fetch(:strategy) { :create } runner = FactoryRunner.new(factory_name, strategy_override, [overrides.except(:strategy)]) @build_strategy.association(runner) end |
#instance=(object_instance) ⇒ Object
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
33 34 35 |
# File 'lib/factory_girl/evaluator.rb', line 33 def instance=(object_instance) @instance = object_instance end |