Merge pull request #3 from pblesi/master

fix seed_once! functionality
This commit is contained in:
John Bintz 2017-04-11 07:30:24 -04:00 committed by GitHub
commit 9feb8e6459
6 changed files with 44 additions and 12 deletions

View File

@ -0,0 +1,5 @@
Feature: Seed Once
Scenario: Seed a record once
Given I have already seeded a record
When I seed the record using seed_once
Then I should not seed the record again

View File

@ -0,0 +1,6 @@
Given(/^I have already seeded a record$/) do
record = Record.new
record[:_id] = 1
record[:data] = 'existing'
record.upsert
end

View File

@ -0,0 +1,4 @@
Then(/^I should not seed the record again$/) do
Record.count.should == 1
Record.find(1).data.should == 'existing'
end

View File

@ -0,0 +1,6 @@
When(/^I seed the record using seed_once$/) do
Record.seed_once :id do |s|
s.id = 1
s.data = 'data'
end
end

View File

@ -27,12 +27,8 @@ end
module Mongoid::Document
module ClassMethods
def seed_once(*constraints)
seeder = SeedFuMongoid::DocumentSeeder.new(self, constraints, block)
if seeder.new?
seeder.seed!
end
def seed_once(*constraints, &block)
SeedFuMongoid::DocumentSeeder.new(self, constraints, block).seed_once!
end
def seed(*constraints_and_objects, &block)

View File

@ -58,9 +58,9 @@ module SeedFuMongoid
return @constraint_search if @constraint_search
@constraint_search = {}
constraints.each do |constraint|
@constraints.each do |constraint|
if data[constraint]
@constraint_search[constraint] = proxy[constraint]
@constraint_search[constraint] = data[constraint]
else
raise ConstraintNotDefined.new(constraint)
end
@ -74,10 +74,14 @@ module SeedFuMongoid
document.send :[]=, key, value
end
puts "#{@klass.name} #{document.attributes}"
puts "#{@klass.name} #{document.attributes}" unless SeedFuMongoid.quiet
document.upsert
end
def new?
!document.persisted?
end
end
def create_document(block_or_object)
@ -94,9 +98,20 @@ module SeedFuMongoid
end
end
def new?
!document.persisted?
def seed_once!
if @objects.empty?
document = create_document(@block)
if document.new?
document.seed!
end
else
@objects.each do |object|
document = create_document(object)
if document.new?
document.seed!
end
end
end
end
end
end