activesupport 7.2.3 → 8.0.0.beta1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/CHANGELOG.md +41 -385
- data/README.rdoc +1 -1
- data/lib/active_support/backtrace_cleaner.rb +2 -2
- data/lib/active_support/benchmark.rb +21 -0
- data/lib/active_support/benchmarkable.rb +3 -2
- data/lib/active_support/broadcast_logger.rb +74 -61
- data/lib/active_support/cache/file_store.rb +14 -4
- data/lib/active_support/cache/mem_cache_store.rb +15 -13
- data/lib/active_support/cache/memory_store.rb +9 -5
- data/lib/active_support/cache/null_store.rb +2 -2
- data/lib/active_support/cache/redis_cache_store.rb +6 -3
- data/lib/active_support/cache/strategy/local_cache.rb +20 -56
- data/lib/active_support/cache.rb +17 -12
- data/lib/active_support/callbacks.rb +3 -5
- data/lib/active_support/class_attribute.rb +26 -0
- data/lib/active_support/code_generator.rb +9 -0
- data/lib/active_support/concurrency/share_lock.rb +0 -1
- data/lib/active_support/configuration_file.rb +15 -6
- data/lib/active_support/core_ext/benchmark.rb +6 -10
- data/lib/active_support/core_ext/class/attribute.rb +12 -21
- data/lib/active_support/core_ext/date/conversions.rb +2 -0
- data/lib/active_support/core_ext/date_and_time/compatibility.rb +2 -2
- data/lib/active_support/core_ext/date_time/conversions.rb +2 -4
- data/lib/active_support/core_ext/enumerable.rb +13 -20
- data/lib/active_support/core_ext/erb/util.rb +2 -2
- data/lib/active_support/core_ext/hash/except.rb +0 -12
- data/lib/active_support/core_ext/module/introspection.rb +0 -3
- data/lib/active_support/core_ext/object/json.rb +18 -14
- data/lib/active_support/core_ext/object/try.rb +2 -2
- data/lib/active_support/core_ext/range.rb +0 -1
- data/lib/active_support/core_ext/securerandom.rb +8 -24
- data/lib/active_support/core_ext/string/filters.rb +3 -3
- data/lib/active_support/core_ext/string/multibyte.rb +3 -3
- data/lib/active_support/core_ext/time/calculations.rb +14 -2
- data/lib/active_support/core_ext/time/compatibility.rb +1 -9
- data/lib/active_support/core_ext/time/conversions.rb +2 -0
- data/lib/active_support/core_ext/time/zones.rb +1 -1
- data/lib/active_support/current_attributes.rb +7 -14
- data/lib/active_support/deprecation.rb +1 -1
- data/lib/active_support/encrypted_configuration.rb +20 -2
- data/lib/active_support/error_reporter.rb +27 -6
- data/lib/active_support/execution_wrapper.rb +1 -1
- data/lib/active_support/file_update_checker.rb +1 -1
- data/lib/active_support/gem_version.rb +4 -4
- data/lib/active_support/hash_with_indifferent_access.rb +31 -31
- data/lib/active_support/i18n_railtie.rb +19 -10
- data/lib/active_support/isolated_execution_state.rb +0 -1
- data/lib/active_support/json/decoding.rb +1 -1
- data/lib/active_support/json/encoding.rb +7 -25
- data/lib/active_support/lazy_load_hooks.rb +1 -1
- data/lib/active_support/message_encryptors.rb +2 -2
- data/lib/active_support/message_verifier.rb +0 -9
- data/lib/active_support/message_verifiers.rb +3 -5
- data/lib/active_support/messages/rotator.rb +0 -5
- data/lib/active_support/multibyte/chars.rb +1 -4
- data/lib/active_support/number_helper.rb +22 -0
- data/lib/active_support/railtie.rb +4 -0
- data/lib/active_support/tagged_logging.rb +5 -0
- data/lib/active_support/testing/assertions.rb +72 -21
- data/lib/active_support/testing/isolation.rb +0 -2
- data/lib/active_support/testing/parallelization/server.rb +2 -15
- data/lib/active_support/testing/parallelization/worker.rb +2 -2
- data/lib/active_support/testing/parallelization.rb +1 -12
- data/lib/active_support/testing/strict_warnings.rb +43 -0
- data/lib/active_support/testing/time_helpers.rb +2 -1
- data/lib/active_support/time_with_zone.rb +22 -13
- data/lib/active_support/values/time_zone.rb +17 -15
- data/lib/active_support/xml_mini.rb +0 -2
- data/lib/active_support.rb +10 -2
- metadata +27 -8
- data/lib/active_support/core_ext/range/sole.rb +0 -17
checksums.yaml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
---
|
|
2
2
|
SHA256:
|
|
3
|
-
metadata.gz:
|
|
4
|
-
data.tar.gz:
|
|
3
|
+
metadata.gz: 492cd4c9d2ec59d97060d7949b3b68badc089d97ea467a30a0e6614d65e69c21
|
|
4
|
+
data.tar.gz: 98af51f7ec102b694fbd17f636cdf942b965a9a845561f05b1569b07efc56747
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: b720480df1c4117bf85c0f9066f7015dc750ca1279bba4c07a66a429effa06101adab40eda21f76c6d14ee1c57d46b6aff5cffd494e0e55d18600fe764c9d0e5
|
|
7
|
+
data.tar.gz: 13d40213e5c9720bda46e71d696a6f011547ca95ade865061df922cc9abd5adfbf6a0daa651e0732314dfb67faf3c9ad3fde39bb3490f4e3fd7577fb24b8221b
|
data/CHANGELOG.md
CHANGED
|
@@ -1,157 +1,4 @@
|
|
|
1
|
-
## Rails
|
|
2
|
-
|
|
3
|
-
* Fix `Enumerable#sole` to return the full tuple instead of just the first element of the tuple.
|
|
4
|
-
|
|
5
|
-
*Olivier Bellone*
|
|
6
|
-
|
|
7
|
-
* Fix parallel tests hanging when worker processes die abruptly.
|
|
8
|
-
|
|
9
|
-
Previously, if a worker process was killed (e.g., OOM killed, `kill -9`) during parallel
|
|
10
|
-
test execution, the test suite would hang forever waiting for the dead worker.
|
|
11
|
-
|
|
12
|
-
*Joshua Young*
|
|
13
|
-
|
|
14
|
-
* `ActiveSupport::FileUpdateChecker` does not depend on `Time.now` to prevent unnecessary reloads with time travel test helpers
|
|
15
|
-
|
|
16
|
-
*Jan Grodowski*
|
|
17
|
-
|
|
18
|
-
* Fix `ActiveSupport::BroadcastLogger` from executing a block argument for each logger (tagged, info, etc.).
|
|
19
|
-
|
|
20
|
-
*Jared Armstrong*
|
|
21
|
-
|
|
22
|
-
* Fix `ActiveSupport::HashWithIndifferentAccess#transform_keys!` removing defaults.
|
|
23
|
-
|
|
24
|
-
*Hartley McGuire*
|
|
25
|
-
|
|
26
|
-
* Fix `ActiveSupport::HashWithIndifferentAccess#tranform_keys!` to handle collisions.
|
|
27
|
-
|
|
28
|
-
If the transformation would result in a key equal to another not yet transformed one,
|
|
29
|
-
it would result in keys being lost.
|
|
30
|
-
|
|
31
|
-
Before:
|
|
32
|
-
|
|
33
|
-
```ruby
|
|
34
|
-
>> {a: 1, b: 2}.with_indifferent_access.transform_keys!(&:succ)
|
|
35
|
-
=> {"c" => 1}
|
|
36
|
-
```
|
|
37
|
-
|
|
38
|
-
After:
|
|
39
|
-
|
|
40
|
-
```ruby
|
|
41
|
-
>> {a: 1, b: 2}.with_indifferent_access.transform_keys!(&:succ)
|
|
42
|
-
=> {"c" => 1, "d" => 2}
|
|
43
|
-
```
|
|
44
|
-
|
|
45
|
-
*Jason T Johnson*, *Jean Boussier*
|
|
46
|
-
|
|
47
|
-
* Fix `ActiveSupport::Cache::MemCacheStore#read_multi` to handle network errors.
|
|
48
|
-
|
|
49
|
-
This method specifically wasn't handling network errors like other codepaths.
|
|
50
|
-
|
|
51
|
-
*Alessandro Dal Grande*
|
|
52
|
-
|
|
53
|
-
* Fix Active Support Cache `fetch_multi` when local store is active.
|
|
54
|
-
|
|
55
|
-
`fetch_multi` now properly yield to the provided block for missing entries
|
|
56
|
-
that have been recorded as such in the local store.
|
|
57
|
-
|
|
58
|
-
*Jean Boussier*
|
|
59
|
-
|
|
60
|
-
* Fix execution wrapping to report all exceptions, including `Exception`.
|
|
61
|
-
|
|
62
|
-
If a more serious error like `SystemStackError` or `NoMemoryError` happens,
|
|
63
|
-
the error reporter should be able to report these kinds of exceptions.
|
|
64
|
-
|
|
65
|
-
*Gannon McGibbon*
|
|
66
|
-
|
|
67
|
-
* Fix `RedisCacheStore` and `MemCacheStore` to also handle connection pool related errors.
|
|
68
|
-
|
|
69
|
-
These errors are rescued and reported to `Rails.error`.
|
|
70
|
-
|
|
71
|
-
*Jean Boussier*
|
|
72
|
-
|
|
73
|
-
* Fix `ActiveSupport::Cache#read_multi` to respect version expiry when using local cache.
|
|
74
|
-
|
|
75
|
-
*zzak*
|
|
76
|
-
|
|
77
|
-
* Fix `ActiveSupport::MessageVerifier` and `ActiveSupport::MessageEncryptor` configuration of `on_rotation` callback.
|
|
78
|
-
|
|
79
|
-
```ruby
|
|
80
|
-
verifier.rotate(old_secret).on_rotation { ... }
|
|
81
|
-
```
|
|
82
|
-
|
|
83
|
-
Now both work as documented.
|
|
84
|
-
|
|
85
|
-
*Jean Boussier*
|
|
86
|
-
|
|
87
|
-
* Fix `ActiveSupport::MessageVerifier` to always be able to verify both URL-safe and URL-unsafe payloads.
|
|
88
|
-
|
|
89
|
-
This is to allow transitioning seemlessly from either configuration without immediately invalidating
|
|
90
|
-
all previously generated signed messages.
|
|
91
|
-
|
|
92
|
-
*Jean Boussier*, *Florent Beaurain*, *Ali Sepehri*
|
|
93
|
-
|
|
94
|
-
* Fix `cache.fetch` to honor the provided expiry when `:race_condition_ttl` is used.
|
|
95
|
-
|
|
96
|
-
```ruby
|
|
97
|
-
cache.fetch("key", expires_in: 1.hour, race_condition_ttl: 5.second) do
|
|
98
|
-
"something"
|
|
99
|
-
end
|
|
100
|
-
```
|
|
101
|
-
|
|
102
|
-
In the above example, the final cache entry would have a 10 seconds TTL instead
|
|
103
|
-
of the requested 1 hour.
|
|
104
|
-
|
|
105
|
-
*Dhia*
|
|
106
|
-
|
|
107
|
-
* Better handle procs with splat arguments in `set_callback`.
|
|
108
|
-
|
|
109
|
-
*Radamés Roriz*
|
|
110
|
-
|
|
111
|
-
* Fix `String#mb_chars` to not mutate the receiver.
|
|
112
|
-
|
|
113
|
-
Previously it would call `force_encoding` on the receiver,
|
|
114
|
-
now it dups the receiver first.
|
|
115
|
-
|
|
116
|
-
*Jean Boussier*
|
|
117
|
-
|
|
118
|
-
* Improve `ErrorSubscriber` to also mark error causes as reported.
|
|
119
|
-
|
|
120
|
-
This avoid some cases of errors being reported twice, notably in views because of how
|
|
121
|
-
errors are wrapped in `ActionView::Template::Error`.
|
|
122
|
-
|
|
123
|
-
*Jean Boussier*
|
|
124
|
-
|
|
125
|
-
* Fix `Module#module_parent_name` to return the correct name after the module has been named.
|
|
126
|
-
|
|
127
|
-
When called on an anonymous module, the return value wouldn't change after the module was given a name
|
|
128
|
-
later by being assigned to a constant.
|
|
129
|
-
|
|
130
|
-
```ruby
|
|
131
|
-
mod = Module.new
|
|
132
|
-
mod.module_parent_name # => "Object"
|
|
133
|
-
MyModule::Something = mod
|
|
134
|
-
mod.module_parent_name # => "MyModule"
|
|
135
|
-
```
|
|
136
|
-
|
|
137
|
-
*Jean Boussier*
|
|
138
|
-
|
|
139
|
-
* Fix a bug in `ERB::Util.tokenize` that causes incorrect tokenization when ERB tags are preceeded by multibyte characters.
|
|
140
|
-
|
|
141
|
-
*Martin Emde*
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
## Rails 7.2.2.2 (August 13, 2025) ##
|
|
145
|
-
|
|
146
|
-
* No changes.
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
## Rails 7.2.2.1 (December 10, 2024) ##
|
|
150
|
-
|
|
151
|
-
* No changes.
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
## Rails 7.2.2 (October 30, 2024) ##
|
|
1
|
+
## Rails 8.0.0.beta1 (September 26, 2024) ##
|
|
155
2
|
|
|
156
3
|
* Include options when instrumenting `ActiveSupport::Cache::Store#delete` and `ActiveSupport::Cache::Store#delete_multi`.
|
|
157
4
|
|
|
@@ -161,272 +8,81 @@
|
|
|
161
8
|
|
|
162
9
|
*John Hawthorn*, *Abeid Ahmed*
|
|
163
10
|
|
|
11
|
+
* Deprecate `Benchmark.ms` core extension.
|
|
164
12
|
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
* No changes.
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
## Rails 7.2.1.1 (October 15, 2024) ##
|
|
171
|
-
|
|
172
|
-
* No changes.
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
## Rails 7.2.1 (August 22, 2024) ##
|
|
176
|
-
|
|
177
|
-
* No changes.
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
## Rails 7.2.0 (August 09, 2024) ##
|
|
181
|
-
|
|
182
|
-
* Fix `delegate_missing_to allow_nil: true` when called with implict self
|
|
183
|
-
|
|
184
|
-
```ruby
|
|
185
|
-
class Person
|
|
186
|
-
delegate_missing_to :address, allow_nil: true
|
|
187
|
-
|
|
188
|
-
def address
|
|
189
|
-
nil
|
|
190
|
-
end
|
|
191
|
-
|
|
192
|
-
def berliner?
|
|
193
|
-
city == "Berlin"
|
|
194
|
-
end
|
|
195
|
-
end
|
|
196
|
-
|
|
197
|
-
Person.new.city # => nil
|
|
198
|
-
Person.new.berliner? # undefined local variable or method `city' for an instance of Person (NameError)
|
|
199
|
-
```
|
|
200
|
-
|
|
201
|
-
*Jean Boussier*
|
|
202
|
-
|
|
203
|
-
* Add `logger` as a dependency since it is a bundled gem candidate for Ruby 3.5
|
|
13
|
+
The `benchmark` gem will become bundled in Ruby 3.5
|
|
204
14
|
|
|
205
15
|
*Earlopain*
|
|
206
16
|
|
|
207
|
-
*
|
|
208
|
-
|
|
209
|
-
*Xavier Noria*
|
|
210
|
-
|
|
211
|
-
* Support `duration` type in `ActiveSupport::XmlMini`.
|
|
212
|
-
|
|
213
|
-
*heka1024*
|
|
214
|
-
|
|
215
|
-
* Remove deprecated `ActiveSupport::Notifications::Event#children` and `ActiveSupport::Notifications::Event#parent_of?`.
|
|
216
|
-
|
|
217
|
-
*Rafael Mendonça França*
|
|
218
|
-
|
|
219
|
-
* Remove deprecated support to call the following methods without passing a deprecator:
|
|
220
|
-
|
|
221
|
-
- `deprecate`
|
|
222
|
-
- `deprecate_constant`
|
|
223
|
-
- `ActiveSupport::Deprecation::DeprecatedObjectProxy.new`
|
|
224
|
-
- `ActiveSupport::Deprecation::DeprecatedInstanceVariableProxy.new`
|
|
225
|
-
- `ActiveSupport::Deprecation::DeprecatedConstantProxy.new`
|
|
226
|
-
- `assert_deprecated`
|
|
227
|
-
- `assert_not_deprecated`
|
|
228
|
-
- `collect_deprecations`
|
|
229
|
-
|
|
230
|
-
*Rafael Mendonça França*
|
|
231
|
-
|
|
232
|
-
* Remove deprecated `ActiveSupport::Deprecation` delegation to instance.
|
|
233
|
-
|
|
234
|
-
*Rafael Mendonça França*
|
|
235
|
-
|
|
236
|
-
* Remove deprecated `SafeBuffer#clone_empty`.
|
|
237
|
-
|
|
238
|
-
*Rafael Mendonça França*
|
|
239
|
-
|
|
240
|
-
* Remove deprecated `#to_default_s` from `Array`, `Date`, `DateTime` and `Time`.
|
|
241
|
-
|
|
242
|
-
*Rafael Mendonça França*
|
|
243
|
-
|
|
244
|
-
* Remove deprecated support to passing `Dalli::Client` instances to `MemCacheStore`.
|
|
245
|
-
|
|
246
|
-
*Rafael Mendonça França*
|
|
247
|
-
|
|
248
|
-
* Remove deprecated `config.active_support.use_rfc4122_namespaced_uuids`.
|
|
249
|
-
|
|
250
|
-
*Rafael Mendonça França*
|
|
251
|
-
|
|
252
|
-
* Remove deprecated `config.active_support.remove_deprecated_time_with_zone_name`.
|
|
253
|
-
|
|
254
|
-
*Rafael Mendonça França*
|
|
255
|
-
|
|
256
|
-
* Remove deprecated `config.active_support.disable_to_s_conversion`.
|
|
257
|
-
|
|
258
|
-
*Rafael Mendonça França*
|
|
259
|
-
|
|
260
|
-
* Remove deprecated support to bolding log text with positional boolean in `ActiveSupport::LogSubscriber#color`.
|
|
261
|
-
|
|
262
|
-
*Rafael Mendonça França*
|
|
263
|
-
|
|
264
|
-
* Remove deprecated constants `ActiveSupport::LogSubscriber::CLEAR` and `ActiveSupport::LogSubscriber::BOLD`.
|
|
265
|
-
|
|
266
|
-
*Rafael Mendonça França*
|
|
267
|
-
|
|
268
|
-
* Remove deprecated support for `config.active_support.cache_format_version = 6.1`.
|
|
269
|
-
|
|
270
|
-
*Rafael Mendonça França*
|
|
271
|
-
|
|
272
|
-
* Remove deprecated `:pool_size` and `:pool_timeout` options for the cache storage.
|
|
273
|
-
|
|
274
|
-
*Rafael Mendonça França*
|
|
275
|
-
|
|
276
|
-
* Warn on tests without assertions.
|
|
277
|
-
|
|
278
|
-
`ActiveSupport::TestCase` now warns when tests do not run any assertions.
|
|
279
|
-
This is helpful in detecting broken tests that do not perform intended assertions.
|
|
17
|
+
* `ActiveSupport::TimeWithZone#inspect` now uses ISO 8601 style time like `Time#inspect`
|
|
280
18
|
|
|
281
|
-
*
|
|
19
|
+
*John Hawthorn*
|
|
282
20
|
|
|
283
|
-
*
|
|
21
|
+
* `ActiveSupport::ErrorReporter#report` now assigns a backtrace to unraised exceptions.
|
|
284
22
|
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
* Deprecate `ActiveSupport::ProxyObject` in favor of Ruby's built-in `BasicObject`.
|
|
288
|
-
|
|
289
|
-
*Earlopain*
|
|
290
|
-
|
|
291
|
-
* `stub_const` now accepts a `exists: false` parameter to allow stubbing missing constants.
|
|
292
|
-
|
|
293
|
-
*Jean Boussier*
|
|
294
|
-
|
|
295
|
-
* Make `ActiveSupport::BacktraceCleaner` copy filters and silencers on dup and clone.
|
|
296
|
-
|
|
297
|
-
Previously the copy would still share the internal silencers and filters array,
|
|
298
|
-
causing state to leak.
|
|
23
|
+
Previously reporting an un-raised exception would result in an error report without
|
|
24
|
+
a backtrace. Now it automatically generates one.
|
|
299
25
|
|
|
300
26
|
*Jean Boussier*
|
|
301
27
|
|
|
302
|
-
*
|
|
303
|
-
|
|
304
|
-
*Damian Nelson*
|
|
305
|
-
|
|
306
|
-
* Add filename support for `ActiveSupport::Logger.logger_outputs_to?`.
|
|
307
|
-
|
|
308
|
-
```ruby
|
|
309
|
-
logger = Logger.new('/var/log/rails.log')
|
|
310
|
-
ActiveSupport::Logger.logger_outputs_to?(logger, '/var/log/rails.log')
|
|
311
|
-
```
|
|
312
|
-
|
|
313
|
-
*Christian Schmidt*
|
|
314
|
-
|
|
315
|
-
* Include `IPAddr#prefix` when serializing an `IPAddr` using the
|
|
316
|
-
`ActiveSupport::MessagePack` serializer.
|
|
317
|
-
|
|
318
|
-
This change is backward and forward compatible — old payloads can
|
|
319
|
-
still be read, and new payloads will be readable by older versions of Rails.
|
|
320
|
-
|
|
321
|
-
*Taiki Komaba*
|
|
322
|
-
|
|
323
|
-
* Add `default:` support for `ActiveSupport::CurrentAttributes.attribute`.
|
|
324
|
-
|
|
325
|
-
```ruby
|
|
326
|
-
class Current < ActiveSupport::CurrentAttributes
|
|
327
|
-
attribute :counter, default: 0
|
|
328
|
-
end
|
|
329
|
-
```
|
|
330
|
-
|
|
331
|
-
*Sean Doyle*
|
|
28
|
+
* Add `escape_html_entities` option to `ActiveSupport::JSON.encode`.
|
|
332
29
|
|
|
333
|
-
|
|
30
|
+
This allows for overriding the global configuration found at
|
|
31
|
+
`ActiveSupport.escape_html_entities_in_json` for specific calls to `to_json`.
|
|
334
32
|
|
|
33
|
+
This should be usable from controllers in the following manner:
|
|
335
34
|
```ruby
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
```
|
|
340
|
-
|
|
341
|
-
*Sean Doyle*
|
|
342
|
-
|
|
343
|
-
* Use logical core count instead of physical core count to determine the
|
|
344
|
-
default number of workers when parallelizing tests.
|
|
345
|
-
|
|
346
|
-
*Jonathan Hefner*
|
|
347
|
-
|
|
348
|
-
* Fix `Time.now/DateTime.now/Date.today` to return results in a system timezone after `#travel_to`.
|
|
349
|
-
|
|
350
|
-
There is a bug in the current implementation of #travel_to:
|
|
351
|
-
it remembers a timezone of its argument, and all stubbed methods start
|
|
352
|
-
returning results in that remembered timezone. However, the expected
|
|
353
|
-
behavior is to return results in a system timezone.
|
|
354
|
-
|
|
355
|
-
*Aleksei Chernenkov*
|
|
356
|
-
|
|
357
|
-
* Add `ErrorReported#unexpected` to report precondition violations.
|
|
358
|
-
|
|
359
|
-
For example:
|
|
360
|
-
|
|
361
|
-
```ruby
|
|
362
|
-
def edit
|
|
363
|
-
if published?
|
|
364
|
-
Rails.error.unexpected("[BUG] Attempting to edit a published article, that shouldn't be possible")
|
|
365
|
-
return false
|
|
35
|
+
class MyController < ApplicationController
|
|
36
|
+
def index
|
|
37
|
+
render json: { hello: "world" }, escape_html_entities: false
|
|
366
38
|
end
|
|
367
|
-
# ...
|
|
368
39
|
end
|
|
369
40
|
```
|
|
370
41
|
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
*Jean Boussier*
|
|
374
|
-
|
|
375
|
-
* Make the order of read_multi and write_multi notifications for `Cache::Store#fetch_multi` operations match the order they are executed in.
|
|
376
|
-
|
|
377
|
-
*Adam Renberg Tamm*
|
|
42
|
+
*Nigel Baillie*
|
|
378
43
|
|
|
379
|
-
*
|
|
44
|
+
* Raise when using key which can't respond to `#to_sym` in `EncryptedConfiguration`.
|
|
380
45
|
|
|
381
|
-
|
|
382
|
-
`nil` if there was an error talking to the cache backend, and `false` if the write failed
|
|
383
|
-
for another reason (e.g. the key already exists and `unless_exist: true` was passed).
|
|
46
|
+
As is the case when trying to use an Integer or Float as a key, which is unsupported.
|
|
384
47
|
|
|
385
|
-
*
|
|
386
|
-
|
|
387
|
-
* Fix logged cache keys not always matching actual key used by cache action.
|
|
388
|
-
|
|
389
|
-
*Hartley McGuire*
|
|
390
|
-
|
|
391
|
-
* Improve error messages of `assert_changes` and `assert_no_changes`.
|
|
48
|
+
*zzak*
|
|
392
49
|
|
|
393
|
-
|
|
394
|
-
to differentiate nil from empty strings, strings from symbols, etc.
|
|
395
|
-
`assert_no_changes` error messages now surface the actual value.
|
|
50
|
+
* Deprecate addition and since between two `Time` and `ActiveSupport::TimeWithZone`.
|
|
396
51
|
|
|
397
|
-
|
|
52
|
+
Previously adding time instances together such as `10.days.ago + 10.days.ago` or `10.days.ago.since(10.days.ago)` produced a nonsensical future date. This behavior is deprecated and will be removed in Rails 8.1.
|
|
398
53
|
|
|
399
|
-
*
|
|
54
|
+
*Nick Schwaderer*
|
|
400
55
|
|
|
401
|
-
|
|
56
|
+
* Support rfc2822 format for Time#to_fs & Date#to_fs.
|
|
402
57
|
|
|
403
|
-
*
|
|
58
|
+
*Akshay Birajdar*
|
|
404
59
|
|
|
405
|
-
|
|
60
|
+
* Optimize load time for `Railtie#initialize_i18n`. Filter `I18n.load_path`s passed to the file watcher to only those
|
|
61
|
+
under `Rails.root`. Previously the watcher would grab all available locales, including those in gems
|
|
62
|
+
which do not require a watcher because they won't change.
|
|
406
63
|
|
|
407
|
-
*
|
|
64
|
+
*Nick Schwaderer*
|
|
408
65
|
|
|
409
|
-
|
|
66
|
+
* Add a `filter` option to `in_order_of` to prioritize certain values in the sorting without filtering the results
|
|
67
|
+
by these values.
|
|
410
68
|
|
|
411
|
-
*
|
|
69
|
+
*Igor Depolli*
|
|
412
70
|
|
|
413
|
-
|
|
414
|
-
|
|
71
|
+
* Improve error message when using `assert_difference` or `assert_changes` with a
|
|
72
|
+
proc by printing the proc's source code (MRI only).
|
|
415
73
|
|
|
416
|
-
|
|
417
|
-
`SemanticLogger` instance.
|
|
74
|
+
*Richard Böhme*, *Jean Boussier*
|
|
418
75
|
|
|
419
|
-
|
|
76
|
+
* Add a new configuration value `:zone` for `ActiveSupport.to_time_preserves_timezone` and rename the previous `true` value to `:offset`. The new default value is `:zone`.
|
|
420
77
|
|
|
421
|
-
*
|
|
78
|
+
*Jason Kim*, *John Hawthorn*
|
|
422
79
|
|
|
423
|
-
|
|
80
|
+
* Align instrumentation `payload[:key]` in ActiveSupport::Cache to follow the same pattern, with namespaced and normalized keys.
|
|
424
81
|
|
|
425
|
-
*
|
|
82
|
+
*Frederik Erbs Spang Thomsen*
|
|
426
83
|
|
|
427
|
-
|
|
428
|
-
method from the `Hash` class, which was not able to access values using indifferent keys.
|
|
84
|
+
* Fix `travel_to` to set usec 0 when `with_usec` is `false` and the given argument String or DateTime.
|
|
429
85
|
|
|
430
|
-
*
|
|
86
|
+
*mopp*
|
|
431
87
|
|
|
432
|
-
Please check [7-
|
|
88
|
+
Please check [7-2-stable](https://github.com/rails/rails/blob/7-2-stable/activesupport/CHANGELOG.md) for previous changes.
|
data/README.rdoc
CHANGED
|
@@ -35,6 +35,6 @@ Bug reports for the Ruby on \Rails project can be filed here:
|
|
|
35
35
|
|
|
36
36
|
* https://github.com/rails/rails/issues
|
|
37
37
|
|
|
38
|
-
Feature requests should be discussed on the
|
|
38
|
+
Feature requests should be discussed on the rails-core mailing list here:
|
|
39
39
|
|
|
40
40
|
* https://discuss.rubyonrails.org/c/rubyonrails-core
|
|
@@ -18,7 +18,7 @@ module ActiveSupport
|
|
|
18
18
|
#
|
|
19
19
|
# bc = ActiveSupport::BacktraceCleaner.new
|
|
20
20
|
# root = "#{Rails.root}/"
|
|
21
|
-
# bc.add_filter { |line| line.
|
|
21
|
+
# bc.add_filter { |line| line.delete_prefix(root) } # strip the Rails.root prefix
|
|
22
22
|
# bc.add_silencer { |line| /puma|rubygems/.match?(line) } # skip any lines from puma or rubygems
|
|
23
23
|
# bc.clean(exception.backtrace) # perform the cleanup
|
|
24
24
|
#
|
|
@@ -79,7 +79,7 @@ module ActiveSupport
|
|
|
79
79
|
#
|
|
80
80
|
# # Will turn "/my/rails/root/app/models/person.rb" into "app/models/person.rb"
|
|
81
81
|
# root = "#{Rails.root}/"
|
|
82
|
-
# backtrace_cleaner.add_filter { |line| line.
|
|
82
|
+
# backtrace_cleaner.add_filter { |line| line.start_with?(root) ? line.from(root.size) : line }
|
|
83
83
|
def add_filter(&block)
|
|
84
84
|
@filters << block
|
|
85
85
|
end
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module ActiveSupport
|
|
4
|
+
module Benchmark # :nodoc:
|
|
5
|
+
# Benchmark realtime in the specified time unit. By default,
|
|
6
|
+
# the returned unit is in seconds.
|
|
7
|
+
#
|
|
8
|
+
# ActiveSupport::Benchmark.realtime { sleep 0.1 }
|
|
9
|
+
# # => 0.10007
|
|
10
|
+
#
|
|
11
|
+
# ActiveSupport::Benchmark.realtime(:float_millisecond) { sleep 0.1 }
|
|
12
|
+
# # => 100.07
|
|
13
|
+
#
|
|
14
|
+
# `unit` can be any of the values accepted by Ruby's `Process.clock_gettime`.
|
|
15
|
+
def self.realtime(unit = :float_second, &block)
|
|
16
|
+
time_start = Process.clock_gettime(Process::CLOCK_MONOTONIC, unit)
|
|
17
|
+
yield
|
|
18
|
+
Process.clock_gettime(Process::CLOCK_MONOTONIC, unit) - time_start
|
|
19
|
+
end
|
|
20
|
+
end
|
|
21
|
+
end
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
# frozen_string_literal: true
|
|
2
2
|
|
|
3
|
-
require "active_support/core_ext/benchmark"
|
|
4
3
|
require "active_support/core_ext/hash/keys"
|
|
5
4
|
|
|
6
5
|
module ActiveSupport
|
|
@@ -41,7 +40,9 @@ module ActiveSupport
|
|
|
41
40
|
options[:level] ||= :info
|
|
42
41
|
|
|
43
42
|
result = nil
|
|
44
|
-
ms = Benchmark.
|
|
43
|
+
ms = ActiveSupport::Benchmark.realtime(:float_millisecond) do
|
|
44
|
+
result = options[:silence] ? logger.silence(&block) : yield
|
|
45
|
+
end
|
|
45
46
|
logger.public_send(options[:level], "%s (%.1fms)" % [ message, ms ])
|
|
46
47
|
result
|
|
47
48
|
else
|