作者热门文章
- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
在railstutorial中,作者为什么选择使用这个(代码 list 10.25): http://ruby.railstutorial.org/chapters/updating-showing-and-deleting-users
namespace :db do
desc "Fill database with sample data"
task :populate => :environment do
Rake::Task['db:reset'].invoke
User.create!(:name => "Example User",
:email => "example@railstutorial.org",
:password => "foobar",
:password_confirmation => "foobar")
99.times do |n|
name = Faker::Name.name
email = "example-#{n+1}@railstutorial.org"
password = "password"
User.create!(:name => name,
:email => email,
:password => password,
:password_confirmation => password)
end
end
end
用假用户填充数据库,以及(代码 list 7.16) http://ruby.railstutorial.org/chapters/modeling-and-viewing-users-two
Factory.define :user do |user|
user.name "Michael Hartl"
user.email "mhartl@example.com"
user.password "foobar"
user.password_confirmation "foobar"
end
看来这两种方式都在数据库中创建用户吧(工厂女孩是否在数据库中创建用户)?两种不同的测试用户创建方式的原因是什么,它们有何不同?什么时候一种方法比另一种更合适?
最佳答案
Faker 和 Factory Girl 在这些例子中被用于两个不同的目的。
rake 任务是使用 Faker 创建的,可以轻松地让您填充数据库,通常是开发数据库。这使您可以浏览包含大量填充的虚假数据的应用。
工厂定义使得测试编写起来很方便。例如,在您的 RSpec 测试中,您可以编写:
before(:each) do
@user = Factory(:user)
end
然后@user 在后面的测试中可用。它会将这些更改写入测试数据库,但请记住,每次运行测试时都会清除这些更改。
关于ruby-on-rails - Railstutorial : db:populate vs. 工厂女孩,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6319595/
我是一名优秀的程序员,十分优秀!