activesupport 7.0.4.3 → 7.0.5

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of activesupport might be problematic. Click here for more details.

checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: af711c41eae644a4fba03556039ec8d30337836525e57b896af3fa895bd5826f
4
- data.tar.gz: 7c4eb0e42e2aaa1ba161eedd7657cdd8a458adfb456ac3df242a72dceceecc5c
3
+ metadata.gz: a007a97f7f9748390b963fa0d7e793dda24335ec0089354c759f8b821844ac7b
4
+ data.tar.gz: a03e94b740516fc4021504804acca899ea75644264b0bc13bd41746badbc38f6
5
5
  SHA512:
6
- metadata.gz: f255bc83f2f93d1743014853471a053798dbad3e8162551a0c0593eb5c5ea8abef362abf37de6c298985e9413c32b5ad02294a84dad063da8c150f8ce34d3051
7
- data.tar.gz: 39f1750b28dc755ead136f17a4b999b9d6e46a5bdf8b733ded897c6ec163f49b8651df20682b6568aa7bd8bf82c127aa5b00fc354ca80a82ba72c642caa25dd2
6
+ metadata.gz: 1a3b21f0c3a626fb6de1b4f79aa9a7d3178cbe20ed98a2ae33dac992fb2d899a057be8edcc932e1f03cfda59638208c668637528833dde7d39092c87b1128453
7
+ data.tar.gz: 3792e41389fb68f5bd0d7d6a806dbcb3d4822b8ab581deeada1f2741b0200563cc1e268ac8596493a4e2831a44a07f9f3ad2c053af2ec769f569394913340c0e
data/CHANGELOG.md CHANGED
@@ -1,3 +1,10 @@
1
+ ## Rails 7.0.5 (May 24, 2023) ##
2
+
3
+ * Fixes TimeWithZone ArgumentError.
4
+
5
+ *Niklas Häusele*
6
+
7
+
1
8
  ## Rails 7.0.4.3 (March 13, 2023) ##
2
9
 
3
10
  * Implement SafeBuffer#bytesplice
@@ -19,6 +26,19 @@
19
26
 
20
27
  ## Rails 7.0.4 (September 09, 2022) ##
21
28
 
29
+ * Ensure `ActiveSupport::Testing::Isolation::Forking` closes pipes
30
+
31
+ Previously, `Forking.run_in_isolation` opened two ends of a pipe. The fork
32
+ process closed the read end, wrote to it, and then terminated (which
33
+ presumably closed the file descriptors on its end). The parent process
34
+ closed the write end, read from it, and returned, never closing the read
35
+ end.
36
+
37
+ This resulted in an accumulation of open file descriptors, which could
38
+ cause errors if the limit is reached.
39
+
40
+ *Sam Bostock*
41
+
22
42
  * Redis cache store is now compatible with redis-rb 5.0.
23
43
 
24
44
  *Jean Boussier*
@@ -109,6 +109,21 @@ class Date
109
109
 
110
110
  # Provides precise Date calculations for years, months, and days. The +options+ parameter takes a hash with
111
111
  # any of these keys: <tt>:years</tt>, <tt>:months</tt>, <tt>:weeks</tt>, <tt>:days</tt>.
112
+ #
113
+ # The increments are applied in order of time units from largest to smallest.
114
+ # In other words, the date is incremented first by +:years+, then by
115
+ # +:months+, then by +:weeks+, then by +:days+. This order can affect the
116
+ # result around the end of a month. For example, incrementing first by months
117
+ # then by days:
118
+ #
119
+ # Date.new(2004, 9, 30).advance(months: 1, days: 1)
120
+ # # => Sun, 31 Oct 2004
121
+ #
122
+ # Whereas incrementing first by days then by months yields a different result:
123
+ #
124
+ # Date.new(2004, 9, 30).advance(days: 1).advance(months: 1)
125
+ # # => Mon, 01 Nov 2004
126
+ #
112
127
  def advance(options)
113
128
  d = self
114
129
 
@@ -75,6 +75,10 @@ class DateTime
75
75
  # The +options+ parameter takes a hash with any of these keys: <tt>:years</tt>,
76
76
  # <tt>:months</tt>, <tt>:weeks</tt>, <tt>:days</tt>, <tt>:hours</tt>,
