gpt4 book ai didi

ruby-on-rails - Railstutorial : db:populate vs. 工厂女孩

转载 作者:数据小太阳 更新时间:2023-10-29 07:13:56 25 4
gpt4 key购买 nike

在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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com