aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--activerecord/lib/active_record/enum.rb17
-rw-r--r--activerecord/test/cases/enum_test.rb6
2 files changed, 19 insertions, 4 deletions
diff --git a/activerecord/lib/active_record/enum.rb b/activerecord/lib/active_record/enum.rb
index 9263dc1e6b..5fcc0382d8 100644
--- a/activerecord/lib/active_record/enum.rb
+++ b/activerecord/lib/active_record/enum.rb
@@ -31,17 +31,26 @@ module ActiveRecord
# class Conversation < ActiveRecord::Base
# enum status: { active: 0, archived: 1 }
# end
+ #
+ # In rare circumstances you might need to access the mapping directly.
+ # The mappings are exposed through a constant with the attributes name:
+ #
+ # Conversation::STATUS # => { "active" => 0, "archived" => 1 }
+ #
+ # Use that constant when you need to know the ordinal value of an enum:
+ #
+ # Conversation.where("status <> ?", Conversation::STATUS[:archived])
module Enum
def enum(definitions)
klass = self
definitions.each do |name, values|
- enum_values = {}
+ # DIRECTION = { }
+ enum_values = _enum_methods_module.const_set name.to_s.upcase, ActiveSupport::HashWithIndifferentAccess.new
name = name.to_sym
_enum_methods_module.module_eval do
# def direction=(value) self[:direction] = DIRECTION[value] end
define_method("#{name}=") { |value|
- value = value.to_s
unless enum_values.has_key?(value)
raise ArgumentError, "'#{value}' is not a valid #{name}"
end
@@ -53,7 +62,7 @@ module ActiveRecord
pairs = values.respond_to?(:each_pair) ? values.each_pair : values.each_with_index
pairs.each do |value, i|
- enum_values[value.to_s] = i
+ enum_values[value] = i
# scope :incoming, -> { where direction: 0 }
klass.scope value, -> { klass.where name => i }
@@ -62,7 +71,7 @@ module ActiveRecord
define_method("#{value}?") { self[name] == i }
# def incoming! update! direction: :incoming end
- define_method("#{value}!") { update! name => value.to_sym }
+ define_method("#{value}!") { update! name => value }
end
end
end
diff --git a/activerecord/test/cases/enum_test.rb b/activerecord/test/cases/enum_test.rb
index 54cc60913a..35e8a98156 100644
--- a/activerecord/test/cases/enum_test.rb
+++ b/activerecord/test/cases/enum_test.rb
@@ -57,4 +57,10 @@ class EnumTest < ActiveRecord::TestCase
end
assert_equal "'unknown' is not a valid status", e.message
end
+
+ test "constant to access the mapping" do
+ assert_equal 0, Book::STATUS[:proposed]
+ assert_equal 1, Book::STATUS["written"]
+ assert_equal 2, Book::STATUS[:published]
+ end
end