77
77
  # <tt>:minutes</tt>, <tt>:seconds</tt>.
78
+ #
79
+ # Just like Date#advance, increments are applied in order of time units from
80
+ # largest to smallest. This order can affect the result around the end of a
81
+ # month.
78
82
  def advance(options)
79
83
  unless options[:weeks].nil?
80
84
  options[:weeks], partial_weeks = options[:weeks].divmod(1)
@@ -55,12 +55,12 @@ module Enumerable
55
55
 
56
56
  # Calculates a sum from the elements.
57
57
  #
58
- # payments.sum { |p| p.price * p.tax_rate }
59
- # payments.sum(&:price)
58
+ # payments.sum { |p| p.price * p.tax_rate }
59
+ # payments.sum(&:price)
60
60
  #
61
61
  # The latter is a shortcut for:
62
62
  #
63
- # payments.inject(0) { |sum, p| sum + p.price }
63
+ # payments.inject(0) { |sum, p| sum + p.price }
64
64
  #
65
65
  # It can also calculate the sum without the use of a block.
66
66
  #
@@ -80,7 +80,7 @@ module Enumerable
80
80
  # empty Enumerable; checking `empty?` would return
81
81
  # true for `[nil]`, which we want to deprecate to
82
82
  # keep consistent with Ruby
83
- elsif first.is_a?(Numeric) || first(1) == []
83
+ elsif first.is_a?(Numeric) || first(1) == [] || first.respond_to?(:coerce)
84
84
  identity ||= 0
85
85
  _original_sum_with_required_identity(identity, &block)
86
86
  else
@@ -144,8 +144,8 @@ module Enumerable
144
144
  def many?
145
145
  cnt = 0
146
146
  if block_given?
147
- any? do |element|
148
- cnt += 1 if yield element
147
+ any? do |element, *args|
148
+ cnt += 1 if yield element, *args
149
149
  cnt > 1
150
150
  end
151
151
  else
@@ -225,8 +225,8 @@ module Enumerable
225
225
  # [1, "", nil, 2, " ", [], {}, false, true].compact_blank
226
226
  # # => [1, 2, true]
227
227
  #
228
- # Set.new([nil, "", 1, 2])
229
- # # => [2, 1] (or [1, 2])
228
+ # Set.new([nil, "", 1, false]).compact_blank
229
+ # # => [1]
230
230
  #
231
231
  # When called on a +Hash+, returns a new +Hash+ without the blank values.
232
232
  #
@@ -245,7 +245,7 @@ module Enumerable
245
245
  # If the +series+ include keys that have no corresponding element in the Enumerable, these are ignored.
246
246
  # If the Enumerable has additional elements that aren't named in the +series+, these are not included in the result.
247
247
  def in_order_of(key, series)
248
- index_by(&key).values_at(*series).compact
248
+ group_by(&key).values_at(*series).flatten.compact
249
249
  end
250
250
 
251
251
  # Returns the sole item in the enumerable. If there are no items, or more
@@ -5,10 +5,10 @@ class Hash
5
5
  # This includes the values from the root hash and from all
6
6
  # nested hashes and arrays.
7
7
  #
8
- # hash = { person: { name: 'Rob', age: '28' } }
8
+ # hash = { person: { name: 'Rob', age: '28' } }
9
9
  #
10
- # hash.deep_transform_values{ |value| value.to_s.upcase }
11
- # # => {person: {name: "ROB", age: "28"}}
10
+ # hash.deep_transform_values{ |value| value.to_s.upcase }
11
+ # # => {person: {name: "ROB", age: "28"}}
12
12
  def deep_transform_values(&block)
13
13
  _deep_transform_values_in_object(self, &block)
14
14
  end
@@ -58,10 +58,10 @@ class Hash
58
58
  # This includes the keys from the root hash and from all
59
59
  # nested hashes and arrays.
60
60
  #
61
- # hash = { person: { name: 'Rob', age: '28' } }
61
+ # hash = { person: { name: 'Rob', age: '28' } }
62
62
  #
