提交 ee5ab222 编写于 作者: G Gannon McGibbon

Introduce FixtureSet::ModelMetadata

上级 ea4b52ab
# frozen_string_literal: true
module ActiveRecord
class FixtureSet
class ModelMetadata # :nodoc:
def initialize(model_class, table_name)
@model_class = model_class
@table_name = table_name
end
def primary_key_name
@primary_key_name ||= @model_class && @model_class.primary_key
end
def primary_key_type
@primary_key_type ||= @model_class && @model_class.type_for_attribute(@model_class.primary_key).type
end
def has_primary_key_column?
@has_primary_key_column ||= primary_key_name &&
@model_class.columns.any? { |col| col.name == primary_key_name }
end
def timestamp_column_names
@timestamp_column_names ||=
%w(created_at created_on updated_at updated_on) & column_names
end
def inheritance_column_name
@inheritance_column_name ||= @model_class && @model_class.inheritance_column
end
private
def column_names
@column_names ||= @model_class.connection.columns(@table_name).collect(&:name)
end
end
end
end
......@@ -8,6 +8,7 @@
require "active_support/core_ext/digest/uuid"
require "active_record/fixture_set/file"
require "active_record/fixture_set/render_context"
require "active_record/fixture_set/model_metadata"
require "active_record/test_fixtures"
require "active_record/errors"
......@@ -669,7 +670,7 @@ def table_rows
if model_class
# fill in timestamp columns if they aren't specified and the model is set to record_timestamps
if model_class.record_timestamps
timestamp_column_names.each do |c_name|
model_metadata.timestamp_column_names.each do |c_name|
row[c_name] = now unless row.key?(c_name)
end
end
......@@ -680,8 +681,8 @@ def table_rows
end
# generate a primary key if necessary
if has_primary_key_column? && !row.include?(primary_key_name)
row[primary_key_name] = ActiveRecord::FixtureSet.identify(label, primary_key_type)
if model_metadata.has_primary_key_column? && !row.include?(model_metadata.primary_key_name)
row[model_metadata.primary_key_name] = ActiveRecord::FixtureSet.identify(label, model_metadata.primary_key_type)
end
# Resolve enums
......@@ -693,8 +694,8 @@ def table_rows
# If STI is used, find the correct subclass for association reflection
reflection_class =
if row.include?(inheritance_column_name)
row[inheritance_column_name].constantize rescue model_class
if row.include?(model_metadata.inheritance_column_name)
row[model_metadata.inheritance_column_name].constantize rescue model_class
else
model_class
end
......@@ -760,13 +761,6 @@ def join_table
end
private
def primary_key_name
@primary_key_name ||= model_class && model_class.primary_key
end
def primary_key_type
@primary_key_type ||= model_class && model_class.type_for_attribute(model_class.primary_key).type
end
def add_join_records(rows, row, association)
# This is the case when the join table has no fixtures file
......@@ -778,28 +772,14 @@ def add_join_records(rows, row, association)
targets = targets.is_a?(Array) ? targets : targets.split(/\s*,\s*/)
rows[table_name].concat targets.map { |target|
{ lhs_key => row[primary_key_name],
{ lhs_key => row[model_metadata.primary_key_name],
rhs_key => ActiveRecord::FixtureSet.identify(target, column_type) }
}
end
end
def has_primary_key_column?
@has_primary_key_column ||= primary_key_name &&
model_class.columns.any? { |c| c.name == primary_key_name }
end
def timestamp_column_names
@timestamp_column_names ||=
%w(created_at created_on updated_at updated_on) & column_names
end
def inheritance_column_name
@inheritance_column_name ||= model_class && model_class.inheritance_column
end
def column_names
@column_names ||= @connection.columns(@table_name).collect(&:name)
def model_metadata
@model_metadata ||= ModelMetadata.new(model_class, table_name)
end
def model_class=(class_name)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册