mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
fb86ecd604
This is an alternative of #31877 to fix #31876 caused by #28808. This issue was caused by a combination of several loose implementation. * finding automatic inverse association of polymorphic without context (caused by #28808) * returning `klass` even if `polymorphic?` (exists before #28808) * loose verification by `valid_inverse_reflection?` (exists before #28808) This makes `klass` raise if `polymorphic?` not to be misused. This issue will not happen unless polymorphic `klass` is misused. Fixes #31876. Closes #31877.
16 lines
635 B
Ruby
16 lines
635 B
Ruby
# frozen_string_literal: true
|
|
|
|
class Face < ActiveRecord::Base
|
|
belongs_to :man, inverse_of: :face
|
|
belongs_to :human, polymorphic: true
|
|
belongs_to :polymorphic_man, polymorphic: true, inverse_of: :polymorphic_face
|
|
# Oracle identifier length is limited to 30 bytes or less, `polymorphic` renamed `poly`
|
|
belongs_to :poly_man_without_inverse, polymorphic: true
|
|
# These is a "broken" inverse_of for the purposes of testing
|
|
belongs_to :horrible_man, class_name: "Man", inverse_of: :horrible_face
|
|
belongs_to :horrible_polymorphic_man, polymorphic: true, inverse_of: :horrible_polymorphic_face
|
|
|
|
validate do
|
|
man
|
|
end
|
|
end
|