63
- # hash.deep_transform_keys{ |key| key.to_s.upcase }
64
- # # => {"PERSON"=>{"NAME"=>"Rob", "AGE"=>"28"}}
63
+ # hash.deep_transform_keys{ |key| key.to_s.upcase }
64
+ # # => {"PERSON"=>{"NAME"=>"Rob", "AGE"=>"28"}}
65
65
  def deep_transform_keys(&block)
66
66
  _deep_transform_keys_in_object(self, &block)
67
67
  end
@@ -6,12 +6,12 @@ class Integer
6
6
  # Ordinalize turns a number into an ordinal string used to denote the
7
7
  # position in an ordered sequence such as 1st, 2nd, 3rd, 4th.
8
8
  #
9
- # 1.ordinalize # => "1st"
10
- # 2.ordinalize # => "2nd"
11
- # 1002.ordinalize # => "1002nd"
12
- # 1003.ordinalize # => "1003rd"
13
- # -11.ordinalize # => "-11th"
14
- # -1001.ordinalize # => "-1001st"
9
+ # 1.ordinalize # => "1st"
10
+ # 2.ordinalize # => "2nd"
11
+ # 1002.ordinalize # => "1002nd"
12
+ # 1003.ordinalize # => "1003rd"
13
+ # -11.ordinalize # => "-11th"
14
+ # -1001.ordinalize # => "-1001st"
15
15
  def ordinalize
16
16
  ActiveSupport::Inflector.ordinalize(self)
17
17
  end
@@ -19,12 +19,12 @@ class Integer
19
19
  # Ordinal returns the suffix used to denote the position
20
20
  # in an ordered sequence such as 1st, 2nd, 3rd, 4th.
21
21
  #
22
- # 1.ordinal # => "st"
23
- # 2.ordinal # => "nd"
24
- # 1002.ordinal # => "nd"
25
- # 1003.ordinal # => "rd"
26
- # -11.ordinal # => "th"
27
- # -1001.ordinal # => "st"
22
+ # 1.ordinal # => "st"
23
+ # 2.ordinal # => "nd"
24
+ # 1002.ordinal # => "nd"
25
+ # 1003.ordinal # => "rd"
26
+ # -11.ordinal # => "th"
27
+ # -1001.ordinal # => "st"
28
28
  def ordinal
29
29
  ActiveSupport::Inflector.ordinal(self)
30
30
  end
@@ -31,8 +31,8 @@ end
31
31
  class Method
32
32
  # Methods are not duplicable:
33
33
  #
34
- # method(:puts).duplicable? # => false
35
- # method(:puts).dup # => TypeError: allocator undefined for Method
34
+ # method(:puts).duplicable? # => false
35
+ # method(:puts).dup # => TypeError: allocator undefined for Method
36
36
  def duplicable?
37
37
  false
38
38
  end
@@ -41,8 +41,8 @@ end
41
41
  class UnboundMethod
42
42
  # Unbound methods are not duplicable:
43
43
  #
44
- # method(:puts).unbind.duplicable? # => false
45
- # method(:puts).unbind.dup # => TypeError: allocator undefined for UnboundMethod
44
+ # method(:puts).unbind.duplicable? # => false
45
+ # method(:puts).unbind.dup # => TypeError: allocator undefined for UnboundMethod
46
46
  def duplicable?
47
47
  false
48
48
  end
@@ -53,7 +53,7 @@ require "singleton"
53
53
  module Singleton
54
54
  # Singleton instances are not duplicable:
55
55
  #
56
- # Class.new.include(Singleton).instance.dup # TypeError (can't dup instance of singleton
56
+ # Class.new.include(Singleton).instance.dup # TypeError (can't dup instance of singleton
57
57
  def duplicable?
58
58
  false
59
59
  end
@@ -64,7 +64,7 @@ class Object
64
64
  #
65
65
  # Hence the inherited default for +if+ key is ignored.
66
66
  #
67
- # NOTE: You cannot call class methods implicitly inside of with_options.
67
+ # NOTE: You cannot call class methods implicitly inside of +with_options+.
68
68
  # You can access these methods using the class name instead:
69
69
  #
70
70
  # class Phone < ActiveRecord::Base
@@ -83,11 +83,11 @@ class Object
83
83
  # end
84
84
  # end
85
85
  #
