aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPetteri Räty <betelgeuse@gentoo.org>2011-03-12 22:00:20 +0200
committerPetteri Räty <betelgeuse@gentoo.org>2011-03-12 22:00:20 +0200
commitee550e2c44169f2004ec4345748fbba1ed7fc6f6 (patch)
tree0841e8b4f888c24ce44a005520744a1cc1bbf26d
parentTypo fixes (diff)
downloadrecruiting-webapp-ee550e2c44169f2004ec4345748fbba1ed7fc6f6.tar.gz
recruiting-webapp-ee550e2c44169f2004ec4345748fbba1ed7fc6f6.tar.bz2
recruiting-webapp-ee550e2c44169f2004ec4345748fbba1ed7fc6f6.zip
Simplify factory sequence usage
Instead of creating separate sequences just use the inline block syntax in cases where the sequence is only needed in one place.
-rw-r--r--spec/factories.rb48
1 files changed, 8 insertions, 40 deletions
diff --git a/spec/factories.rb b/spec/factories.rb
index 3ead1e1..5253103 100644
--- a/spec/factories.rb
+++ b/spec/factories.rb
@@ -1,54 +1,34 @@
- Factory.sequence :recruit do |n|
- "recruit-#{n}"
- end
-
- Factory.sequence :mentor do |n|
- "mentor-#{n}"
- end
-
- Factory.sequence :recruiter do |n|
- "recruiter-#{n}"
- end
-
- Factory.sequence :administrator do |n|
- "administrator-#{n}"
- end
-
# Creates a new mentor for recruit by default
Factory.define :recruit, :class => User do |u|
- u.name { Factory.next(:recruit) }
+ u.sequence(:name) { |n| "recruit-#{n}" }
u.email_address { |u| "#{u.name}@recruits.org" }
u.mentor { Factory(:mentor) }
end
Factory.define :mentor, :class => User do |u|
- u.name { Factory.next(:mentor) }
+ u.sequence(:name) { |n| "mentor-#{n}" }
u.email_address { |u| "#{u.name}@recruiters.org" }
u.role :mentor
u.nick { |u| u.name }
end
Factory.define :recruiter, :class => User do |u|
- u.name { Factory.next(:recruiter) }
+ u.sequence(:name) { |n| "recruiter-#{n}" }
u.email_address { |u| "#{u.name}@recruiters.org" }
u.role :recruiter
u.nick { |u| u.name }
end
Factory.define :administrator, :class => User do |u|
- u.name { Factory.next(:administrator) }
+ u.sequence(:name) { |n| "administrator-#{n}" }
u.email_address { |u| "#{u.name}@admins.org" }
u.role :recruiter
u.administrator true
u.nick { |u| u.name }
end
- Factory.sequence :category do |n|
- "category-#{n}"
- end
-
Factory.define :category do |q|
- q.name { Factory.next(:category) }
+ q.sequence(:name) { |n| "category-#{n}" }
end
Factory.define :question_category do |qc|
@@ -56,13 +36,9 @@
qc.association :category
end
- Factory.sequence :question do |n|
- "question-#{n}"
- end
-
# it'll belong to new category by default
Factory.define :question do |q|
- q.title { Factory.next(:question) }
+ q.sequence(:title) { |n| "question-#{n}" }
q.after_build { |q|
q.categories = [Factory.build :category]
}
@@ -91,14 +67,10 @@
q.category { Factory(:category) }
end
- Factory.sequence :comment do |n|
- "comment-#{n}"
- end
-
Factory.define :comment do |c|
c.answer { Factory(:answer) }
c.owner { |c| c.answer.owner.mentor }
- c.content { Factory.next(:comment) }
+ c.sequence(:content) { |n| "comment-#{n}" }
end
# create new recruit (being accepted) and mentor (accepting) by default
@@ -107,12 +79,8 @@
a.accepting_nick { Factory(:mentor).nick }
end
- Factory.sequence :question_group do |n|
- "question_group-#{n}"
- end
-
Factory.define :question_group do |c|
- c.name { Factory.next(:question_group) }
+ c.sequence(:name) { |n| "question_group-#{n}" }
c.description "Just another group"
end