require "machinist" require "machinist/blueprints" begin require "mongo_mapper" rescue LoadError puts "MongoMapper is not installed (gem install mongo_mapper)" exit end module Machinist class Lathe def assign_attribute(key, value) assigned_attributes[key.to_sym] = value if @object.respond_to? "#{key}=" @object.send("#{key}=", value) else @object[key] = value end end end class MongoMapperAdapter def self.has_association?(object, attribute) object.class.associations[attribute] end def self.class_for_association(object, attribute) association = object.class.associations[attribute] association && association.klass end def self.assigned_attributes_without_associations(lathe) attributes = {} lathe.assigned_attributes.each_pair do |attribute, value| association = lathe.object.class.associations[attribute] if association && association.belongs_to? && !value.nil? attributes[association.foreign_key.to_sym] = value.id else attributes[attribute] = value end end attributes end end module MongoMapperExtensions module Document def make(*args, &block) lathe = Lathe.run(Machinist::MongoMapperAdapter, self.new, *args) unless Machinist.nerfed? lathe.object.save! lathe.object.reload end lathe.object(&block) end def make_unsaved(*args) returning(Machinist.with_save_nerfed { make(*args) }) do |object| yield object if block_given? end end def plan(*args) lathe = Lathe.run(Machinist::MongoMapperAdapter, self.new, *args) Machinist::MongoMapperAdapter.assigned_attributes_without_associations(lathe) end end module EmbeddedDocument def make(*args, &block) lathe = Lathe.run(Machinist::MongoMapperAdapter, self.new, *args) lathe.object(&block) end end end end MongoMapper::Document.append_extensions(Machinist::Blueprints::ClassMethods) MongoMapper::Document.append_extensions(Machinist::MongoMapperExtensions::Document) MongoMapper::EmbeddedDocument::ClassMethods.send(:include, Machinist::Blueprints::ClassMethods) MongoMapper::EmbeddedDocument::ClassMethods.send(:include, Machinist::MongoMapperExtensions::EmbeddedDocument)