86
- # # styled.link_to "I'm red", "/"
87
- # # #=> <a href="/" style="color: red;">I'm red</a>
86
+ # styled.link_to "I'm red", "/"
87
+ # # => <a href="/" style="color: red;">I'm red</a>
88
88
  #
89
- # # styled.button_tag "I'm red too!"
90
- # # #=> <button style="color: red;">I'm red too!</button>
89
+ # styled.button_tag "I'm red too!"
90
+ # # => <button style="color: red;">I'm red too!</button>
91
91
  #
92
92
  def with_options(options, &block)
93
93
  option_merger = ActiveSupport::OptionMerger.new(self, options)
@@ -1,7 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- # frozen_string_literal: true
4
-
5
3
  ActiveSupport::Deprecation.warn(<<-MSG.squish)
6
4
  `active_support/core_ext/range/include_time_with_zone` is deprecated and will be removed in Rails 7.1.
7
5
  MSG
@@ -179,6 +179,10 @@ class Time
179
179
  # Time.new(2015, 8, 1, 14, 35, 0).advance(hours: 1) # => 2015-08-01 15:35:00 -0700
180
180
  # Time.new(2015, 8, 1, 14, 35, 0).advance(days: 1) # => 2015-08-02 14:35:00 -0700
181
181
  # Time.new(2015, 8, 1, 14, 35, 0).advance(weeks: 1) # => 2015-08-08 14:35:00 -0700
182
+ #
183
+ # Just like Date#advance, increments are applied in order of time units from
184
+ # largest to smallest. This order can affect the result around the end of a
185
+ # month.
182
186
  def advance(options)
183
187
  unless options[:weeks].nil?
184
188
  options[:weeks], partial_weeks = options[:weeks].divmod(1)
@@ -49,10 +49,9 @@ class Time
49
49
  # around_action :set_time_zone
50
50
  #
51
51
  # private
52
- #
53
- # def set_time_zone
54
- # Time.use_zone(current_user.timezone) { yield }
55
- # end
52
+ # def set_time_zone
53
+ # Time.use_zone(current_user.timezone) { yield }
54
+ # end
56
55
  # end
57
56
  #
58
57
  # NOTE: This won't affect any ActiveSupport::TimeWithZone
@@ -5,15 +5,15 @@ module ActiveSupport
5
5
  module Disallowed
6
6
  # Sets the criteria used to identify deprecation messages which should be
7
7
  # disallowed. Can be an array containing strings, symbols, or regular
8
- # expressions. (Symbols are treated as strings). These are compared against
8
+ # expressions. (Symbols are treated as strings.) These are compared against
9
9
  # the text of the generated deprecation warning.
10
10
  #
11
11
  # Additionally the scalar symbol +:all+ may be used to treat all
12
12
  # deprecations as disallowed.
13
13
  #
14
14
  # Deprecations matching a substring or regular expression will be handled
15
- # using the configured +ActiveSupport::Deprecation.disallowed_behavior+
16
- # rather than +ActiveSupport::Deprecation.behavior+
15
+ # using the configured Behavior#disallowed_behavior rather than
16
+ # Behavior#behavior.
17
17
  attr_writer :disallowed_warnings
18
18
 
19
19
  # Returns the configured criteria used to identify deprecation messages
@@ -7,6 +7,28 @@ require "active_support/core_ext/object/inclusion"
7
7
  require "active_support/core_ext/module/delegation"
8
8
 
9
9
  module ActiveSupport
10
+ # Provides convenience methods on top of EncryptedFile to access values stored
11
+ # as encrypted YAML.
12
+ #
13
+ # Values can be accessed via +Hash+ methods, such as +fetch+ and +dig+, or via
14
+ # dynamic accessor methods, similar to OrderedOptions.
15
+ #
16
+ # my_config = ActiveSupport::EncryptedConfiguration.new(...)
17
+ # my_config.read # => "some_secret: 123\nsome_namespace:\n another_secret: 456"
18
+ #
19
+ # my_config[:some_secret]
20
+ # # => 123
21
+ # my_config.some_secret
22
+ # # => 123
23
+ # my_config.dig(:some_namespace, :another_secret)
24
+ # # => 456
25
+ # my_config.some_namespace.another_secret
26
+ # # => 456
27
+ # my_config.fetch(:foo)
28
+ # # => KeyError
29
+ # my_config.foo!
30
+ # # => KeyError
31
+ #
10
32
  class EncryptedConfiguration < EncryptedFile
