swivel 0.0.146 → 0.0.149
Sign up to get free protection for your applications and to get access to all the features.
- data/README +4 -1
- data/Rakefile +1 -1
- data/lib/swivel.rb +1 -1
- data/lib/swivel2/benchmarking.rb +1 -0
- data/lib/swivel2/config.rb +45 -0
- data/lib/swivel2/connection.rb +89 -0
- data/lib/swivel2/formats.rb +11 -0
- data/lib/swivel2/logging.rb +1 -0
- data/lib/swivel2/performance.rb +21 -0
- data/lib/swivel2/response.rb +5 -0
- data/lib/swivel2/swivelrc.default +5 -0
- data/vendor/activeresource-2.0.2-/CHANGELOG +223 -0
- data/vendor/activeresource-2.0.2-/README +165 -0
- data/vendor/activeresource-2.0.2-/Rakefile +133 -0
- data/vendor/activeresource-2.0.2-/lib/active_resource.rb +47 -0
- data/vendor/activeresource-2.0.2-/lib/active_resource/base.rb +872 -0
- data/vendor/activeresource-2.0.2-/lib/active_resource/connection.rb +172 -0
- data/vendor/activeresource-2.0.2-/lib/active_resource/custom_methods.rb +105 -0
- data/vendor/activeresource-2.0.2-/lib/active_resource/formats.rb +14 -0
- data/vendor/activeresource-2.0.2-/lib/active_resource/formats/json_format.rb +23 -0
- data/vendor/activeresource-2.0.2-/lib/active_resource/formats/xml_format.rb +34 -0
- data/vendor/activeresource-2.0.2-/lib/active_resource/http_mock.rb +147 -0
- data/vendor/activeresource-2.0.2-/lib/active_resource/validations.rb +288 -0
- data/vendor/activeresource-2.0.2-/lib/active_resource/version.rb +9 -0
- data/vendor/activeresource-2.0.2-/lib/activeresource.rb +1 -0
- data/vendor/activeresource-2.0.2-/test/abstract_unit.rb +10 -0
- data/vendor/activeresource-2.0.2-/test/authorization_test.rb +82 -0
- data/vendor/activeresource-2.0.2-/test/base/custom_methods_test.rb +96 -0
- data/vendor/activeresource-2.0.2-/test/base/equality_test.rb +43 -0
- data/vendor/activeresource-2.0.2-/test/base/load_test.rb +111 -0
- data/vendor/activeresource-2.0.2-/test/base_errors_test.rb +48 -0
- data/vendor/activeresource-2.0.2-/test/base_test.rb +454 -0
- data/vendor/activeresource-2.0.2-/test/connection_test.rb +170 -0
- data/vendor/activeresource-2.0.2-/test/fixtures/beast.rb +14 -0
- data/vendor/activeresource-2.0.2-/test/fixtures/person.rb +3 -0
- data/vendor/activeresource-2.0.2-/test/fixtures/street_address.rb +4 -0
- data/vendor/activeresource-2.0.2-/test/format_test.rb +42 -0
- data/vendor/activeresource-2.0.2-/test/setter_trap.rb +27 -0
- data/vendor/activesupport-2.0.2-/CHANGELOG +986 -0
- data/vendor/activesupport-2.0.2-/README +43 -0
- data/vendor/activesupport-2.0.2-/lib/active_support.rb +49 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/basic_object.rb +5 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/buffered_logger.rb +107 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/clean_logger.rb +127 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext.rb +4 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/array.rb +13 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/array/access.rb +28 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/array/conversions.rb +94 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/array/extract_options.rb +19 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/array/grouping.rb +68 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/array/random_access.rb +12 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/bigdecimal.rb +2 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/bigdecimal/conversions.rb +6 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/blank.rb +50 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/cgi.rb +5 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/cgi/escape_skipping_slashes.rb +14 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/class.rb +4 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/class/attribute_accessors.rb +48 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/class/delegating_attributes.rb +40 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/class/inheritable_attributes.rb +140 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/class/removal.rb +24 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/date.rb +10 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/date/behavior.rb +13 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/date/calculations.rb +188 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/date/conversions.rb +98 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/date_time.rb +10 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/date_time/calculations.rb +77 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/date_time/conversions.rb +74 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/duplicable.rb +37 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/enumerable.rb +63 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/exception.rb +33 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/file.rb +21 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/float.rb +5 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/float/rounding.rb +24 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/hash.rb +13 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/hash/conversions.rb +242 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/hash/diff.rb +19 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/hash/except.rb +24 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/hash/indifferent_access.rb +102 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/hash/keys.rb +54 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/hash/reverse_merge.rb +25 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/hash/slice.rb +28 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/integer.rb +7 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/integer/even_odd.rb +24 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/integer/inflections.rb +21 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/kernel.rb +5 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/kernel/agnostics.rb +11 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/kernel/daemonizing.rb +15 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/kernel/debugger.rb +13 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/kernel/reporting.rb +51 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/kernel/requires.rb +24 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/load_error.rb +38 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/logger.rb +16 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/module.rb +8 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/module/aliasing.rb +70 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/module/attr_accessor_with_default.rb +31 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/module/attr_internal.rb +31 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/module/attribute_accessors.rb +48 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/module/delegation.rb +62 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/module/inclusion.rb +11 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/module/introspection.rb +35 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/module/loading.rb +13 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/name_error.rb +17 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/numeric.rb +7 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/numeric/bytes.rb +44 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/numeric/time.rb +91 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/object.rb +4 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/object/conversions.rb +14 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/object/extending.rb +58 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/object/instance_variables.rb +22 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/object/misc.rb +59 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/pathname.rb +7 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/pathname/clean_within.rb +14 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/proc.rb +12 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/range.rb +11 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/range/blockless_step.rb +22 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/range/conversions.rb +23 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/range/include_range.rb +22 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/range/overlaps.rb +12 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/string.rb +23 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/string/access.rb +58 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/string/conversions.rb +28 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/string/inflections.rb +153 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/string/iterators.rb +17 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/string/starts_ends_with.rb +27 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/string/unicode.rb +42 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/string/xchar.rb +11 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/symbol.rb +14 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/test.rb +1 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/test/unit/assertions.rb +62 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/time.rb +19 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/time/behavior.rb +13 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/time/calculations.rb +224 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/core_ext/time/conversions.rb +94 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/dependencies.rb +540 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/deprecation.rb +204 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/duration.rb +96 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/inflections.rb +53 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/inflector.rb +282 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/json.rb +31 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/json/decoding.rb +60 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/json/encoders/date.rb +5 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/json/encoders/date_time.rb +5 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/json/encoders/enumerable.rb +12 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/json/encoders/false_class.rb +5 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/json/encoders/hash.rb +50 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/json/encoders/nil_class.rb +5 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/json/encoders/numeric.rb +5 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/json/encoders/object.rb +6 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/json/encoders/regexp.rb +5 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/json/encoders/string.rb +30 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/json/encoders/symbol.rb +5 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/json/encoders/time.rb +5 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/json/encoders/true_class.rb +5 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/json/encoding.rb +38 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/json/variable.rb +10 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/multibyte.rb +9 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/multibyte/chars.rb +141 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/multibyte/generators/generate_tables.rb +149 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/multibyte/handlers/passthru_handler.rb +9 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/multibyte/handlers/utf8_handler.rb +564 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/multibyte/handlers/utf8_handler_proc.rb +43 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/option_merger.rb +25 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/ordered_options.rb +49 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/test_case.rb +5 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/testing.rb +1 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/testing/default.rb +12 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/values/time_zone.rb +181 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/values/unicode_tables.dat +0 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/vendor.rb +14 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/vendor/builder-2.1.2/blankslate.rb +113 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/vendor/builder-2.1.2/builder.rb +13 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/vendor/builder-2.1.2/builder/blankslate.rb +20 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/vendor/builder-2.1.2/builder/css.rb +250 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/vendor/builder-2.1.2/builder/xchar.rb +115 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/vendor/builder-2.1.2/builder/xmlbase.rb +139 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/vendor/builder-2.1.2/builder/xmlevents.rb +63 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/vendor/builder-2.1.2/builder/xmlmarkup.rb +328 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/vendor/xml-simple-1.0.11/xmlsimple.rb +1021 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/version.rb +9 -0
- data/vendor/activesupport-2.0.2-/lib/active_support/whiny_nil.rb +38 -0
- data/vendor/activesupport-2.0.2-/lib/activesupport.rb +1 -0
- metadata +222 -2
@@ -0,0 +1,170 @@
|
|
1
|
+
require "#{File.dirname(__FILE__)}/abstract_unit"
|
2
|
+
require 'base64'
|
3
|
+
|
4
|
+
class ConnectionTest < Test::Unit::TestCase
|
5
|
+
ResponseCodeStub = Struct.new(:code)
|
6
|
+
|
7
|
+
def setup
|
8
|
+
@conn = ActiveResource::Connection.new('http://localhost')
|
9
|
+
@matz = { :id => 1, :name => 'Matz' }
|
10
|
+
@david = { :id => 2, :name => 'David' }
|
11
|
+
@people = [ @matz, @david ].to_xml(:root => 'people')
|
12
|
+
@people_single = [ @matz ].to_xml(:root => 'people-single-elements')
|
13
|
+
@people_empty = [ ].to_xml(:root => 'people-empty-elements')
|
14
|
+
@matz = @matz.to_xml(:root => 'person')
|
15
|
+
@david = @david.to_xml(:root => 'person')
|
16
|
+
@header = {'key' => 'value'}.freeze
|
17
|
+
|
18
|
+
@default_request_headers = { 'Content-Type' => 'application/xml' }
|
19
|
+
ActiveResource::HttpMock.respond_to do |mock|
|
20
|
+
mock.get "/people/2.xml", @header, @david
|
21
|
+
mock.get "/people.xml", {}, @people
|
22
|
+
mock.get "/people_single_elements.xml", {}, @people_single
|
23
|
+
mock.get "/people_empty_elements.xml", {}, @people_empty
|
24
|
+
mock.get "/people/1.xml", {}, @matz
|
25
|
+
mock.put "/people/1.xml", {}, nil, 204
|
26
|
+
mock.put "/people/2.xml", {}, @header, 204
|
27
|
+
mock.delete "/people/1.xml", {}, nil, 200
|
28
|
+
mock.delete "/people/2.xml", @header, nil, 200
|
29
|
+
mock.post "/people.xml", {}, nil, 201, 'Location' => '/people/5.xml'
|
30
|
+
mock.post "/members.xml", {}, @header, 201, 'Location' => '/people/6.xml'
|
31
|
+
end
|
32
|
+
end
|
33
|
+
|
34
|
+
def test_handle_response
|
35
|
+
# 2xx and 3xx are valid responses.
|
36
|
+
[200, 299, 300, 399].each do |code|
|
37
|
+
expected = ResponseCodeStub.new(code)
|
38
|
+
assert_equal expected, handle_response(expected)
|
39
|
+
end
|
40
|
+
|
41
|
+
# 400 is a bad request (e.g. malformed URI or missing request parameter)
|
42
|
+
assert_response_raises ActiveResource::BadRequest, 400
|
43
|
+
|
44
|
+
# 401 is an unauthorized request
|
45
|
+
assert_response_raises ActiveResource::UnauthorizedAccess, 401
|
46
|
+
|
47
|
+
# 403 is a forbidden requst (and authorizing will not help)
|
48
|
+
assert_response_raises ActiveResource::ForbiddenAccess, 403
|
49
|
+
|
50
|
+
# 404 is a missing resource.
|
51
|
+
assert_response_raises ActiveResource::ResourceNotFound, 404
|
52
|
+
|
53
|
+
# 405 is a missing not allowed error
|
54
|
+
assert_response_raises ActiveResource::MethodNotAllowed, 405
|
55
|
+
|
56
|
+
# 409 is an optimistic locking error
|
57
|
+
assert_response_raises ActiveResource::ResourceConflict, 409
|
58
|
+
|
59
|
+
# 422 is a validation error
|
60
|
+
assert_response_raises ActiveResource::ResourceInvalid, 422
|
61
|
+
|
62
|
+
# 4xx are client errors.
|
63
|
+
[402, 499].each do |code|
|
64
|
+
assert_response_raises ActiveResource::ClientError, code
|
65
|
+
end
|
66
|
+
|
67
|
+
# 5xx are server errors.
|
68
|
+
[500, 599].each do |code|
|
69
|
+
assert_response_raises ActiveResource::ServerError, code
|
70
|
+
end
|
71
|
+
|
72
|
+
# Others are unknown.
|
73
|
+
[199, 600].each do |code|
|
74
|
+
assert_response_raises ActiveResource::ConnectionError, code
|
75
|
+
end
|
76
|
+
end
|
77
|
+
|
78
|
+
ResponseHeaderStub = Struct.new(:code, :message, 'Allow')
|
79
|
+
def test_should_return_allowed_methods_for_method_no_allowed_exception
|
80
|
+
begin
|
81
|
+
handle_response ResponseHeaderStub.new(405, "HTTP Failed...", "GET, POST")
|
82
|
+
rescue ActiveResource::MethodNotAllowed => e
|
83
|
+
assert_equal "Failed with 405 HTTP Failed...", e.message
|
84
|
+
assert_equal [:get, :post], e.allowed_methods
|
85
|
+
end
|
86
|
+
end
|
87
|
+
|
88
|
+
def test_initialize_raises_argument_error_on_missing_site
|
89
|
+
assert_raise(ArgumentError) { ActiveResource::Connection.new(nil) }
|
90
|
+
end
|
91
|
+
|
92
|
+
def test_site_accessor_accepts_uri_or_string_argument
|
93
|
+
site = URI.parse("http://localhost")
|
94
|
+
|
95
|
+
assert_raise(URI::InvalidURIError) { @conn.site = nil }
|
96
|
+
|
97
|
+
assert_nothing_raised { @conn.site = "http://localhost" }
|
98
|
+
assert_equal site, @conn.site
|
99
|
+
|
100
|
+
assert_nothing_raised { @conn.site = site }
|
101
|
+
assert_equal site, @conn.site
|
102
|
+
end
|
103
|
+
|
104
|
+
def test_get
|
105
|
+
matz = @conn.get("/people/1.xml")
|
106
|
+
assert_equal "Matz", matz["name"]
|
107
|
+
end
|
108
|
+
|
109
|
+
def test_get_with_header
|
110
|
+
david = @conn.get("/people/2.xml", @header)
|
111
|
+
assert_equal "David", david["name"]
|
112
|
+
end
|
113
|
+
|
114
|
+
def test_get_collection
|
115
|
+
people = @conn.get("/people.xml")
|
116
|
+
assert_equal "Matz", people[0]["name"]
|
117
|
+
assert_equal "David", people[1]["name"]
|
118
|
+
end
|
119
|
+
|
120
|
+
def test_get_collection_single
|
121
|
+
people = @conn.get("/people_single_elements.xml")
|
122
|
+
assert_equal "Matz", people[0]["name"]
|
123
|
+
end
|
124
|
+
|
125
|
+
def test_get_collection_empty
|
126
|
+
people = @conn.get("/people_empty_elements.xml")
|
127
|
+
assert_equal [], people
|
128
|
+
end
|
129
|
+
|
130
|
+
def test_post
|
131
|
+
response = @conn.post("/people.xml")
|
132
|
+
assert_equal "/people/5.xml", response["Location"]
|
133
|
+
end
|
134
|
+
|
135
|
+
def test_post_with_header
|
136
|
+
response = @conn.post("/members.xml", @header)
|
137
|
+
assert_equal "/people/6.xml", response["Location"]
|
138
|
+
end
|
139
|
+
|
140
|
+
def test_put
|
141
|
+
response = @conn.put("/people/1.xml")
|
142
|
+
assert_equal 204, response.code
|
143
|
+
end
|
144
|
+
|
145
|
+
def test_put_with_header
|
146
|
+
response = @conn.put("/people/2.xml", @header)
|
147
|
+
assert_equal 204, response.code
|
148
|
+
end
|
149
|
+
|
150
|
+
def test_delete
|
151
|
+
response = @conn.delete("/people/1.xml")
|
152
|
+
assert_equal 200, response.code
|
153
|
+
end
|
154
|
+
|
155
|
+
def test_delete_with_header
|
156
|
+
response = @conn.delete("/people/2.xml", @header)
|
157
|
+
assert_equal 200, response.code
|
158
|
+
end
|
159
|
+
|
160
|
+
protected
|
161
|
+
def assert_response_raises(klass, code)
|
162
|
+
assert_raise(klass, "Expected response code #{code} to raise #{klass}") do
|
163
|
+
handle_response ResponseCodeStub.new(code)
|
164
|
+
end
|
165
|
+
end
|
166
|
+
|
167
|
+
def handle_response(response)
|
168
|
+
@conn.send!(:handle_response, response)
|
169
|
+
end
|
170
|
+
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
class BeastResource < ActiveResource::Base
|
2
|
+
self.site = 'http://beast.caboo.se'
|
3
|
+
site.user = 'foo'
|
4
|
+
site.password = 'bar'
|
5
|
+
end
|
6
|
+
|
7
|
+
class Forum < BeastResource
|
8
|
+
# taken from BeastResource
|
9
|
+
# self.site = 'http://beast.caboo.se'
|
10
|
+
end
|
11
|
+
|
12
|
+
class Topic < BeastResource
|
13
|
+
self.site += '/forums/:forum_id'
|
14
|
+
end
|
@@ -0,0 +1,42 @@
|
|
1
|
+
require "#{File.dirname(__FILE__)}/abstract_unit"
|
2
|
+
require "fixtures/person"
|
3
|
+
|
4
|
+
class FormatTest < Test::Unit::TestCase
|
5
|
+
def setup
|
6
|
+
@matz = { :id => 1, :name => 'Matz' }
|
7
|
+
@david = { :id => 2, :name => 'David' }
|
8
|
+
|
9
|
+
@programmers = [ @matz, @david ]
|
10
|
+
end
|
11
|
+
|
12
|
+
def test_formats_on_single_element
|
13
|
+
for format in [ :json, :xml ]
|
14
|
+
using_format(Person, format) do
|
15
|
+
ActiveResource::HttpMock.respond_to.get "/people/1.#{format}", {}, ActiveResource::Formats[format].encode(@david)
|
16
|
+
assert_equal @david[:name], Person.find(1).name
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
def test_formats_on_collection
|
22
|
+
for format in [ :json, :xml ]
|
23
|
+
using_format(Person, format) do
|
24
|
+
ActiveResource::HttpMock.respond_to.get "/people.#{format}", {}, ActiveResource::Formats[format].encode(@programmers)
|
25
|
+
remote_programmers = Person.find(:all)
|
26
|
+
assert_equal 2, remote_programmers.size
|
27
|
+
assert remote_programmers.select { |p| p.name == 'David' }
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
|
33
|
+
private
|
34
|
+
def using_format(klass, mime_type_reference)
|
35
|
+
previous_format = klass.format
|
36
|
+
klass.format = mime_type_reference
|
37
|
+
|
38
|
+
yield
|
39
|
+
ensure
|
40
|
+
klass.format = previous_format
|
41
|
+
end
|
42
|
+
end
|
@@ -0,0 +1,27 @@
|
|
1
|
+
class SetterTrap < BasicObject
|
2
|
+
class << self
|
3
|
+
def rollback_sets(obj)
|
4
|
+
returning yield(setter_trap = new(obj)) do
|
5
|
+
setter_trap.rollback_sets
|
6
|
+
end
|
7
|
+
end
|
8
|
+
end
|
9
|
+
|
10
|
+
def initialize(obj)
|
11
|
+
@cache = {}
|
12
|
+
@obj = obj
|
13
|
+
end
|
14
|
+
|
15
|
+
def respond_to?(method)
|
16
|
+
@obj.respond_to?(method)
|
17
|
+
end
|
18
|
+
|
19
|
+
def method_missing(method, *args, &proc)
|
20
|
+
@cache[method] ||= @obj.send($`) if method.to_s =~ /=$/
|
21
|
+
@obj.send method, *args, &proc
|
22
|
+
end
|
23
|
+
|
24
|
+
def rollback_sets
|
25
|
+
@cache.each { |k, v| @obj.send k, v }
|
26
|
+
end
|
27
|
+
end
|
@@ -0,0 +1,986 @@
|
|
1
|
+
*SVN*
|
2
|
+
|
3
|
+
* Ruby 1.9 compatibility. #1689, #10466, #10468 [Cheah Chu Yeow, Pratik Naik, Jeremy Kemper]
|
4
|
+
|
5
|
+
* TimeZone#to_s uses UTC rather than GMT. #1689 [Cheah Chu Yeow]
|
6
|
+
|
7
|
+
* Refactor of Hash#symbolize_keys! to use Hash#replace. Closes #10420 [ReinH]
|
8
|
+
|
9
|
+
* Fix HashWithIndifferentAccess#to_options! so it doesn't clear the options hash. Closes #10419 [ReinH]
|
10
|
+
|
11
|
+
|
12
|
+
*2.0.1* (December 7th, 2007)
|
13
|
+
|
14
|
+
* Added Array#from and Array#to that behaves just from String#from and String#to [DHH]
|
15
|
+
|
16
|
+
* Fix that empty collections should be treated as empty arrays regardless of whitespace for Hash#from_xml #10255 [adamj]
|
17
|
+
|
18
|
+
* Time#time_with_datetime_fallback, Time#to_datetime, Date#to_datetime and String#to_datetime honor Ruby's default calendar reform setting. #10201 [Geoff Buesing]
|
19
|
+
|
20
|
+
* Change Time and DateTime #end_of_month to return last second of month instead of beginning of last day of month. Closes #10200 [Geoff Buesing]
|
21
|
+
|
22
|
+
* Speedup String#blank? [Jeremy Kemper, Koz]
|
23
|
+
|
24
|
+
* Add documentation for Hash#diff. Closes #9306 [Tarmo Tänav]
|
25
|
+
|
26
|
+
* Add new superclass_delegating_accessors. Similar to class inheritable attributes but with subtly different semantics. [Koz, Tarmo Tänav]
|
27
|
+
|
28
|
+
* Change JSON to encode %w(< > &) as 4 digit hex codes to be in compliance with the JSON spec. Closes #9975 [Josh Peek, Cheah Chu Yeow, Tim Pope]
|
29
|
+
|
30
|
+
* Fix JSON encoding/decoding bugs dealing with /'s. Closes #9990 [Rick, theamazingrando]
|
31
|
+
|
32
|
+
* Introduce a base class for all test cases used by rails applications. ActiveSupport::TestCase [Koz]
|
33
|
+
|
34
|
+
The intention is to use this to reduce the amount of monkeypatching / overriding that
|
35
|
+
is done to test/unit's classes.
|
36
|
+
|
37
|
+
* Document Enumerable and Hash #to_json. #9970 [Cheah Chu Yeow]
|
38
|
+
|
39
|
+
* Hash#to_xml handles symbol values. #9954 [Assaf]
|
40
|
+
|
41
|
+
* Hash#symbolize_keys behaves well with integer keys. #9890 [PotatoSalad]
|
42
|
+
|
43
|
+
* Multibyte: String#slice supports regexp argument. #9646 [yob]
|
44
|
+
|
45
|
+
* object.duplicable? returns true if object.dup is safe. False for nil, true, false, symbols, and numbers; true otherwise. #9333 [sur]
|
46
|
+
|
47
|
+
* Time, Date and DateTime #advance accept :weeks option. #9866 [Geoff Buesing]
|
48
|
+
|
49
|
+
* Fix Time#years_ago and #years_since from leap days. #9865 [Geoff Buesing]
|
50
|
+
|
51
|
+
* Time and DateTime#advance accept :hours, :minutes, and :seconds options. #9825 [Geoff Buesing]
|
52
|
+
|
53
|
+
* Fix Date#years_ago and #years_since from leap days. #9864 [Geoff Buesing]
|
54
|
+
|
55
|
+
* Refactor Time and Date#months_since and #months_ago to use #advance. #9863 [Geoff Buesing]
|
56
|
+
|
57
|
+
* Rebundle Builder 2.1.2 but prefer a newer RubyGem if available. [Jeremy Kemper]
|
58
|
+
|
59
|
+
* Add Range#overlaps?(range), Range#include?(range), and Range#step without a block. [brandon]
|
60
|
+
|
61
|
+
* Correct BufferedLogger#level? checks. #9806 [wildchild, Johan Sorensen]
|
62
|
+
|
63
|
+
* String#to_xs uses Eric Wong's fast_xs extension, if available, for Builder speedup. http://bogomips.org/fast_xs/ [Jeremy Kemper]
|
64
|
+
|
65
|
+
* Introduce BasicObject as Builder::BlankSlate for Ruby 1.9 forward compatibility. [Jeremy Kemper]
|
66
|
+
|
67
|
+
* Unbundle Builder in favor of a gem dependency. [Jeremy Kemper]
|
68
|
+
|
69
|
+
* Disambiguate Time, Date, and DateTime#to_json formatting. #9750 [Geoff Buesing, Cheah Chu Yeow]
|
70
|
+
|
71
|
+
* Hash#to_json takes :only or :except options to specific or omit certain hash keys. Enumerable#to_json passes through its options to each element. #9751 [Cheah Chu Yeow]
|
72
|
+
|
73
|
+
* BufferedLogger#auto_flushing = N flushes the log every N messages. Buffers with an array instead of string. Disabling auto_flushing still flushes when the buffer hits a maximum size, as a failsafe against memory-gobbling. [Jeremy Kemper]
|
74
|
+
|
75
|
+
* Fixed Date#xmlschema for dates outside the range of what can be created with Time #9744 [Geoff Buesing]
|
76
|
+
|
77
|
+
* Fixed that La Paz was included in -25200 and -14400 offsets when it should only be in -14400 #9735 [bermi]
|
78
|
+
|
79
|
+
* Fixed JSON encoding to use quoted keys according to the JSON standard. #8762 [choonkat, Cheah Chu Yeow]
|
80
|
+
|
81
|
+
* Alias Object#send to send! for Ruby 1.9 forward compatibility. [Jeremy Kemper]
|
82
|
+
|
83
|
+
* Backport Object#instance_variable_defined? for Ruby < 1.8.6. [Jeremy Kemper]
|
84
|
+
|
85
|
+
* BufferedLogger#add converts the message to a string. #9702, #9724 [eigentone, DrMark, tomafro]
|
86
|
+
|
87
|
+
* Added ActiveSupport::BufferedLogger as a duck-typing alternative (albeit with no formatter) to the Ruby Logger, which provides a very nice speed bump (inspired by Ezra's buffered logger) [DHH]
|
88
|
+
|
89
|
+
* Object#instance_exec produces fewer garbage methods. [Mauricio Fernandez]
|
90
|
+
|
91
|
+
* Decode json strings as Dates/Times if they're using a YAML-compatible format. Closes #9614 [Rick]
|
92
|
+
|
93
|
+
* Fixed cache_page to use the request url instead of the routing options when picking a save path. #8614 [Josh Peek]
|
94
|
+
|
95
|
+
* Object.subclasses_of includes anonymous subclasses. [Jeremy Kemper]
|
96
|
+
|
97
|
+
* Fixed that pluralizing an empty string should return the same empty string, not "s". #7720 [Josh Peek]
|
98
|
+
|
99
|
+
* Added call to inspect on non-string classes for the logger #8533 [codahale]
|
100
|
+
|
101
|
+
* Deprecation: remove deprecated :mday option from Time, Date, and DateTime#change. [Jeremy Kemper]
|
102
|
+
|
103
|
+
* Fix JSON decoder with nested quotes and commas. #9579 [zdennis]
|
104
|
+
|
105
|
+
* Hash#to_xml doesn't double-unescape. #8806 [Ezran]
|
106
|
+
|
107
|
+
* Added Array#rand #9170 [Norbert Crombach]. Examples:
|
108
|
+
|
109
|
+
[].rand # => nil
|
110
|
+
['a'].rand # => 'a'
|
111
|
+
[1,2,3].rand # => 1 or 2 or 3
|
112
|
+
|
113
|
+
* Deprecation: removed Reloadable. [Jeremy Kemper]
|
114
|
+
|
115
|
+
* Make the utf-handler return the correct value for non-matching regular expressions. Closes #9049 [manfred]
|
116
|
+
|
117
|
+
* Add ljust, rjust and center to utf8-handler. Closes #9165 [manfred]
|
118
|
+
|
119
|
+
* Fix Time#advance bug when trying to advance a year from leap day. Closes #8655 [gbuesing]
|
120
|
+
|
121
|
+
* Add support for []= on ActiveSupport::Multibyte::Chars. Closes #9142. [ewan, manfred]
|
122
|
+
|
123
|
+
* Added Array#extract_options! to encapsulate the pattern of getting an options hash out of a variable number of parameters. #8759 [Norbert Crombach]
|
124
|
+
|
125
|
+
* Let alias_attribute work with attributes with initial capital letters (legacy columns etc). Closes #8596 [mpalmer]
|
126
|
+
|
127
|
+
* Added Hash#except which is the inverse of Hash#slice -- return the hash except the keys that are specified [DHH]
|
128
|
+
|
129
|
+
* Added support for pluralization with a different starting letter than the singular version (cow/kine) #4929 [norri_b/hasmanyjosh]
|
130
|
+
|
131
|
+
* Demote Hash#to_xml to use XmlSimple#xml_in_string so it can't read files or stdin. #8453 [candlerb, Jeremy Kemper]
|
132
|
+
|
133
|
+
* Backport clean_logger changes to support ruby 1.8.2 [mislav]
|
134
|
+
|
135
|
+
* Added proper handling of arrays #8537 [hasmanyjosh]
|
136
|
+
|
137
|
+
Before:
|
138
|
+
Hash.from_xml '<images></images>'
|
139
|
+
# => {:images => nil}
|
140
|
+
|
141
|
+
Hash.from_xml '<images><image>foo.jpg</image></images>'
|
142
|
+
# => {:images => {:image => "foo.jpg"}}
|
143
|
+
|
144
|
+
Hash.from_xml '<images><image>foo.jpg</image><image>bar.jpg</image></images>'
|
145
|
+
# => {:images => {:image => ["foo.jpg", "bar.jpg"]}}
|
146
|
+
|
147
|
+
After:
|
148
|
+
Hash.from_xml '<images type="array"></images>'
|
149
|
+
# => {:images => []}
|
150
|
+
|
151
|
+
Hash.from_xml '<images type="array"><image>foo.jpg</image></images>'
|
152
|
+
# => {:images => ["foo.jpg"]}
|
153
|
+
|
154
|
+
Hash.from_xml '<images type="array"><image>foo.jpg</image><image>bar.jpg</image></images>'
|
155
|
+
# => {:images => ["foo.jpg", "bar.jpg"]}
|
156
|
+
|
157
|
+
* Improve Time and Date test coverage. #8646 [Josh Peek]
|
158
|
+
|
159
|
+
* Add Date#since, ago, beginning_of_day, and end_of_day. Date + seconds works now. #8575 [Geoff Buesing]
|
160
|
+
|
161
|
+
* String#to_time overflows to DateTime. Add String#to_datetime. #8572 [Geoff Buesing]
|
162
|
+
|
163
|
+
* Date.yesterday and .tomorrow. #8571 [Geoff Buesing]
|
164
|
+
|
165
|
+
* Readable Date and DateTime#inspect. #8570 [Geoff Buesing]
|
166
|
+
|
167
|
+
* Move common DateTime calculations to Date. #8536 [Geoff Buesing]
|
168
|
+
|
169
|
+
* Added Date#change (like Time#change) [DHH]
|
170
|
+
|
171
|
+
* DateTime#to_time converts to Time unless out of range. #8512 [Geoff Buesing]
|
172
|
+
|
173
|
+
* Date#to_datetime, #to_s(:rfc822). #8512 [Geoff Buesing]
|
174
|
+
|
175
|
+
* Time durations use since instead of + for accuracy. #8513 [Geoff Buesing]
|
176
|
+
|
177
|
+
* escape <'s and >'s in JSON strings. #8371 [Rick]
|
178
|
+
|
179
|
+
* Inflections: MatrixTest -> MatrixTests instead of MatricesTest. #8496 [jbwiv]
|
180
|
+
|
181
|
+
* Multibyte strings respond_to the String methods they proxy so they can be duck-typed. #6549 [Tuxie]
|
182
|
+
|
183
|
+
* Array#to_xml yields the builder just like Hash and ActiveRecord::Base. #8472 [seth]
|
184
|
+
|
185
|
+
* Date, Time, and DateTime support formatting blocks in addition to strftime strings. Introduce :long_ordinal format, e.g. "February 21st, 2005". #8191 [Coda Hale]
|
186
|
+
|
187
|
+
* Document Object#blank?. #6491 [Chris Mear]
|
188
|
+
|
189
|
+
* Date, Time, and DateTime#to_json. #8399 [wycats]
|
190
|
+
|
191
|
+
* Simplify API of assert_difference by passing in an expression that is evaluated before and after the passed in block. See documenation for examples of new API. [Marcel Molina Jr.]
|
192
|
+
|
193
|
+
* Added assert_difference and assert_no_difference to test/unit assertions [Tobias Luetke]
|
194
|
+
|
195
|
+
* Removed breakpointer and Binding.of_caller in favor of relying on ruby-debug by Kent Sibilev since the breakpointer has been broken since Ruby 1.8.4 and will not be coming back [DHH]
|
196
|
+
|
197
|
+
* Added parsing of file type in Hash.xml_in so you can easily do file uploads with base64 from an API [DHH]
|
198
|
+
|
199
|
+
<person>
|
200
|
+
<name>David</name>
|
201
|
+
<avatar type="file" name="me.jpg" content_type="image/jpg">R0lGODlhkACZAPUAAM5lcfjrtMQCG=\n</avatar>
|
202
|
+
</person>
|
203
|
+
|
204
|
+
...becomes:
|
205
|
+
|
206
|
+
attributes = { :person => { :name => "David", :avatar => #<StringIO> } }
|
207
|
+
attributes[:person][:avatar].content_type # => "image/jpg"
|
208
|
+
attributes[:person][:avatar].original_filename # => "me.jpg"
|
209
|
+
attributes[:person][:avatar].read # => binary data of the file
|
210
|
+
|
211
|
+
Which is duck-type compatible with the files that you get when doing multipart uploads through HTML.
|
212
|
+
|
213
|
+
* Improved multibyte performance by relying less on exception raising #8159 [Blaine]
|
214
|
+
|
215
|
+
* Use XSD-compatible type names for Hash#to_xml and make the converters extendable #8047 [Tim Pope]
|
216
|
+
|
217
|
+
* Added yielding of builder in Hash#to_xml [DHH]
|
218
|
+
|
219
|
+
* Hash#with_indifferent_access now also converts hashes kept in arrays to indifferent access (makes it easier to treat HTML and XML parameters the same) [DHH]
|
220
|
+
|
221
|
+
* Hash#to_xml supports YAML attributes. #7502 [jonathan]
|
222
|
+
|
223
|
+
* Refactor ActiveSupport::JSON to be less obtuse. Add support for JSON decoding by way of Syck with ActiveSupport::JSON.decode(json_string). Prevent hash keys that are JavaScript reserved words from being unquoted during encoding. [Sam Stephenson]
|
224
|
+
|
225
|
+
* alias_method_chain preserves the original method's visibility. #7854 [Jonathan Viney]
|
226
|
+
|
227
|
+
* Update Dependencies to ignore constants inherited from ancestors. Closes #6951. [Nicholas Seckar]
|
228
|
+
|
229
|
+
* Array#to_query preserves its ordering. #7756 [Greg Spurrier]
|
230
|
+
|
231
|
+
* Out-of-range Time calculations transparently overflow to DateTime. Introduce Time#to_datetime. #7706, #7715 [Geoff Buesing]
|
232
|
+
|
233
|
+
* DateTime calculations analogous to the Date and Time extensions. #7693 [Geoff Buesing]
|
234
|
+
|
235
|
+
* Give DateTime correct .to_s implementations, lets it play nice with ActiveRecord quoting. #7649 [Geoff Buesing]
|
236
|
+
|
237
|
+
* Add File.atomic_write, allows you to write large files in an atomic manner, preventing users from seeing half written files. [Koz]
|
238
|
+
|
239
|
+
* Allow users to provide custom formatters to Logger. [aeden]
|
240
|
+
|
241
|
+
* Hash#to_query CGI-escapes its keys. [Jeremy Kemper]
|
242
|
+
|
243
|
+
* Optimize Class Inheritable Attributes so that unnecessary hashes are not created. Closes #7472 [Bruce Perens]
|
244
|
+
|
245
|
+
* :db format for Date#to_s [Jeremy Kemper]
|
246
|
+
Date.new(2007, 1, 27).to_s(:db) # => '2007-01-27'
|
247
|
+
|
248
|
+
* Added :instance_writer option to #mattr_writer/accessor, #cattr_writer/accessor, and #class_inheritable_writer to skip the creation of the instance writer. [Rick]
|
249
|
+
|
250
|
+
* Added Hash#to_query to turn a hash of values into a form-encoded query string [Nicholas Seckar]
|
251
|
+
|
252
|
+
* Increase test coverage for subclasses_of. Closes #7335. [Roman2K, Nicholas Seckar]
|
253
|
+
|
254
|
+
* Remove unused code from Duration#inspect. Closes #7180. [Rich Collins]
|
255
|
+
|
256
|
+
* Added test coverage for Inflector.inflections.clear. Closes #7179. [Rich Collins]
|
257
|
+
|
258
|
+
* ActiveSupport::Multibyte::Handlers::UTF8Handler should raise when a range and an integer are passed in (just like the native implementation). Closes #7176 [Rich Collins]
|
259
|
+
|
260
|
+
* A couple extra tests for #classify. Closes #7273. [Josh Susser]
|
261
|
+
|
262
|
+
* Better docs for Object extensions [zackchandler, Jamis Buck]
|
263
|
+
|
264
|
+
* Fix that Dates couldn't be subtracted from Dates after [5940]. [Sam Stephenson]
|
265
|
+
|
266
|
+
* Add Object#acts_like? and Time#acts_like_time? and Date#acts_like_date? to facilitate duck-typing. [Jamis Buck]
|
267
|
+
|
268
|
+
* Make 1.months and friends accurate by introducing a Duration class. #6835 [eventualbuddha]
|
269
|
+
|
270
|
+
|
271
|
+
*1.4.2* (March 12th, 2007)
|
272
|
+
|
273
|
+
* Ruby 1.8.6 and 1.9 define private Time#to_date and #to_datetime; make them
|
274
|
+
public for compatibility. [Jeremy Kemper]
|
275
|
+
|
276
|
+
* Deprecation: warn on stderr if RAILS_DEFAULT_LOGGER isn't set yet. [Jeremy Kemper]
|
277
|
+
|
278
|
+
|
279
|
+
*1.4.1* (February 5th, 2007)
|
280
|
+
|
281
|
+
* Optimize Class Inheritable Attributes so that unnecessary hashes are not created. Closes #7472 [Bruce Perens]
|
282
|
+
|
283
|
+
* Added :instance_writer option to #mattr_writer/accessor, #cattr_writer/accessor, and #class_inheritable_writer to skip the creation of the instance writer. [Rick]
|
284
|
+
|
285
|
+
* Full test coverage for Inflector. #7228 [Dan Kubb]
|
286
|
+
|
287
|
+
|
288
|
+
*1.4.0* (January 16th, 2007)
|
289
|
+
|
290
|
+
* Document Inflector.ordinalize and merge docs from String inflections. #7023 [smeade]
|
291
|
+
|
292
|
+
* Unbundle flexmock. [Jeremy Kemper]
|
293
|
+
|
294
|
+
* Fix Dependencies.autoloaded? to ignore anonymous modules. Closes #6561. [Nicholas Seckar]
|
295
|
+
|
296
|
+
* Update load once paths to prevent nested once constants from being detected and claimed by an external non-once load. [Nicholas Seckar]
|
297
|
+
|
298
|
+
* Deprecation: silence warnings when reporting test errors. [Jeremy Kemper]
|
299
|
+
|
300
|
+
* Hash#slice(*keys) returns a new hash with only the given keys. #slice! replaces the hash with only the given keys. Works with HashWithIndifferentAccess also. [Jeremy Kemper]
|
301
|
+
|
302
|
+
* HashWithIndifferentAccess#to_hash converts to a Hash with String keys and the same default value. [Jeremy Kemper]
|
303
|
+
|
304
|
+
* Fix remove_constant to correctly handle constant names of the form "::A::...". References #6720. [Nicholas Seckar]
|
305
|
+
|
306
|
+
* Fixed Array#to_xml when it contains a series of hashes (each piece would get its own XML declaration) #6610 [thkarcher/cyu]
|
307
|
+
|
308
|
+
* Added Time#to_s(:time) which will just return H:M, like 17:44 [DHH]
|
309
|
+
|
310
|
+
* Add Module#attr_accessor_with_default to initialize value of attribute before setting it. Closes #6538. [Stuart Halloway, Marcel Molina Jr.]
|
311
|
+
|
312
|
+
* Hash#to_xml handles keys with the same name as Kernel methods. #6613 [Catfish]
|
313
|
+
|
314
|
+
* Added Time#end_of_day to get 23:59:59 of that day [DHH]
|
315
|
+
|
316
|
+
* Don't quote hash keys in Hash#to_json if they're valid JavaScript identifiers. Disable this with ActiveSupport::JSON.unquote_hash_key_identifiers = false if you need strict JSON compliance. [Sam Stephenson]
|
317
|
+
|
318
|
+
* Lazily load the Unicode Database in the UTF-8 Handler [Rick Olson]
|
319
|
+
|
320
|
+
* Update dependencies to delete partially loaded constants. [Nicholas Seckar]
|
321
|
+
|
322
|
+
* Fix unicode JSON regexp for Onigurama compatibility. #6494 [whitley]
|
323
|
+
|
324
|
+
* update XmlSimple to 1.0.10. Closes #6532. [nicksieger]
|
325
|
+
|
326
|
+
* Update dependencies to allow constants to be defined alongside their siblings. A common case for this is AR model classes with STI; user.rb might define User, Administrator and Guest for example. [Nicholas Seckar]
|
327
|
+
|
328
|
+
* next_week respects DST changes. #6483, #5617, #2353, #2509, #4551 [marclove, rabiedenharn, rails@roetzel.de, jsolson@damogran.org, drbrain@segment7.net]
|
329
|
+
|
330
|
+
* Expose methods added to Enumerable in the documentation, such as group_by. Closes #6170. [sergeykojin@gmail.com, Marcel Molina Jr.]
|
331
|
+
|
332
|
+
* Ensure Chars#tidy_bytes only tidies broken bytes. Closes #6397 [Manfred Stienstra]
|
333
|
+
|
334
|
+
* Add 'unloadable', a method used to mark any constant as requiring an unload after each request. [Nicholas Seckar]
|
335
|
+
|
336
|
+
* Make core_ext/string/access.rb multibyte safe. Closes #6388 [Manfred Stienstra]
|
337
|
+
|
338
|
+
* Make String#chars slicing behaviour consistent with String. Closes #6387 [Manfred Stienstra]
|
339
|
+
|
340
|
+
* Pull in latest multibyte patch. Closes #6346 [Manfred Stienstra]
|
341
|
+
|
342
|
+
* Add ActiveSupport::Multibyte. Provides String#chars which lets you deal with strings as a sequence of chars, not of bytes. Closes #6242 [Julian Tarkhanov, Manfred Stienstra, Thijs van der Vossen & Jan Behrens]
|
343
|
+
|
344
|
+
* Fix issue with #class_inheritable_accessor saving updates to the parent class when initialized with an Array or Hash [mojombo]
|
345
|
+
|
346
|
+
* Hash#to_xml supports Bignum and BigDecimal. #6313 [edibiase]
|
347
|
+
|
348
|
+
* Don't undefine #class in OptionMerger [Rick]
|
349
|
+
|
350
|
+
* Hash.create_from_xml has been renamed to Hash.from_xml, alias will exist until Rails 2.0 [DHH]
|
351
|
+
|
352
|
+
* alias_method_chain works with accessor= methods also. #6153 [Caio Chassot]
|
353
|
+
|
354
|
+
* Fix loadable_constants_for_path to handle load paths that do not end with a slash. [Nicholas Seckar]
|
355
|
+
|
356
|
+
* Fix logic error in determining what was loaded by a given file. Closes #6039. [Nicholas Seckar]
|
357
|
+
|
358
|
+
* Equate Kernel.const_missing with Object.const_missing. Fixes #5988. [Nicholas Seckar]
|
359
|
+
|
360
|
+
* Add ApplicationController special case to Dependencies. [Nicholas Seckar]
|
361
|
+
|
362
|
+
* Don't pad remaining places with in_groups_of if specified padding value is false. [Marcel Molina Jr.]
|
363
|
+
|
364
|
+
* Fix cases where empty xml nodes weren't being translated to nil in Hash.create_from_xml [Rick Olso n]
|
365
|
+
|
366
|
+
<written-on type="date"></written-on> # => { :type => 'date' } # WRONG
|
367
|
+
<written-on type="date"></written-on> # => nil # RIGHT
|
368
|
+
|
369
|
+
* Tighten rescue clauses. #5985 [james@grayproductions.net]
|
370
|
+
|
371
|
+
* Inflections: don't singularize -ies plurals. [foamdino@gmail.com, Mark Van Holstyn]
|
372
|
+
|
373
|
+
* Update Initializer to use load_once_paths to avoid plugin reloading. References #5852. [Nicholas Seckar]
|
374
|
+
|
375
|
+
* Use Array#assoc in ActiveSupport::OrderedHash. [Mauricio Fernandez]
|
376
|
+
|
377
|
+
* Greatly increased performance of String.to_json, which speeds up RJS considerably on large pages, fixes #3473 [Shugo Maeda]
|
378
|
+
|
379
|
+
* Detect missing_constants calls from removed modules and fail accordingly. [Nicholas Seckar]
|
380
|
+
|
381
|
+
* Stop using defined? in Dependencies.qualified_const_defined? since defined? may invoke const_missing. [Nicholas Seckar]
|
382
|
+
|
383
|
+
* Dependencies can autoload directories of nested classes. [Jeremy Kemper]
|
384
|
+
Example:
|
385
|
+
invoice.rb class Invoice
|
386
|
+
invoice/lineitem.rb class Invoice::Lineitem
|
387
|
+
|
388
|
+
* Add Deprecation.silence so that Reloadable does not scold itself. [Nicholas Seckar]
|
389
|
+
|
390
|
+
* Add debugging logging to Dependencies. Currently can be enabled with Dependencies.log_activity = true; adding to Initializer and documenting is forthcoming. [Nicholas Seckar]
|
391
|
+
|
392
|
+
* Replace Reloadable with improvements to the Dependencies mechanism. [Nicholas Seckar]
|
393
|
+
|
394
|
+
* DateTime#to_time gives hour/minute/second resolution. #5747 [jon.evans@pobox.com]
|
395
|
+
|
396
|
+
* attr_internal to support namespacing and deprecation. Like attr_* except backed by internally-named instance variable. Set attr_internal_naming_format to change the format from the default '@_%s'. [Jeremy Kemper]
|
397
|
+
# def foo() @foo__rofl end
|
398
|
+
# def foo=(v) @foo__rofl = v end
|
399
|
+
self.attr_internal_naming_format = '@%s__rofl'
|
400
|
+
attr_internal :foo
|
401
|
+
|
402
|
+
* Raise fully qualified names upon name errors. #5533 [lars@pinds.com, Nicholas Seckar]
|
403
|
+
|
404
|
+
* Add extention to obtain the missing constant from NameError instances. [Nicholas Seckar]
|
405
|
+
|
406
|
+
* Thoroughly document inflections. #5700 [petermichaux@gmail.com]
|
407
|
+
|
408
|
+
* Added Module#alias_attribute [Jamis/DHH]. Example:
|
409
|
+
|
410
|
+
class Content < ActiveRecord::Base
|
411
|
+
# has a title attribute
|
412
|
+
end
|
413
|
+
|
414
|
+
class Email < ActiveRecord::Base
|
415
|
+
alias_attribute :subject, :title
|
416
|
+
end
|
417
|
+
|
418
|
+
e = Email.find(1)
|
419
|
+
e.title # => "Superstars"
|
420
|
+
e.subject # => "Superstars"
|
421
|
+
e.subject? # => true
|
422
|
+
e.subject = "Megastars"
|
423
|
+
e.title # => "Megastars"
|
424
|
+
|
425
|
+
* Deprecation: easier to work with warning behavior as procs; default behaviors for each environment so users needn't update env.rb; and testing pleasure with assert_deprecated, assert_not_deprecated. [Jeremy Kemper]
|
426
|
+
By default, test prints to $stderr, dev logs, production ignores.
|
427
|
+
Provide your own per-environment in e.g. config/environments/development.rb:
|
428
|
+
ActiveSupport::Deprecation.behavior = Proc.new { |message| raise message }
|
429
|
+
|
430
|
+
* First cut of the Rails Deprecation system. [Koz]
|
431
|
+
|
432
|
+
* Strip boolean XML content before checking for 'true' [Rick Olson]
|
433
|
+
|
434
|
+
* Customize default BigDecimal formatting. References #5672 [dave@pragprog.com]
|
435
|
+
|
436
|
+
* Correctly convert <foo nil="true"> to nil when using Hash.create_from_xml. [Rick]
|
437
|
+
|
438
|
+
* Optional identity for Enumerable#sum defaults to zero. #5657 [gensym@mac.com]
|
439
|
+
|
440
|
+
* HashWithIndifferentAccess shouldn't confuse false and nil. #5601 [shugo@ruby-lang.org]
|
441
|
+
|
442
|
+
* Fixed HashWithIndifferentAccess#default #5586 [chris@seagul.co.uk]
|
443
|
+
|
444
|
+
* More compatible Hash.create_from_xml. #5523 [nunemaker@gmail.com]
|
445
|
+
|
446
|
+
* Added Enumerable#sum for calculating a sum from the elements [DHH, jonathan@daikini.com]. Examples:
|
447
|
+
|
448
|
+
[1, 2, 3].sum
|
449
|
+
payments.sum { |p| p.price * p.tax_rate }
|
450
|
+
payments.sum(&:price)
|
451
|
+
|
452
|
+
This is instead of payments.inject(0) { |sum, p| sum + p.price }
|
453
|
+
|
454
|
+
* Correct and clarify Array#to_sentence docs. #5458 [brad@madriska.com]
|
455
|
+
|
456
|
+
* alias_method_chain preserves method punctuation so foo, foo?, and foo! may be chained with the same feature. [Jeremy Kemper]
|
457
|
+
Example:
|
458
|
+
alias_method_chain :save!, :validation
|
459
|
+
is equivalent to
|
460
|
+
alias_method :save_without_validation!, :save!
|
461
|
+
alias_method :save!, :save_with_validation!
|
462
|
+
|
463
|
+
* Enhance Symbol#to_proc so it works with list objects, such as multi-dimensional arrays. Closes #5295 [nov@yo.rim.or.jp]. Example:
|
464
|
+
|
465
|
+
{1 => "one", 2 => "two", 3 => "three"}.sort_by(&:first).map(&:last)
|
466
|
+
#=> ["one", "two", "three"]
|
467
|
+
|
468
|
+
* Added Hash.create_from_xml(string) which will create a hash from a XML string and even typecast if possible [DHH]. Example:
|
469
|
+
|
470
|
+
Hash.create_from_xml <<-EOT
|
471
|
+
<note>
|
472
|
+
<title>This is a note</title>
|
473
|
+
<created-at type="date">2004-10-10</created-at>
|
474
|
+
</note>
|
475
|
+
EOT
|
476
|
+
|
477
|
+
...would return:
|
478
|
+
|
479
|
+
{ :note => { :title => "This is a note", :created_at => Date.new(2004, 10, 10) } }
|
480
|
+
|
481
|
+
* Added Jim Weirich's excellent FlexMock class to vendor (Copyright 2003, 2004 by Jim Weirich (jim@weriichhouse.org)) -- it's not automatically required, though, so require 'flexmock' is still necessary [DHH]
|
482
|
+
|
483
|
+
* Fixed that Module#alias_method_chain should work with both foo? foo! and foo at the same time #4954 [anna@wota.jp]
|
484
|
+
|
485
|
+
* to_xml fixes, features, and speedup: introduce :dasherize option that converts updated_at to updated-at if true (the existing default); binary columns get encoding="base64" attribute; nil values get nil="true" attribute to distinguish empty values; add type information for float columns; allow arbitrarily deep :include; include SQL type information as the type attribute. #4989 [Blair Zajac <blair@orcaware.com>]
|
486
|
+
|
487
|
+
* Add OrderedHash#values. [Sam Stephenson]
|
488
|
+
|
489
|
+
* Added Array#to_s(:db) that'll produce a comma-separated list of ids [DHH]. Example:
|
490
|
+
|
491
|
+
Purchase.find(:all, :conditions => "product_id IN (#{shops.products.to_s(:db)})"
|
492
|
+
|
493
|
+
* Normalize classify's argument to a String so that it plays nice with Symbols. [Marcel Molina Jr.]
|
494
|
+
|
495
|
+
* Strip out leading schema name in classify. References #5139. [schoenm@earthlink.net]
|
496
|
+
|
497
|
+
* Remove Enumerable#first_match since break(value) handles the use case well enough. [Nicholas Seckar]
|
498
|
+
|
499
|
+
Enumerable#first_match was like detect, but instead of returning the matching element, the yielded value returned. For example:
|
500
|
+
|
501
|
+
user_xml = adapters(:from => User, :to => Xml).first_match do |adapter|
|
502
|
+
adapter.adapt @user
|
503
|
+
end
|
504
|
+
|
505
|
+
But this is just as easily done with:
|
506
|
+
|
507
|
+
user_xml = adapters(:from => User, :to => Xml).each do
|
508
|
+
break adapter.adapt(@user)
|
509
|
+
end
|
510
|
+
|
511
|
+
* Make Array#in_groups_of just return the grouped collection if a block isn't given. [Marcel Molina Jr.]
|
512
|
+
|
513
|
+
* Don't destroy a HashWithIndifferentAccess if symbolize_keys! or stringify_keys! is called on it. Closes #5076. [Marcel Molina Jr., guy.naor@famundo.com]
|
514
|
+
|
515
|
+
* Document Module::delegate. #5002 [pergesu@gmail.com]
|
516
|
+
|
517
|
+
* Replace alias method chaining with Module#alias_method_chain. [Marcel Molina Jr.]
|
518
|
+
|
519
|
+
* Strip out punctuation on predicates or bang methods being aliased with alias_method_chain since target?_without_feature is not a valid method name. Add tests for Module#alias_method_chain. [Marcel Molina Jr.]
|
520
|
+
|
521
|
+
* Replace Ruby's deprecated append_features in favor of included. [Marcel Molina Jr.]
|
522
|
+
|
523
|
+
* Allow default options in with_options to be overridden. Closes #4480. [murphy@cYcnus.de]
|
524
|
+
|
525
|
+
* Added Module#alias_method_chain [Jamis Buck]
|
526
|
+
|
527
|
+
* Updated to Builder 2.0 [DHH]
|
528
|
+
|
529
|
+
* Add Array#split for dividing arrays into one or more subarrays by value or block. [Sam Stephenson]
|
530
|
+
|
531
|
+
*1.3.1* (April 6th, 2006)
|
532
|
+
|
533
|
+
* Clean paths inside of exception messages and traces. [Nicholas Seckar]
|
534
|
+
|
535
|
+
* Add Pathname.clean_within for cleaning all the paths inside of a string. [Nicholas Seckar]
|
536
|
+
|
537
|
+
* provide an empty Dependencies::LoadingModule.load which prints deprecation warnings. Lets 1.0 applications function with .13-style environment.rb.
|
538
|
+
|
539
|
+
|
540
|
+
*1.3.0* (March 27th, 2006)
|
541
|
+
|
542
|
+
* When possible, avoid incorrectly obtaining constants from parent modules. Fixes #4221. [Nicholas Seckar]
|
543
|
+
|
544
|
+
* Add more tests for dependencies; refactor existing cases. [Nicholas Seckar]
|
545
|
+
|
546
|
+
* Move Module#parent and Module#as_load_path into core_ext. Add Module#parent. [Nicholas Seckar]
|
547
|
+
|
548
|
+
* Add CachingTools::HashCaching to simplify the creation of nested, autofilling hashes. [Nicholas Seckar]
|
549
|
+
|
550
|
+
* Remove a hack intended to avoid unloading the same class twice, but which would not work anyways. [Nicholas Seckar]
|
551
|
+
|
552
|
+
* Update Object.subclasses_of to locate nested classes. This affects Object.remove_subclasses_of in that nested classes will now be unloaded. [Nicholas Seckar]
|
553
|
+
|
554
|
+
* Update Object.remove_subclasses_of to use Class.remove_class, reducing duplication. [Nicholas Seckar]
|
555
|
+
|
556
|
+
* Added Fixnum#seconds for consistency, so you can say 5.minutes + 30.seconds instead of 5.minutes + 30 #4389 [François Beausoleil]
|
557
|
+
|
558
|
+
* Added option to String#camelize to generate lower-cased camel case by passing in :lower, like "super_man".camelize(:lower) # => "superMan" [DHH]
|
559
|
+
|
560
|
+
* Added Hash#diff to show the difference between two hashes [Chris McGrath]
|
561
|
+
|
562
|
+
* Added Time#advance to do precise time time calculations for cases where a month being approximated to 30 days won't do #1860 [Rick Olson]
|
563
|
+
|
564
|
+
* Enhance Inflector.underscore to convert '-' into '_' (as the inverse of Inflector.dasherize) [Jamis Buck]
|
565
|
+
|
566
|
+
* Switched to_xml to use the xml schema format for datetimes. This allows the encoding of time zones and should improve operability. [Koz]
|
567
|
+
|
568
|
+
* Added a note to the documentation for the Date related Numeric extensions to indicate that they're
|
569
|
+
approximations and shouldn't be used for critical calculations. [Koz]
|
570
|
+
|
571
|
+
* Added Hash#to_xml and Array#to_xml that makes it much easier to produce XML from basic structures [DHH]. Examples:
|
572
|
+
|
573
|
+
{ :name => "David", :street_name => "Paulina", :age => 26, :moved_on => Date.new(2005, 11, 15) }.to_xml
|
574
|
+
|
575
|
+
...returns:
|
576
|
+
|
577
|
+
<person>
|
578
|
+
<street-name>Paulina</street-name>
|
579
|
+
<name>David</name>
|
580
|
+
<age type="integer">26</age>
|
581
|
+
<moved-on type="date">2005-11-15</moved-on>
|
582
|
+
</person>
|
583
|
+
|
584
|
+
* Moved Jim Weirich's wonderful Builder from Action Pack to Active Support (it's simply too useful to be stuck in AP) [DHH]
|
585
|
+
|
586
|
+
* Fixed that Array#to_sentence will return "" on an empty array instead of ", and" #3842, #4031 [rubyonrails@beautifulpixel.com]
|
587
|
+
|
588
|
+
* Add Enumerable#group_by for grouping collections based on the result of some
|
589
|
+
block. Useful, for example, for grouping records by date.
|
590
|
+
|
591
|
+
ex.
|
592
|
+
|
593
|
+
latest_transcripts.group_by(&:day).each do |day, transcripts|
|
594
|
+
p "#{day} -> #{transcripts.map(&:class) * ', '}"
|
595
|
+
end
|
596
|
+
"2006-03-01 -> Transcript"
|
597
|
+
"2006-02-28 -> Transcript"
|
598
|
+
"2006-02-27 -> Transcript, Transcript"
|
599
|
+
"2006-02-26 -> Transcript, Transcript"
|
600
|
+
|
601
|
+
Add Array#in_groups_of, for iterating over an array in groups of a certain
|
602
|
+
size.
|
603
|
+
|
604
|
+
ex.
|
605
|
+
|
606
|
+
%w(1 2 3 4 5 6 7).in_groups_of(3) {|g| p g}
|
607
|
+
["1", "2", "3"]
|
608
|
+
["4", "5", "6"]
|
609
|
+
["7", nil, nil]
|
610
|
+
|
611
|
+
[Marcel Molina Jr., Sam Stephenson]
|
612
|
+
|
613
|
+
* Added Kernel#daemonize to turn the current process into a daemon that can be killed with a TERM signal [DHH]
|
614
|
+
|
615
|
+
* Add 'around' methods to Logger, to make it easy to log before and after messages for a given block as requested in #3809. [Michael Koziarski] Example:
|
616
|
+
|
617
|
+
logger.around_info("Start rendering component (#{options.inspect}): ",
|
618
|
+
"\n\nEnd of component rendering") { yield }
|
619
|
+
|
620
|
+
* Added Time#beginning_of_quarter #3607 [cohen.jeff@gmail.com]
|
621
|
+
|
622
|
+
* Fix Object.subclasses_of to only return currently defined objects [Jonathan Viney <jonathan@bluewire.net.nz>]
|
623
|
+
|
624
|
+
* Fix constantize to properly handle names beginning with '::'. [Nicholas Seckar]
|
625
|
+
|
626
|
+
* Make String#last return the string instead of nil when it is shorter than the limit [Scott Barron].
|
627
|
+
|
628
|
+
* Added delegation support to Module that allows multiple delegations at once (unlike Forwardable in the stdlib) [DHH]. Example:
|
629
|
+
|
630
|
+
class Account < ActiveRecord::Base
|
631
|
+
has_one :subscription
|
632
|
+
delegate :free?, :paying?, :to => :subscription
|
633
|
+
delegate :overdue?, :to => "subscription.last_payment"
|
634
|
+
end
|
635
|
+
|
636
|
+
account.free? # => account.subscription.free?
|
637
|
+
account.overdue? # => account.subscription.last_payment.overdue?
|
638
|
+
|
639
|
+
* Fix Reloadable to handle the case where a class that has been 'removed' has not yet been garbage collected. [Nicholas Seckar]
|
640
|
+
|
641
|
+
* Don't allow Reloadable to be included into Modules.
|
642
|
+
|
643
|
+
* Remove LoadingModule. [Nicholas Seckar]
|
644
|
+
|
645
|
+
* Add documentation for Reloadable::Subclasses. [Nicholas Seckar]
|
646
|
+
|
647
|
+
* Add Reloadable::Subclasses which handles the common case where a base class should not be reloaded, but its subclasses should be. [Nicholas Seckar]
|
648
|
+
|
649
|
+
* Further improvements to reloading code [Nicholas Seckar, Trevor Squires]
|
650
|
+
|
651
|
+
- All classes/modules which include Reloadable can define reloadable? for fine grained control of reloading
|
652
|
+
- Class.remove_class uses Module#parent to access the parent module
|
653
|
+
- Class.remove_class expanded to handle multiple classes in a single call
|
654
|
+
- LoadingModule.clear! has been removed as it is no longer required
|
655
|
+
- Module#remove_classes_including has been removed in favor of Reloadable.reloadable_classes
|
656
|
+
|
657
|
+
* Added reusable reloading support through the inclusion of the Relodable module that all subclasses of ActiveRecord::Base, ActiveRecord::Observer, ActiveController::Base, and ActionMailer::Base automatically gets. This means that these classes will be reloaded by the dispatcher when Dependencies.mechanism = :load. You can make your own models reloadable easily:
|
658
|
+
|
659
|
+
class Setting
|
660
|
+
include Reloadable
|
661
|
+
end
|
662
|
+
|
663
|
+
Reloading a class is done by removing its constant which will cause it to be loaded again on the next reference. [DHH]
|
664
|
+
|
665
|
+
* Added auto-loading support for classes in modules, so Conductor::Migration will look for conductor/migration.rb and Conductor::Database::Settings will look for conductor/database/settings.rb [Nicholas Seckar]
|
666
|
+
|
667
|
+
* Add Object#instance_exec, like instance_eval but passes its arguments to the block. (Active Support will not override the Ruby 1.9 implementation of this method.) [Sam Stephenson]
|
668
|
+
|
669
|
+
* Add Proc#bind(object) for changing a proc or block's self by returning a Method bound to the given object. Based on why the lucky stiff's "cloaker" method. [Sam Stephenson]
|
670
|
+
|
671
|
+
* Fix merge and dup for hashes with indifferent access #3404 [kenneth.miller@bitfield.net]
|
672
|
+
|
673
|
+
* Fix the requires in option_merger_test to unbreak AS tests. [Sam Stephenson]
|
674
|
+
|
675
|
+
* Make HashWithIndifferentAccess#update behave like Hash#update by returning the hash. #3419, #3425 [asnem@student.ethz.ch, JanPrill@blauton.de, Marcel Molina Jr.]
|
676
|
+
|
677
|
+
* Add ActiveSupport::JSON and Object#to_json for converting Ruby objects to JSON strings. [Sam Stephenson]
|
678
|
+
|
679
|
+
* Add Object#with_options for DRYing up multiple calls to methods having shared options. [Sam Stephenson] Example:
|
680
|
+
|
681
|
+
ActionController::Routing::Routes.draw do |map|
|
682
|
+
# Account routes
|
683
|
+
map.with_options(:controller => 'account') do |account|
|
684
|
+
account.home '', :action => 'dashboard'
|
685
|
+
account.signup 'signup', :action => 'new'
|
686
|
+
account.logout 'logout', :action => 'logout'
|
687
|
+
end
|
688
|
+
end
|
689
|
+
|
690
|
+
* Introduce Dependencies.warnings_on_first_load setting. If true, enables warnings on first load of a require_dependency. Otherwise, loads without warnings. Disabled (set to false) by default. [Jeremy Kemper]
|
691
|
+
|
692
|
+
* Active Support is warnings-safe. #1792 [Eric Hodel]
|
693
|
+
|
694
|
+
* Introduce enable_warnings counterpart to silence_warnings. Turn warnings on when loading a file for the first time if Dependencies.mechanism == :load. Common mistakes such as redefined methods will print warnings to stderr. [Jeremy Kemper]
|
695
|
+
|
696
|
+
* Add Symbol#to_proc, which allows for, e.g. [:foo, :bar].map(&:to_s). [Marcel Molina Jr.]
|
697
|
+
|
698
|
+
* Added the following methods [Marcel Molina Jr., Sam Stephenson]:
|
699
|
+
* Object#copy_instance_variables_from(object) to copy instance variables from one object to another
|
700
|
+
* Object#extended_by to get an instance's included/extended modules
|
701
|
+
* Object#extend_with_included_modules_from(object) to extend an instance with the modules from another instance
|
702
|
+
|
703
|
+
*1.2.5* (December 13th, 2005)
|
704
|
+
|
705
|
+
* Become part of Rails 1.0
|
706
|
+
|
707
|
+
* Rename Version constant to VERSION. #2802 [Marcel Molina Jr.]
|
708
|
+
|
709
|
+
*1.2.3* (November 7th, 2005)
|
710
|
+
|
711
|
+
* Change Inflector#constantize to use eval instead of const_get. [Nicholas Seckar]
|
712
|
+
|
713
|
+
* Fix const_missing handler to ignore the trailing '.rb' on files when comparing paths. [Nicholas Seckar]
|
714
|
+
|
715
|
+
* Define kernel.rb methods in "class Object" instead of "module Kernel" to work around a Windows peculiarity [Sam Stephenson]
|
716
|
+
|
717
|
+
* Fix broken tests caused by incomplete loading of active support. [Nicholas Seckar]
|
718
|
+
|
719
|
+
* Fix status pluralization bug so status_codes doesn't get pluralized as statuses_code. #2758 [keithm@infused.org]
|
720
|
+
|
721
|
+
* Added Kernel#silence_stderr to silence stderr for the duration of the given block [Sam Stephenson]
|
722
|
+
|
723
|
+
* Changed Kernel#` to print a message to stderr (like Unix) instead of raising Errno::ENOENT on Win32 [Sam Stephenson]
|
724
|
+
|
725
|
+
* Changed 0.blank? to false rather than true since it violates everyone's expectation of blankness. #2518, #2705 [rails@jeffcole.net]
|
726
|
+
|
727
|
+
* When loading classes using const_missing, raise a NameError if and only if the file we tried to load was not present. [Nicholas Seckar]
|
728
|
+
|
729
|
+
* Added petabytes and exebytes to numeric extensions #2397 [timct@mac.com]
|
730
|
+
|
731
|
+
* Added Time#end_of_month to accompany Time#beginning_of_month #2514 [Jens-Christian Fischer]
|
732
|
+
|
733
|
+
|
734
|
+
*1.2.2* (October 26th, 2005)
|
735
|
+
|
736
|
+
* Set Logger.silencer = false to disable Logger#silence. Useful for debugging fixtures.
|
737
|
+
|
738
|
+
* Add title case method to String to do, e.g., 'action_web_service'.titlecase # => 'Action Web Service'. [Marcel Molina Jr.]
|
739
|
+
|
740
|
+
|
741
|
+
*1.2.1* (October 19th, 2005)
|
742
|
+
|
743
|
+
* Classify generated routing code as framework code to avoid appearing in application traces. [Nicholas Seckar]
|
744
|
+
|
745
|
+
* Show all framework frames in the framework trace. [Nicholas Seckar]
|
746
|
+
|
747
|
+
|
748
|
+
*1.2.0* (October 16th, 2005)
|
749
|
+
|
750
|
+
* Update Exception extension to show the first few framework frames in an application trace. [Nicholas Seckar]
|
751
|
+
|
752
|
+
* Added Exception extension to provide support for clean backtraces. [Nicholas Seckar]
|
753
|
+
|
754
|
+
* Updated whiny nil to be more concise and useful. [Nicholas Seckar]
|
755
|
+
|
756
|
+
* Added Enumerable#first_match [Nicholas Seckar]
|
757
|
+
|
758
|
+
* Fixed that Time#change should also reset usec when also resetting minutes #2459 [ikeda@dream.big.or.jp]
|
759
|
+
|
760
|
+
* Fix Logger compatibility for distributions that don't keep Ruby and its standard library in sync.
|
761
|
+
|
762
|
+
* Replace '%e' from long and short time formats as Windows does not support it. #2344. [Tom Ward <tom@popdog.net>]
|
763
|
+
|
764
|
+
* Added to_s(:db) to Range, so you can get "BETWEEN '2005-12-10' AND '2005-12-12'" from Date.new(2005, 12, 10)..Date.new(2005, 12, 12) (and likewise with Times)
|
765
|
+
|
766
|
+
* Moved require_library_or_gem into Kernel. #1992 [Michael Schuerig <michael@schuerig.de>]
|
767
|
+
|
768
|
+
* Add :rfc822 as an option for Time#to_s (to get rfc822-formatted times)
|
769
|
+
|
770
|
+
* Chain the const_missing hook to any previously existing hook so rails can play nicely with rake
|
771
|
+
|
772
|
+
* Clean logger is compatible with both 1.8.2 and 1.8.3 Logger. #2263 [Michael Schuerig <michael@schuerig.de>]
|
773
|
+
|
774
|
+
* Added native, faster implementations of .blank? for the core types #2286 [skae]
|
775
|
+
|
776
|
+
* Fixed clean logger to work with Ruby 1.8.3 Logger class #2245
|
777
|
+
|
778
|
+
* Fixed memory leak with Active Record classes when Dependencies.mechanism = :load #1704 [c.r.mcgrath@gmail.com]
|
779
|
+
|
780
|
+
* Fixed Inflector.underscore for use with acronyms, so HTML becomes html instead of htm_l #2173 [k@v2studio.com]
|
781
|
+
|
782
|
+
* Fixed dependencies related infinite recursion bug when a controller file does not contain a controller class. Closes #1760. [rcolli2@tampabay.rr.com]
|
783
|
+
|
784
|
+
* Fixed inflections for status, quiz, move #2056 [deirdre@deirdre.net]
|
785
|
+
|
786
|
+
* Added Hash#reverse_merge, Hash#reverse_merge!, and Hash#reverse_update to ease the use of default options
|
787
|
+
|
788
|
+
* Added Array#to_sentence that'll turn ['one', 'two', 'three'] into "one, two, and three" #2157 [m.stienstra@fngtps.com]
|
789
|
+
|
790
|
+
* Added Kernel#silence_warnings to turn off warnings temporarily for the passed block
|
791
|
+
|
792
|
+
* Added String#starts_with? and String#ends_with? #2118 [thijs@vandervossen.net]
|
793
|
+
|
794
|
+
* Added easy extendability to the inflector through Inflector.inflections (using the Inflector::Inflections singleton class). Examples:
|
795
|
+
|
796
|
+
Inflector.inflections do |inflect|
|
797
|
+
inflect.plural /^(ox)$/i, '\1\2en'
|
798
|
+
inflect.singular /^(ox)en/i, '\1'
|
799
|
+
|
800
|
+
inflect.irregular 'octopus', 'octopi'
|
801
|
+
|
802
|
+
inflect.uncountable "equipment"
|
803
|
+
end
|
804
|
+
|
805
|
+
* Added String#at, String#from, String#to, String#first, String#last in ActiveSupport::CoreExtensions::String::Access to ease access to individual characters and substrings in a string serving basically as human names for range access.
|
806
|
+
|
807
|
+
* Make Time#last_month work when invoked on the 31st of a month.
|
808
|
+
|
809
|
+
* Add Time.days_in_month, and make Time#next_month work when invoked on the 31st of a month
|
810
|
+
|
811
|
+
* Fixed that Time#midnight would have a non-zero usec on some platforms #1836
|
812
|
+
|
813
|
+
* Fixed inflections of "index/indices" #1766 [damn_pepe@gmail.com]
|
814
|
+
|
815
|
+
* Added stripping of _id to String#humanize, so "employee_id" becomes "Employee" #1574 [Justin French]
|
816
|
+
|
817
|
+
* Factor Fixnum and Bignum extensions into Integer extensions [Nicholas Seckar]
|
818
|
+
|
819
|
+
* Hooked #ordinalize into Fixnum and Bignum classes. [Nicholas Seckar, danp]
|
820
|
+
|
821
|
+
* Added Fixnum#ordinalize to turn 1.ordinalize to "1st", 3.ordinalize to "3rd", and 10.ordinalize to "10th" and so on #1724 [paul@cnt.org]
|
822
|
+
|
823
|
+
|
824
|
+
*1.1.1* (11 July, 2005)
|
825
|
+
|
826
|
+
* Added more efficient implementation of the development mode reset of classes #1638 [Chris McGrath]
|
827
|
+
|
828
|
+
|
829
|
+
*1.1.0* (6 July, 2005)
|
830
|
+
|
831
|
+
* Fixed conflict with Glue gem #1606 [Rick Olson]
|
832
|
+
|
833
|
+
* Added new rules to the Inflector to deal with more unusual plurals mouse/louse => mice/lice, information => information, ox => oxen, virus => viri, archive => archives #1571, #1583, #1490, #1599, #1608 [foamdino@gmail.com/others]
|
834
|
+
|
835
|
+
* Fixed memory leak with Object#remove_subclasses_of, which inflicted a Rails application running in development mode with a ~20KB leak per request #1289 [c.r.mcgrath@gmail.com]
|
836
|
+
|
837
|
+
* Made 1.year == 365.25.days to account for leap years. This allows you to do User.find(:all, :conditions => ['birthday > ?', 50.years.ago]) without losing a lot of days. #1488 [tuxie@dekadance.se]
|
838
|
+
|
839
|
+
* Added an exception if calling id on nil to WhinyNil #584 [kevin-temp@writesoon.com]
|
840
|
+
|
841
|
+
* Added Fix/Bignum#multiple_of? which returns true on 14.multiple_of?(7) and false on 16.multiple_of?(7) #1464 [Thomas Fuchs]
|
842
|
+
|
843
|
+
* Added even? and odd? to work with Bignums in addition to Fixnums #1464 [Thomas Fuchs]
|
844
|
+
|
845
|
+
* Fixed Time#at_beginning_of_week returned the next Monday instead of the previous one when called on a Sunday #1403 [jean.helou@gmail.com]
|
846
|
+
|
847
|
+
* Increased the speed of indifferent hash access by using Hash#default. #1436 [Nicholas Seckar]
|
848
|
+
|
849
|
+
* Added that " " is now also blank? (using strip if available)
|
850
|
+
|
851
|
+
* Fixed Dependencies so all modules are able to load missing constants #1173 [Nicholas Seckar]
|
852
|
+
|
853
|
+
* Fixed the Inflector to underscore strings containing numbers, so Area51Controller becomes area51_controller #1176 [Nicholas Seckar]
|
854
|
+
|
855
|
+
* Fixed that HashWithIndifferentAccess stringified all keys including symbols, ints, objects, and arrays #1162 [Nicholas Seckar]
|
856
|
+
|
857
|
+
* Fixed Time#last_year to go back in time, not forward #1278 [fabien@odilat.com]
|
858
|
+
|
859
|
+
* Fixed the pluralization of analysis to analyses #1295 [seattle@rootimage.msu.edu]
|
860
|
+
|
861
|
+
* Fixed that Time.local(2005,12).months_since(1) would raise "ArgumentError: argument out of range" #1311 [jhahn@niveon.com]
|
862
|
+
|
863
|
+
* Added silencing to the default Logger class
|
864
|
+
|
865
|
+
|
866
|
+
*1.0.4* (19th April, 2005)
|
867
|
+
|
868
|
+
* Fixed that in some circumstances controllers outside of modules may have hidden ones inside modules. For example, admin/content might have been hidden by /content. #1075 [Nicholas Seckar]
|
869
|
+
|
870
|
+
* Fixed inflection of perspectives and similar words #1045 [thijs@vandervossen.net]
|
871
|
+
|
872
|
+
* Added Fixnum#even? and Fixnum#odd?
|
873
|
+
|
874
|
+
* Fixed problem with classes being required twice. Object#const_missing now uses require_dependency to load files. It used to use require_or_load which would cause models to be loaded twice, which was not good for validations and other class methods #971 [Nicholas Seckar]
|
875
|
+
|
876
|
+
|
877
|
+
*1.0.3* (27th March, 2005)
|
878
|
+
|
879
|
+
* Fixed Inflector.pluralize to handle capitalized words #932 [Jeremy Kemper]
|
880
|
+
|
881
|
+
* Added Object#suppress which allows you to make a saner choice around with exceptions to swallow #980. Example:
|
882
|
+
|
883
|
+
suppress(ZeroDivisionError) { 1/0 }
|
884
|
+
|
885
|
+
...instead of:
|
886
|
+
|
887
|
+
1/0 rescue nil # BAD, EVIL, DIRTY.
|
888
|
+
|
889
|
+
|
890
|
+
*1.0.2* (22th March, 2005)
|
891
|
+
|
892
|
+
* Added Kernel#returning -- a Ruby-ized realization of the K combinator, courtesy of Mikael Brockman.
|
893
|
+
|
894
|
+
def foo
|
895
|
+
returning values = [] do
|
896
|
+
values << 'bar'
|
897
|
+
values << 'baz'
|
898
|
+
end
|
899
|
+
end
|
900
|
+
|
901
|
+
foo # => ['bar', 'baz']
|
902
|
+
|
903
|
+
|
904
|
+
*1.0.1* (7th March, 2005)
|
905
|
+
|
906
|
+
* Fixed Hash#indifferent_access to also deal with include? and fetch and nested hashes #726 [Nicholas Seckar]
|
907
|
+
|
908
|
+
* Added Object#blank? -- see http://redhanded.hobix.com/inspect/objectBlank.html #783 [_why the lucky stiff]
|
909
|
+
|
910
|
+
* Added inflection rules for "sh" words, like "wish" and "fish" #755 [phillip@pjbsoftware.com]
|
911
|
+
|
912
|
+
* Fixed an exception when using Ajax based requests from Safari because Safari appends a \000 to the post body. Symbols can't have \000 in them so indifferent access would throw an exception in the constructor. Indifferent hashes now use strings internally instead. #746 [Tobias Luetke]
|
913
|
+
|
914
|
+
* Added String#to_time and String#to_date for wrapping ParseDate
|
915
|
+
|
916
|
+
|
917
|
+
*1.0.0* (24th February, 2005)
|
918
|
+
|
919
|
+
* Added TimeZone as the first of a number of value objects that among others Active Record can use rich value objects using composed_of #688 [Jamis Buck]
|
920
|
+
|
921
|
+
* Added Date::Conversions for getting dates in different convenient string representations and other objects
|
922
|
+
|
923
|
+
* Added Time::Conversions for getting times in different convenient string representations and other objects
|
924
|
+
|
925
|
+
* Added Time::Calculations to ask for things like Time.now.tomorrow, Time.now.yesterday, Time.now.months_ago(4) #580 [DP|Flurin]. Examples:
|
926
|
+
|
927
|
+
"Later today" => now.in(3.hours),
|
928
|
+
"Tomorrow morning" => now.tomorrow.change(:hour => 9),
|
929
|
+
"Tomorrow afternoon" => now.tomorrow.change(:hour => 14),
|
930
|
+
"In a couple of days" => now.tomorrow.tomorrow.change(:hour => 9),
|
931
|
+
"Next monday" => now.next_week.change(:hour => 9),
|
932
|
+
"In a month" => now.next_month.change(:hour => 9),
|
933
|
+
"In 6 months" => now.months_since(6).change(:hour => 9),
|
934
|
+
"In a year" => now.in(1.year).change(:hour => 9)
|
935
|
+
|
936
|
+
* Upgraded to breakpoint 92 which fixes:
|
937
|
+
|
938
|
+
* overload IRB.parse_opts(), fixes #443
|
939
|
+
=> breakpoints in tests work even when running them via rake
|
940
|
+
* untaint handlers, might fix an issue discussed on the Rails ML
|
941
|
+
* added verbose mode to breakpoint_client
|
942
|
+
* less noise caused by breakpoint_client by default
|
943
|
+
* ignored TerminateLineInput exception in signal handler
|
944
|
+
=> quiet exit on Ctrl-C
|
945
|
+
|
946
|
+
* Fixed Inflector for words like "news" and "series" that are the same in plural and singular #603 [echion], #615 [marcenuc]
|
947
|
+
|
948
|
+
* Added Hash#stringify_keys and Hash#stringify_keys!
|
949
|
+
|
950
|
+
* Added IndifferentAccess as a way to wrap a hash by a symbol-based store that also can be accessed by string keys
|
951
|
+
|
952
|
+
* Added Inflector.constantize to turn "Admin::User" into a reference for the constant Admin::User
|
953
|
+
|
954
|
+
* Added that Inflector.camelize and Inflector.underscore can deal with modules like turning "Admin::User" into "admin/user" and back
|
955
|
+
|
956
|
+
* Added Inflector.humanize to turn attribute names like employee_salary into "Employee salary". Used by automated error reporting in AR.
|
957
|
+
|
958
|
+
* Added availability of class inheritable attributes to the masses #477 [Jeremy Kemper]
|
959
|
+
|
960
|
+
class Foo
|
961
|
+
class_inheritable_reader :read_me
|
962
|
+
class_inheritable_writer :write_me
|
963
|
+
class_inheritable_accessor :read_and_write_me
|
964
|
+
class_inheritable_array :read_and_concat_me
|
965
|
+
class_inheritable_hash :read_and_update_me
|
966
|
+
end
|
967
|
+
|
968
|
+
# Bar gets a clone of (not a reference to) Foo's attributes.
|
969
|
+
class Bar < Foo
|
970
|
+
end
|
971
|
+
|
972
|
+
Bar.read_and_write_me == Foo.read_and_write_me
|
973
|
+
Bar.read_and_write_me = 'bar'
|
974
|
+
Bar.read_and_write_me != Foo.read_and_write_me
|
975
|
+
|
976
|
+
* Added Inflections as an extension on String, so Inflector.pluralize(Inflector.classify(name)) becomes name.classify.pluralize #476 [Jeremy Kemper]
|
977
|
+
|
978
|
+
* Added Byte operations to Numeric, so 5.5.megabytes + 200.kilobytes #461 [Marcel Molina]
|
979
|
+
|
980
|
+
* Fixed that Dependencies.reload can't load the same file twice #420 [Kent Sibilev]
|
981
|
+
|
982
|
+
* Added Fixnum#ago/until, Fixnum#since/from_now #450 [Jeremy Kemper]
|
983
|
+
|
984
|
+
* Added that Inflector now accepts Symbols and Classes by calling .to_s on the word supplied
|
985
|
+
|
986
|
+
* Added time unit extensions to Fixnum that'll return the period in seconds, like 2.days + 4.hours.
|