mirror of
https://github.com/github/rails.git
synced 2026-04-26 03:00:59 -04:00
Merge branch 'master' of gitproxy:rails/rails
This commit is contained in:
@@ -295,6 +295,10 @@ module ActionView
|
||||
end
|
||||
end
|
||||
|
||||
def error_message
|
||||
object.errors[@method_name]
|
||||
end
|
||||
|
||||
def column_type
|
||||
object.send(:column_for_attribute, @method_name).type
|
||||
end
|
||||
|
||||
@@ -147,6 +147,20 @@ class ActiveModelHelperTest < ActionView::TestCase
|
||||
)
|
||||
end
|
||||
|
||||
def test_field_error_proc
|
||||
old_proc = ActionView::Base.field_error_proc
|
||||
ActionView::Base.field_error_proc = Proc.new do |html_tag, instance|
|
||||
%(<div class=\"fieldWithErrors\">#{html_tag} <span class="error">#{[instance.error_message].join(', ')}</span></div>).html_safe
|
||||
end
|
||||
|
||||
assert_dom_equal(
|
||||
%(<div class="fieldWithErrors"><input id="post_author_name" name="post[author_name]" size="30" type="text" value="" /> <span class="error">can't be empty</span></div>),
|
||||
text_field("post", "author_name")
|
||||
)
|
||||
ensure
|
||||
ActionView::Base.field_error_proc = old_proc if old_proc
|
||||
end
|
||||
|
||||
def test_form_with_string
|
||||
assert_dom_equal(
|
||||
%(<form action="create" method="post"><p><label for="post_title">Title</label><br /><input id="post_title" name="post[title]" size="30" type="text" value="Hello World" /></p>\n<p><label for="post_body">Body</label><br /><div class="fieldWithErrors"><textarea cols="40" id="post_body" name="post[body]" rows="20">Back to the hill and over it again!</textarea></div></p><input name="commit" type="submit" value="Create" /></form>),
|
||||
|
||||
@@ -1,3 +1,14 @@
|
||||
class Hash
|
||||
# By default, only instances of Hash itself are extractable.
|
||||
# Subclasses of Hash may implement this method and return
|
||||
# true to declare themselves as extractable. If a Hash
|
||||
# is extractable, Array#extract_options! pops it from
|
||||
# the Array when it is the last element of the Array.
|
||||
def extractable_options?
|
||||
instance_of?(Hash)
|
||||
end
|
||||
end
|
||||
|
||||
class Array
|
||||
# Extracts options from a set of arguments. Removes and returns the last
|
||||
# element in the array if it's a hash, otherwise returns a blank hash.
|
||||
@@ -9,6 +20,10 @@ class Array
|
||||
# options(1, 2) # => {}
|
||||
# options(1, 2, :a => :b) # => {:a=>:b}
|
||||
def extract_options!
|
||||
last.is_a?(::Hash) ? pop : {}
|
||||
if last.is_a?(Hash) && last.extractable_options?
|
||||
pop
|
||||
else
|
||||
{}
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
@@ -10,8 +10,8 @@ require 'active_support/core_ext/array/extract_options'
|
||||
# Person.hair_colors = [:brown, :black, :blonde, :red]
|
||||
class Class
|
||||
def cattr_reader(*syms)
|
||||
options = syms.extract_options!
|
||||
syms.flatten.each do |sym|
|
||||
next if sym.is_a?(Hash)
|
||||
class_eval(<<-EOS, __FILE__, __LINE__ + 1)
|
||||
unless defined? @@#{sym} # unless defined? @@hair_colors
|
||||
@@#{sym} = nil # @@hair_colors = nil
|
||||
@@ -19,12 +19,15 @@ class Class
|
||||
#
|
||||
def self.#{sym} # def self.hair_colors
|
||||
@@#{sym} # @@hair_colors
|
||||
end # end
|
||||
#
|
||||
def #{sym} # def hair_colors
|
||||
@@#{sym} # @@hair_colors
|
||||
end # end
|
||||
EOS
|
||||
unless options[:instance_reader] == false
|
||||
class_eval(<<-EOS, __FILE__, __LINE__)
|
||||
def #{sym} # def hair_colors
|
||||
@@#{sym} # @@hair_colors
|
||||
end # end
|
||||
EOS
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
@@ -2,7 +2,7 @@ require 'active_support/core_ext/array/extract_options'
|
||||
|
||||
class Module
|
||||
def mattr_reader(*syms)
|
||||
syms.extract_options!
|
||||
options = syms.extract_options!
|
||||
syms.each do |sym|
|
||||
class_eval(<<-EOS, __FILE__, __LINE__ + 1)
|
||||
unless defined? @@#{sym} # unless defined? @@pagination_options
|
||||
@@ -12,11 +12,15 @@ class Module
|
||||
def self.#{sym} # def self.pagination_options
|
||||
@@#{sym} # @@pagination_options
|
||||
end # end
|
||||
|
||||
def #{sym} # def pagination_options
|
||||
@@#{sym} # @@pagination_options
|
||||
end # end
|
||||
EOS
|
||||
|
||||
unless options[:instance_reader] == false
|
||||
class_eval(<<-EOS, __FILE__, __LINE__)
|
||||
def #{sym} # def hair_colors
|
||||
@@#{sym} # @@hair_colors
|
||||
end # end
|
||||
EOS
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
@@ -4,6 +4,10 @@
|
||||
|
||||
module ActiveSupport
|
||||
class HashWithIndifferentAccess < Hash
|
||||
def extractable_options?
|
||||
true
|
||||
end
|
||||
|
||||
def initialize(constructor = {})
|
||||
if constructor.is_a?(Hash)
|
||||
super()
|
||||
|
||||
@@ -4,6 +4,7 @@ require 'active_support/core_ext/big_decimal'
|
||||
require 'active_support/core_ext/object/conversions'
|
||||
|
||||
require 'active_support/core_ext' # FIXME: pulling in all to_xml extensions
|
||||
require 'active_support/hash_with_indifferent_access'
|
||||
|
||||
class ArrayExtAccessTests < Test::Unit::TestCase
|
||||
def test_from
|
||||
@@ -294,12 +295,45 @@ class ArrayToXmlTests < Test::Unit::TestCase
|
||||
end
|
||||
|
||||
class ArrayExtractOptionsTests < Test::Unit::TestCase
|
||||
class HashSubclass < Hash
|
||||
end
|
||||
|
||||
class ExtractableHashSubclass < Hash
|
||||
def extractable_options?
|
||||
true
|
||||
end
|
||||
end
|
||||
|
||||
def test_extract_options
|
||||
assert_equal({}, [].extract_options!)
|
||||
assert_equal({}, [1].extract_options!)
|
||||
assert_equal({:a=>:b}, [{:a=>:b}].extract_options!)
|
||||
assert_equal({:a=>:b}, [1, {:a=>:b}].extract_options!)
|
||||
end
|
||||
|
||||
def test_extract_options_doesnt_extract_hash_subclasses
|
||||
hash = HashSubclass.new
|
||||
hash[:foo] = 1
|
||||
array = [hash]
|
||||
options = array.extract_options!
|
||||
assert_equal({}, options)
|
||||
assert_equal [hash], array
|
||||
end
|
||||
|
||||
def test_extract_options_extracts_extractable_subclass
|
||||
hash = ExtractableHashSubclass.new
|
||||
hash[:foo] = 1
|
||||
array = [hash]
|
||||
options = array.extract_options!
|
||||
assert_equal({:foo => 1}, options)
|
||||
assert_equal [], array
|
||||
end
|
||||
|
||||
def test_extract_options_extracts_hwia
|
||||
hash = [{:foo => 1}.with_indifferent_access]
|
||||
options = hash.extract_options!
|
||||
assert_equal 1, options[:foo]
|
||||
end
|
||||
end
|
||||
|
||||
class ArrayUniqByTests < Test::Unit::TestCase
|
||||
|
||||
@@ -5,7 +5,8 @@ class ClassAttributeAccessorTest < Test::Unit::TestCase
|
||||
def setup
|
||||
@class = Class.new do
|
||||
cattr_accessor :foo
|
||||
cattr_accessor :bar, :instance_writer => false
|
||||
cattr_accessor :bar, :instance_writer => false
|
||||
cattr_reader :shaq, :instance_reader => false
|
||||
end
|
||||
@object = @class.new
|
||||
end
|
||||
@@ -29,4 +30,9 @@ class ClassAttributeAccessorTest < Test::Unit::TestCase
|
||||
assert @object.respond_to?(:bar)
|
||||
assert !@object.respond_to?(:bar=)
|
||||
end
|
||||
|
||||
def test_should_not_create_instance_reader
|
||||
assert @class.respond_to?(:shaq)
|
||||
assert !@object.respond_to?(:shaq)
|
||||
end
|
||||
end
|
||||
|
||||
@@ -6,6 +6,7 @@ class ModuleAttributeAccessorTest < Test::Unit::TestCase
|
||||
m = @module = Module.new do
|
||||
mattr_accessor :foo
|
||||
mattr_accessor :bar, :instance_writer => false
|
||||
mattr_reader :shaq, :instance_reader => false
|
||||
end
|
||||
@class = Class.new
|
||||
@class.instance_eval { include m }
|
||||
@@ -31,4 +32,9 @@ class ModuleAttributeAccessorTest < Test::Unit::TestCase
|
||||
assert @object.respond_to?(:bar)
|
||||
assert !@object.respond_to?(:bar=)
|
||||
end
|
||||
|
||||
def test_should_not_create_instance_reader
|
||||
assert @module.respond_to?(:shaq)
|
||||
assert !@object.respond_to?(:shaq)
|
||||
end
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user