11
33
  delegate :[], :fetch, to: :config
12
34
  delegate_missing_to :options
@@ -16,10 +38,11 @@ module ActiveSupport
16
38
  env_key: env_key, raise_if_missing_key: raise_if_missing_key
17
39
  end
18
40
 
19
- # Allow a config to be started without a file present
41
+ # Reads the file and returns the decrypted content. See EncryptedFile#read.
20
42
  def read
21
43
  super
22
44
  rescue ActiveSupport::EncryptedFile::MissingContentError
45
+ # Allow a config to be started without a file present
23
46
  ""
24
47
  end
25
48
 
@@ -29,6 +52,14 @@ module ActiveSupport
29
52
  super
30
53
  end
31
54
 
55
+ # Returns the decrypted content as a Hash with symbolized keys.
56
+ #
57
+ # my_config = ActiveSupport::EncryptedConfiguration.new(...)
58
+ # my_config.read # => "some_secret: 123\nsome_namespace:\n another_secret: 456"
59
+ #
60
+ # my_config.config
61
+ # # => { some_secret: 123, some_namespace: { another_secret: 789 } }
62
+ #
32
63
  def config
33
64
  @config ||= deserialize(read).deep_symbolize_keys
34
65
  end
@@ -9,8 +9,8 @@ module ActiveSupport
9
9
  module VERSION
10
10
  MAJOR = 7
11
11
  MINOR = 0
12
- TINY = 4
13
- PRE = "3"
12
+ TINY = 5
13
+ PRE = nil
14
14
 
15
15
  STRING = [MAJOR, MINOR, TINY, PRE].compact.join(".")
16
16
  end
@@ -196,8 +196,8 @@ module ActiveSupport
196
196
  end
197
197
 
198
198
  # Creates a class name from a plural table name like Rails does for table
199
- # names to models. Note that this returns a string and not a Class (To
200
- # convert to an actual class follow +classify+ with #constantize).
199
+ # names to models. Note that this returns a string and not a Class. (To
200
+ # convert to an actual class follow +classify+ with #constantize.)
201
201
  #
202
202
  # classify('ham_and_eggs') # => "HamAndEgg"
203
203
  # classify('posts') # => "Post"
@@ -361,8 +361,8 @@ module ActiveSupport
361
361
  # If passed an optional +locale+ parameter, the uncountables will be
362
362
  # found for that locale.
363
363
  #
364
- # apply_inflections('post', inflections.plurals, :en) # => "posts"
365
- # apply_inflections('posts', inflections.singulars, :en) # => "post"
364
+ # apply_inflections('post', inflections.plurals, :en) # => "posts"
365
+ # apply_inflections('posts', inflections.singulars, :en) # => "post"
366
366
  def apply_inflections(word, rules, locale = :en)
367
367
  result = word.to_s.dup
368
368
 
@@ -66,7 +66,7 @@ module ActiveSupport
66
66
  # Executes all blocks registered to +name+ via on_load, using +base+ as the
67
67
  # evaluation context.
68
68
  #
69
- # ActiveSupport.run_load_hooks(:active_record, ActiveRecord::Base)
69
+ # ActiveSupport.run_load_hooks(:active_record, ActiveRecord::Base)
70
70
  #
71
71
  # In the case of the above example, it will execute all hooks registered
72
72
  # for +:active_record+ within the class +ActiveRecord::Base+.
@@ -237,8 +237,8 @@ module ActiveSupport
237
237
  #
238
238
  # Raises an error if invalid event name type is passed:
239
239
  #
240
- # ActiveSupport::Notifications.subscribe(:render) {|*args| ...}
241
- # #=> ArgumentError (pattern must be specified as a String, Regexp or empty)
240
+ # ActiveSupport::Notifications.subscribe(:render) {|*args| ...}
241
+ # #=> ArgumentError (pattern must be specified as a String, Regexp or empty)
242
242
  #
243
243
  def subscribe(pattern = nil, callback = nil, &block)
244
244
  notifier.subscribe(pattern, callback, monotonic: false, &block)
@@ -358,13 +358,14 @@ module ActiveSupport
358
358
  # out by default (set <tt>:strip_insignificant_zeros</tt> to
