我有一个属于用户的用户模型和运营商模型。我创建了一些关联它们的工厂(在我的功能中,当操作员注册时创建用户帐户),所以我迈出了这一步:
def create_operator_with_user(operator_name)
user = Factory(:user)
puts "MY PASS: #{user.password}"
operator = Factory(:operator, :chief_pilot_or_business_owner => operator_name, :user_id => user.id)
pew = User.find(operator.user_id)
puts "USER: #{operator.user.inspect} PASS: #{operator.user.password} PEWPASS: #{pew.password}"
end
这是我的用户工厂:
Factory.define :admin, :class => User do |f|
f.sequence(:login) { |n| "admin#{n}"}
f.is_admin true
f.password "password"
f.password_confirmation "password"
f.sequence(:email) { |n| "test#{n}@test.com"}
end
Factory.define :user, :parent => :admin do |f|
f.sequence(:login) { |n| "user_#{n}" }
f.sequence(:email) { |n| "the_user_#{n}@asdf.com" }
end
我试图运行我的功能,这是输出:
MY PASS: password
USER: #<User id: 181, login: "user_1", email: "the_user_1@asdf.com", crypted_password: "e9f6932a07cbe6e49073a331530f9dc01a3482502d25770be00...", password_salt: "YEjT9Q8EGYdrNh4qGZda", persistence_token: "259a61440f6ecd001e79a4aaf1c5c343e50be04388bbf1718c3...", created_at: "2011-06-02 04:24:34", updated_at: "2011-06-02 04:24:34", is_admin: true>
PASS:
PEWPASS:
所以问题是,用户有密码,因为它被允许创建,更不用说它在使用工厂创建后打印出来了。问题是,当我尝试通过User.find(user.id)或operator.user访问密码时,为什么密码为空?
如果有帮助,这适用于authlogic
答案 0 :(得分:0)
这有用吗?
Factory.define :admin, :class => :user do |f|
答案 1 :(得分:0)
似乎我试图访问authlogic的受保护属性,这就是为什么即使我再次尝试获取用户对象也无法访问密码的原因。我的解决方案是使用全局变量(@user),以便我可以在其他步骤中访问它。