- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我有一个子类化另一个模型的模型,这个特定模型不使用我指定的表,而是默认返回到试图找到该表的父类。
父类在gem中,子类在 namespace 隔离的引擎中。
父级(在 gem 中):
require_relative 'concerns/user_concerns'
require 'bcrypt'
module CoreModels
module Models
class User < ActiveRecord::Base
self.abstract_class = true
extend FriendlyId
friendly_id :first_name, use: [:slugged, :finders, :history]
before_save :encrypt_password
has_many :group_memberships, :dependent => :delete_all
has_many :groups, :through => :group_memberships, :dependent => :delete_all
has_many :roles, :through => :group_memberships, :dependent => :delete_all
has_many :api_keys
validates :first_name, presence: true
validates :user_name, uniqueness: true, presence: true, length: {minimum: 5}
validates :email, presence: true, confirmation: true, uniqueness: true
validates_format_of :email, :with => /\A([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})\z/i
validates :password, presence: true, confirmation: true, length: { minimum: 10 }, if: :new_record?
include CoreModels::Models::Concerns::UserConcerns
before_create{ generate_token(:auth_token) }
def self.authenticate_user(user_name, password)
user = Xaaron::User.find_by_user_name(user_name)
if(user && (user.password == BCrypt::Engine.hash_secret(password, user.salt)))
user
else
nil
end
end
def encrypt_password
if password.present?
self.salt = BCrypt::Engine.generate_salt
self.password = BCrypt::Engine.hash_secret(password, salt)
end
end
def send_password_reset
generate_token(:password_reset_token)
self.password_reset_timestamp = Time.zone.now
save!
UserMailer.password_reset(self).deliver
end
protected
def generate_token(column)
begin
self[column] = SecureRandom.urlsafe_base64
end while User.exists?(column => self[column])
end
end
end
end
child (在引擎中):
require 'core_models/models/user'
module Xaaron
class User < CoreModels::Models::User
self.table_name = 'xaaron_users'
end
end
当我运行我的测试时,其中 135 个失败,一遍又一遍地给我同样的错误:
Failure/Error: setup_group_role_permissions_relations_for_administrator
ActiveRecord::StatementInvalid:
PG::UndefinedTable: ERROR: relation "users" does not exist
LINE 5: WHERE a.attrelid = '"users"'::regclass
^
: SELECT a.attname, format_type(a.atttypid, a.atttypmod),
pg_get_expr(d.adbin, d.adrelid), a.attnotnull, a.atttypid, a.atttypmod
FROM pg_attribute a LEFT JOIN pg_attrdef d
ON a.attrelid = d.adrelid AND a.attnum = d.adnum
WHERE a.attrelid = '"users"'::regclass
AND a.attnum > 0 AND NOT a.attisdropped
ORDER BY a.attnum
这个特殊的方法是:
def setup_group_role_permissions_relations_for_administrator
@user = FactoryGirl.create(:user)
@role = FactoryGirl.create(:admin_role)
@group = FactoryGirl.create(:administrator_group)
@permission = FactoryGirl.create(:can_read)
@role.add_permission = @permission.permission_name
@group.add_role = @role.role_name
@user.add_group_membership(@group, @role)
end
所以你可以看到当我说使用表 x 时它没有听我说。相反,它试图使用一个不存在的表。/我所有的引擎表都是用 xaaron_
经过一些调查,核心问题是 FactoryGirl,如果我们看一下发生在以下位置的第一件事:setup_group_role_permissions_relations_for_administrator
我在做 @user = FactoryGirl.create(:user)
,当我用 pry 弄清楚那里发生了什么时 - 这就是问题所在,所以让我们看看这个工厂:
FactoryGirl.define do
sequence :user_email do |n|
"user#{n}@example.com"
end
# Allows for multiple user names
sequence :user_name do |n|
"user#{n}"
end
sequence :permission_name do |n|
"can_read#{n}"
end
sequence :role_name do |n|
"Member#{n}"
end
factory :user, :class => Xaaron::User do
first_name 'Adam'
last_name 'Something'
user_name {generate :user_name}
email {generate :user_email}
password 'somePasswordThat_Is$ecure10!'
end
factory :admin, :class => Xaaron::User do
first_name "Sample Admin"
email "a@gmail.com"
user_name "Admin_User_Name"
password "admin_Password10985"
end
end
factory girl 创建用户的方式有问题,因为我可以启动 Rails 控制台并执行 Xaaron::User.all
并且它知道查看 xaaron_users
而不是 users
所以 self.table_name=""
可以工作,但由于某种原因不能与工厂女郎一起工作。
我已经在以下位置提交了一份可能的错误报告:Their Github Repo
最佳答案
一般来说,Active Record 被设计为使用单表继承(同一张表用于所有子类的记录)而不是多表继承(子类使用不同的表。)
也就是说,您可以尝试覆盖 table_name
方法,而不是使用 self.table_name =
在您的子类中设置表名
def table_name
'xaaron_users'
end
看看这是否适用于您的场景。这是 mentioned as an alternative in the docs .
关于ruby-on-rails - Rails 不使用模型指定的表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28463305/
可不可以命名为MVVM模型?因为View通过查看模型数据。 View 是否应该只与 ViewModelData 交互?我确实在某处读到正确的 MVVM 模型应该在 ViewModel 而不是 Mode
我正在阅读有关设计模式的文章,虽然作者们都认为观察者模式很酷,但在设计方面,每个人都在谈论 MVC。 我有点困惑,MVC 图不是循环的,代码流具有闭合拓扑不是很自然吗?为什么没有人谈论这种模式: mo
我正在开发一个 Sticky Notes 项目并在 WPF 中做 UI,显然将 MVVM 作为我的架构设计选择。我正在重新考虑我的模型、 View 和 View 模型应该是什么。 我有一个名为 Not
不要混淆:How can I convert List to Hashtable in C#? 我有一个模型列表,我想将它们组织成一个哈希表,以枚举作为键,模型列表(具有枚举的值)作为值。 publi
我只是花了一些时间阅读这些术语(我不经常使用它们,因为我们没有任何 MVC 应用程序,我通常只说“模型”),但我觉得根据上下文,这些意味着不同的东西: 实体 这很简单,它是数据库中的一行: 2) In
我想知道你们中是否有人知道一些很好的教程来解释大型应用程序的 MVVM。我发现关于 MVVM 的每个教程都只是基础知识解释(如何实现模型、 View 模型和 View ),但我对在应用程序页面之间传递
我想realm.delete() 我的 Realm 中除了一个模型之外的所有模型。有什么办法可以不列出所有这些吗? 也许是一种遍历 Realm 中当前存在的所有类型的方法? 最佳答案 您可以从您的 R
我正在尝试使用 alias 指令模拟一个 Eloquent 模型,如下所示: $transporter = \Mockery::mock('alias:' . Transporter::class)
我正在使用 stargazer 创建我的 plm 汇总表。 library(plm) library(pglm) data("Unions", package = "pglm") anb1 <- pl
我读了几篇与 ASP.NET 分层架构相关的文章和问题,但是读得太多后我有点困惑。 UI 层是在 ASP.NET MVC 中开发的,对于数据访问,我在项目中使用 EF。 我想通过一个例子来描述我的问题
我收到此消息错误: Inceptionv3.mlmodel: unable to read document 我下载了最新版本的 xcode。 9.4 版测试版 (9Q1004a) 最佳答案 您没有
(同样,一个 MVC 验证问题。我知道,我知道......) 我想使用 AutoMapper ( http://automapper.codeplex.com/ ) 来验证我的创建 View 中不在我
需要澄清一件事,现在我正在处理一个流程,其中我有两个 View 模型,一个依赖于另一个 View 模型,为了处理这件事,我尝试在我的基本 Activity 中注入(inject)两个 View 模型,
如果 WPF MVVM 应该没有代码,为什么在使用 ICommand 时,是否需要在 Window.xaml.cs 代码中实例化 DataContext 属性?我已经并排观看并关注了 YouTube
当我第一次听说 ASP.NET MVC 时,我认为这意味着应用程序由三个部分组成:模型、 View 和 Controller 。 然后我读到 NerdDinner并学习了存储库和 View 模型的方法
Platform : ubuntu 16.04 Python version: 3.5.2 mmdnn version : 0.2.5 Source framework with version :
我正在学习本教程:https://www.raywenderlich.com/160728/object-oriented-programming-swift ...并尝试对代码进行一些个人调整,看看
我正试图围绕 AngularJS。我很喜欢它,但一个核心概念似乎在逃避我——模型在哪里? 例如,如果我有一个显示多个交易列表的应用程序。一个列表向服务器查询匹配某些条件的分页事务集,另一个列表使用不同
我在为某个应用程序找出最佳方法时遇到了麻烦。我不太习惯取代旧 TLA(三层架构)的新架构,所以这就是我的来源。 在为我的应用程序(POCO 类,对吧??)设计模型和 DAL 时,我有以下疑问: 我的模
我有两个模型:Person 和 Department。每个人可以在一个部门工作。部门可以由多人管理。我不确定如何在 Django 模型中构建这种关系。 这是我不成功的尝试之一 [models.py]:
我是一名优秀的程序员,十分优秀!