359
359
  # +false+ to change that):
360
360
  #
361
- # number_to_human(12.00001) # => "12"
362
- # number_to_human(12.00001, strip_insignificant_zeros: false) # => "12.0"
361
+ # number_to_human(12.00001) # => "12"
362
+ # number_to_human(12.00001, strip_insignificant_zeros: false) # => "12.0"
363
363
  #
364
364
  # ==== Custom Unit Quantifiers
365
365
  #
366
366
  # You can also use your own custom unit quantifiers:
367
- # number_to_human(500000, units: { unit: 'ml', thousand: 'lt' }) # => "500 lt"
367
+ #
368
+ # number_to_human(500000, units: { unit: 'ml', thousand: 'lt' }) # => "500 lt"
368
369
  #
369
370
  # If in your I18n locale you have:
370
371
  #
@@ -3,32 +3,36 @@
3
3
  require "active_support/core_ext/object/duplicable"
4
4
 
5
5
  module ActiveSupport
6
- # +ParameterFilter+ allows you to specify keys for sensitive data from
7
- # hash-like object and replace corresponding value. Filtering only certain
8
- # sub-keys from a hash is possible by using the dot notation:
9
- # 'credit_card.number'. If a proc is given, each key and value of a hash and
10
- # all sub-hashes are passed to it, where the value or the key can be replaced
11
- # using String#replace or similar methods.
6
+ # +ParameterFilter+ replaces values in a <tt>Hash</tt>-like object if their
7
+ # keys match one of the specified filters.
12
8
  #
9
+ # Matching based on nested keys is possible by using dot notation, e.g.
10
+ # <tt>"credit_card.number"</tt>.
11
+ #
12
+ # If a proc is given as a filter, each key and value of the <tt>Hash</tt>-like
13
+ # and of any nested <tt>Hash</tt>es will be passed to it. The value or key can
14
+ # then be mutated as desired using methods such as <tt>String#replace</tt>.
15
+ #
16
+ # # Replaces values with "[FILTERED]" for keys that match /password/i.
13
17
  # ActiveSupport::ParameterFilter.new([:password])
14
- # => replaces the value to all keys matching /password/i with "[FILTERED]"
15
18
  #
19
+ # # Replaces values with "[FILTERED]" for keys that match /foo|bar/i.
16
20
  # ActiveSupport::ParameterFilter.new([:foo, "bar"])
17
- # => replaces the value to all keys matching /foo|bar/i with "[FILTERED]"
18
21
  #
19
- # ActiveSupport::ParameterFilter.new([/\Apin\z/i, /\Apin_/i])
20
- # => replaces the value for the exact (case-insensitive) key 'pin' and all
21
- # (case-insensitive) keys beginning with 'pin_', with "[FILTERED]".
22
- # Does not match keys with 'pin' as a substring, such as 'shipping_id'.
22
+ # # Replaces values for the exact key "pin" and for keys that begin with
23
+ # # "pin_". Does not match keys that otherwise include "pin" as a
24
+ # # substring, such as "shipping_id".
25
+ # ActiveSupport::ParameterFilter.new([/\Apin\z/, /\Apin_/])
23
26
  #
27
+ # # Replaces the value for :code in `{ credit_card: { code: "xxxx" } }`.
28
+ # # Does not change `{ file: { code: "xxxx" } }`.
24
29
  # ActiveSupport::ParameterFilter.new(["credit_card.code"])
25
- # => replaces { credit_card: {code: "xxxx"} } with "[FILTERED]", does not
26
- # change { file: { code: "xxxx"} }
27
30
  #
31
+ # # Reverses values for keys that match /secret/i.
28
32
  # ActiveSupport::ParameterFilter.new([-> (k, v) do
29
33
  # v.reverse! if /secret/i.match?(k)
30
34
  # end])
31
- # => reverses the value to all keys matching /secret/i
35
+ #
32
36
  class ParameterFilter
33
37
  FILTERED = "[FILTERED]" # :nodoc:
34
38
 
@@ -25,38 +25,39 @@ module ActiveSupport
25
25
 
26
26
  module Forking
27
27
  def run_in_isolation(&blk)
28
- read, write = IO.pipe
29
- read.binmode
30
- write.binmode
28
+ IO.pipe do |read, write|
29
+ read.binmode
30
+ write.binmode
31
31
 
32
- pid = fork do
33
- read.close
34
- yield
35
- begin
36
- if error?
37
- failures.map! { |e|
38
- begin
39
- Marshal.dump e
40
- e
41
- rescue TypeError
42
- ex = Exception.new e.message
43
- ex.set_backtrace e.backtrace
44
- Minitest::UnexpectedError.new ex
45
- end
46
- }
32
+ pid = fork do
33
+ read.close
34
+ yield
35
+ begin
36
+ if error?
37
+ failures.map! { |e|
38
+ begin
39
+ Marshal.dump e
40
+ e
41
+ rescue TypeError
42
+ ex = Exception.new e.message
43
+ ex.set_backtrace e.backtrace
44
+ Minitest::UnexpectedError.new ex
45
+ end
46
+ }
47
+ end
48
+ test_result = defined?(Minitest::Result) ? Minitest::Result.from(self) : dup
49
+ result = Marshal.dump(test_result)
47
50
  end
48
- test_result = defined?(Minitest::Result) ? Minitest::Result.from(self) : dup
49
- result = Marshal.dump(test_result)
51
+
52
+ write.puts [result].pack("m")
53
+ exit!
50
54
  end
51
55
 
52
- write.puts [result].pack("m")
53
- exit!
56
+ write.close
57
+ result = read.read
58
+ Process.wait2(pid)
59
+ result.unpack1("m")
54
60
  end
55
-
56
- write.close
57
- result = read.read
58
- Process.wait2(pid)
59
- result.unpack1("m")
60
61
  end
61
62
  end
62
63
 
@@ -566,8 +566,8 @@ module ActiveSupport
566
566
 
567
567
  # Send the missing method to +time+ instance, and wrap result in a new
568
568
  # TimeWithZone with the existing +time_zone+.
569
- def method_missing(sym, *args, &block)
570
- wrap_with_time_zone time.__send__(sym, *args, &block)
569
+ def method_missing(...)
570
+ wrap_with_time_zone time.__send__(...)
571
571
  rescue NoMethodError => e
572
572
  raise e, e.message.sub(time.inspect, inspect).sub("Time", "ActiveSupport::TimeWithZone"), e.backtrace
573
573
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: activesupport
3
3
  version: !ruby/object:Gem::Version
4
- version: 7.0.4.3
4
+ version: 7.0.5
5
5
  platform: ruby
6
6
  authors:
7
7
  - David Heinemeier Hansson
8
- autorequire:
8
+ autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2023-03-13 00:00:00.000000000 Z
11
+ date: 2023-05-24 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: i18n
@@ -359,12 +359,12 @@ licenses:
359
359
  - MIT
360
360
  metadata:
361
361
  bug_tracker_uri: https://github.com/rails/rails/issues
362
- changelog_uri: https://github.com/rails/rails/blob/v7.0.4.3/activesupport/CHANGELOG.md
363
- documentation_uri: https://api.rubyonrails.org/v7.0.4.3/
362
+ changelog_uri: https://github.com/rails/rails/blob/v7.0.5/activesupport/CHANGELOG.md
363
+ documentation_uri: https://api.rubyonrails.org/v7.0.5/
364
364
  mailing_list_uri: https://discuss.rubyonrails.org/c/rubyonrails-talk
365
- source_code_uri: https://github.com/rails/rails/tree/v7.0.4.3/activesupport
365
+ source_code_uri: https://github.com/rails/rails/tree/v7.0.5/activesupport
366
366
  rubygems_mfa_required: 'true'
367
- post_install_message:
367
+ post_install_message:
368
368
  rdoc_options:
369
369
  - "--encoding"
370
370
  - UTF-8
@@ -381,8 +381,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
381
381
  - !ruby/object:Gem::Version
382
382
  version: '0'
383
383
  requirements: []
384
- rubygems_version: 3.4.3
385
- signing_key:
384
+ rubygems_version: 3.4.10
385
+ signing_key:
386
386
  specification_version: 4
387
387
  summary: A toolkit of support libraries and Ruby core extensions extracted from the
388
388
  Rails framework.