activesupport 3.1.0 → 5.0.0
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 +7 -0
- data/CHANGELOG.md +798 -0
- data/MIT-LICENSE +20 -0
- data/README.rdoc +13 -7
- data/lib/active_support/array_inquirer.rb +44 -0
- data/lib/active_support/backtrace_cleaner.rb +38 -34
- data/lib/active_support/benchmarkable.rb +17 -28
- data/lib/active_support/cache/file_store.rb +85 -70
- data/lib/active_support/cache/mem_cache_store.rb +75 -66
- data/lib/active_support/cache/memory_store.rb +31 -23
- data/lib/active_support/cache/null_store.rb +41 -0
- data/lib/active_support/cache/strategy/local_cache.rb +73 -70
- data/lib/active_support/cache/strategy/local_cache_middleware.rb +44 -0
- data/lib/active_support/cache.rb +360 -294
- data/lib/active_support/callbacks.rb +563 -393
- data/lib/active_support/concern.rb +42 -34
- data/lib/active_support/concurrency/latch.rb +19 -0
- data/lib/active_support/concurrency/share_lock.rb +186 -0
- data/lib/active_support/configurable.rb +70 -12
- data/lib/active_support/core_ext/array/access.rb +53 -9
- data/lib/active_support/core_ext/array/conversions.rb +109 -62
- data/lib/active_support/core_ext/array/extract_options.rb +2 -2
- data/lib/active_support/core_ext/array/grouping.rb +39 -32
- data/lib/active_support/core_ext/array/inquiry.rb +17 -0
- data/lib/active_support/core_ext/array/prepend_and_append.rb +7 -0
- data/lib/active_support/core_ext/array/wrap.rb +16 -18
- data/lib/active_support/core_ext/array.rb +2 -2
- data/lib/active_support/core_ext/benchmark.rb +7 -0
- data/lib/active_support/core_ext/big_decimal/conversions.rb +8 -36
- data/lib/active_support/core_ext/class/attribute.rb +47 -34
- data/lib/active_support/core_ext/class/attribute_accessors.rb +4 -79
- data/lib/active_support/core_ext/class/subclasses.rb +12 -7
- data/lib/active_support/core_ext/class.rb +0 -3
- data/lib/active_support/core_ext/date/blank.rb +12 -0
- data/lib/active_support/core_ext/date/calculations.rb +57 -167
- data/lib/active_support/core_ext/date/conversions.rb +31 -42
- data/lib/active_support/core_ext/date/zones.rb +2 -10
- data/lib/active_support/core_ext/date.rb +5 -0
- data/lib/active_support/core_ext/date_and_time/calculations.rb +335 -0
- data/lib/active_support/core_ext/date_and_time/compatibility.rb +18 -0
- data/lib/active_support/core_ext/date_and_time/zones.rb +40 -0
- data/lib/active_support/core_ext/date_time/acts_like.rb +1 -0
- data/lib/active_support/core_ext/date_time/blank.rb +12 -0
- data/lib/active_support/core_ext/date_time/calculations.rb +132 -65
- data/lib/active_support/core_ext/date_time/compatibility.rb +5 -0
- data/lib/active_support/core_ext/date_time/conversions.rb +36 -34
- data/lib/active_support/core_ext/date_time.rb +5 -0
- data/lib/active_support/core_ext/digest/uuid.rb +51 -0
- data/lib/active_support/core_ext/enumerable.rb +81 -74
- data/lib/active_support/core_ext/file/atomic.rb +53 -26
- data/lib/active_support/core_ext/file.rb +0 -1
- data/lib/active_support/core_ext/hash/compact.rb +20 -0
- data/lib/active_support/core_ext/hash/conversions.rb +175 -70
- data/lib/active_support/core_ext/hash/deep_merge.rb +30 -8
- data/lib/active_support/core_ext/hash/except.rb +11 -12
- data/lib/active_support/core_ext/hash/indifferent_access.rb +7 -8
- data/lib/active_support/core_ext/hash/keys.rb +147 -24
- data/lib/active_support/core_ext/hash/reverse_merge.rb +2 -3
- data/lib/active_support/core_ext/hash/slice.rb +22 -14
- data/lib/active_support/core_ext/hash/transform_values.rb +29 -0
- data/lib/active_support/core_ext/hash.rb +2 -2
- data/lib/active_support/core_ext/integer/inflections.rb +13 -1
- data/lib/active_support/core_ext/integer/multiple.rb +4 -0
- data/lib/active_support/core_ext/integer/time.rb +12 -22
- data/lib/active_support/core_ext/kernel/agnostics.rb +2 -2
- data/lib/active_support/core_ext/kernel/concern.rb +12 -0
- data/lib/active_support/core_ext/kernel/debugger.rb +2 -15
- data/lib/active_support/core_ext/kernel/reporting.rb +12 -62
- data/lib/active_support/core_ext/kernel/singleton_class.rb +0 -7
- data/lib/active_support/core_ext/kernel.rb +2 -3
- data/lib/active_support/core_ext/load_error.rb +14 -7
- data/lib/active_support/core_ext/marshal.rb +22 -0
- data/lib/active_support/core_ext/module/aliasing.rb +16 -12
- data/lib/active_support/core_ext/module/anonymous.rb +12 -8
- data/lib/active_support/core_ext/module/attr_internal.rb +2 -5
- data/lib/active_support/core_ext/module/attribute_accessors.rb +165 -13
- data/lib/active_support/core_ext/module/attribute_accessors_per_thread.rb +141 -0
- data/lib/active_support/core_ext/module/concerning.rb +135 -0
- data/lib/active_support/core_ext/module/delegation.rb +141 -68
- data/lib/active_support/core_ext/module/deprecation.rb +17 -3
- data/lib/active_support/core_ext/module/introspection.rb +9 -31
- data/lib/active_support/core_ext/module/method_transplanting.rb +3 -0
- data/lib/active_support/core_ext/module/qualified_const.rb +70 -0
- data/lib/active_support/core_ext/module/reachable.rb +1 -3
- data/lib/active_support/core_ext/module/remove_method.rb +24 -5
- data/lib/active_support/core_ext/module.rb +3 -3
- data/lib/active_support/core_ext/name_error.rb +15 -2
- data/lib/active_support/core_ext/numeric/bytes.rb +20 -0
- data/lib/active_support/core_ext/numeric/conversions.rb +145 -0
- data/lib/active_support/core_ext/numeric/inquiry.rb +26 -0
- data/lib/active_support/core_ext/numeric/time.rb +31 -36
- data/lib/active_support/core_ext/numeric.rb +2 -0
- data/lib/active_support/core_ext/object/acts_like.rb +4 -4
- data/lib/active_support/core_ext/object/blank.rb +52 -18
- data/lib/active_support/core_ext/object/deep_dup.rb +53 -0
- data/lib/active_support/core_ext/object/duplicable.rb +12 -20
- data/lib/active_support/core_ext/object/inclusion.rb +13 -1
- data/lib/active_support/core_ext/object/instance_variables.rb +7 -12
- data/lib/active_support/core_ext/object/json.rb +205 -0
- data/lib/active_support/core_ext/object/to_param.rb +1 -55
- data/lib/active_support/core_ext/object/to_query.rb +66 -9
- data/lib/active_support/core_ext/object/try.rb +124 -33
- data/lib/active_support/core_ext/object/with_options.rb +37 -11
- data/lib/active_support/core_ext/object.rb +2 -1
- data/lib/active_support/core_ext/range/conversions.rb +17 -7
- data/lib/active_support/core_ext/range/each.rb +21 -0
- data/lib/active_support/core_ext/range/include_range.rb +20 -18
- data/lib/active_support/core_ext/range/overlaps.rb +1 -1
- data/lib/active_support/core_ext/range.rb +1 -2
- data/lib/active_support/core_ext/securerandom.rb +23 -0
- data/lib/active_support/core_ext/string/access.rb +95 -90
- data/lib/active_support/core_ext/string/behavior.rb +1 -1
- data/lib/active_support/core_ext/string/conversions.rb +41 -38
- data/lib/active_support/core_ext/string/exclude.rb +6 -1
- data/lib/active_support/core_ext/string/filters.rb +70 -17
- data/lib/active_support/core_ext/string/indent.rb +43 -0
- data/lib/active_support/core_ext/string/inflections.rb +139 -59
- data/lib/active_support/core_ext/string/inquiry.rb +2 -2
- data/lib/active_support/core_ext/string/multibyte.rb +46 -65
- data/lib/active_support/core_ext/string/output_safety.rb +153 -56
- data/lib/active_support/core_ext/string/strip.rb +3 -6
- data/lib/active_support/core_ext/string/zones.rb +14 -0
- data/lib/active_support/core_ext/string.rb +2 -3
- data/lib/active_support/core_ext/struct.rb +3 -0
- data/lib/active_support/core_ext/time/calculations.rb +173 -173
- data/lib/active_support/core_ext/time/compatibility.rb +5 -0
- data/lib/active_support/core_ext/time/conversions.rb +33 -29
- data/lib/active_support/core_ext/time/marshal.rb +2 -56
- data/lib/active_support/core_ext/time/zones.rb +57 -32
- data/lib/active_support/core_ext/time.rb +5 -0
- data/lib/active_support/core_ext/uri.rb +13 -19
- data/lib/active_support/core_ext.rb +3 -2
- data/lib/active_support/dependencies/autoload.rb +47 -20
- data/lib/active_support/dependencies/interlock.rb +51 -0
- data/lib/active_support/dependencies.rb +315 -265
- data/lib/active_support/deprecation/behaviors.rb +71 -30
- data/lib/active_support/deprecation/instance_delegator.rb +24 -0
- data/lib/active_support/deprecation/method_wrappers.rb +59 -18
- data/lib/active_support/deprecation/proxy_wrappers.rb +82 -14
- data/lib/active_support/deprecation/reporting.rb +61 -14
- data/lib/active_support/deprecation.rb +38 -13
- data/lib/active_support/descendants_tracker.rb +34 -19
- data/lib/active_support/duration/iso8601_parser.rb +122 -0
- data/lib/active_support/duration/iso8601_serializer.rb +51 -0
- data/lib/active_support/duration.rb +85 -14
- data/lib/active_support/evented_file_update_checker.rb +194 -0
- data/lib/active_support/execution_wrapper.rb +117 -0
- data/lib/active_support/executor.rb +6 -0
- data/lib/active_support/file_update_checker.rb +138 -17
- data/lib/active_support/gem_version.rb +15 -0
- data/lib/active_support/gzip.rb +11 -5
- data/lib/active_support/hash_with_indifferent_access.rb +199 -49
- data/lib/active_support/i18n.rb +6 -2
- data/lib/active_support/i18n_railtie.rb +40 -21
- data/lib/active_support/inflections.rb +22 -13
- data/lib/active_support/inflector/inflections.rb +175 -144
- data/lib/active_support/inflector/methods.rb +328 -91
- data/lib/active_support/inflector/transliterate.rb +51 -37
- data/lib/active_support/json/decoding.rb +31 -22
- data/lib/active_support/json/encoding.rb +88 -248
- data/lib/active_support/key_generator.rb +71 -0
- data/lib/active_support/lazy_load_hooks.rb +27 -25
- data/lib/active_support/locale/en.yml +102 -3
- data/lib/active_support/log_subscriber/test_helper.rb +24 -21
- data/lib/active_support/log_subscriber.rb +36 -49
- data/lib/active_support/logger.rb +106 -0
- data/lib/active_support/logger_silence.rb +28 -0
- data/lib/active_support/logger_thread_safe_level.rb +31 -0
- data/lib/active_support/message_encryptor.rb +72 -36
- data/lib/active_support/message_verifier.rb +96 -24
- data/lib/active_support/multibyte/chars.rb +88 -333
- data/lib/active_support/multibyte/unicode.rb +156 -136
- data/lib/active_support/multibyte.rb +5 -28
- data/lib/active_support/notifications/fanout.rb +115 -19
- data/lib/active_support/notifications/instrumenter.rb +52 -15
- data/lib/active_support/notifications.rb +168 -33
- data/lib/active_support/number_helper/number_converter.rb +182 -0
- data/lib/active_support/number_helper/number_to_currency_converter.rb +44 -0
- data/lib/active_support/number_helper/number_to_delimited_converter.rb +28 -0
- data/lib/active_support/number_helper/number_to_human_converter.rb +68 -0
- data/lib/active_support/number_helper/number_to_human_size_converter.rb +62 -0
- data/lib/active_support/number_helper/number_to_percentage_converter.rb +12 -0
- data/lib/active_support/number_helper/number_to_phone_converter.rb +58 -0
- data/lib/active_support/number_helper/number_to_rounded_converter.rb +92 -0
- data/lib/active_support/number_helper.rb +368 -0
- data/lib/active_support/option_merger.rb +1 -1
- data/lib/active_support/ordered_hash.rb +18 -183
- data/lib/active_support/ordered_options.rb +44 -24
- data/lib/active_support/per_thread_registry.rb +58 -0
- data/lib/active_support/proxy_object.rb +13 -0
- data/lib/active_support/rails.rb +27 -0
- data/lib/active_support/railtie.rb +25 -34
- data/lib/active_support/reloader.rb +129 -0
- data/lib/active_support/rescuable.rb +98 -48
- data/lib/active_support/security_utils.rb +27 -0
- data/lib/active_support/string_inquirer.rb +14 -9
- data/lib/active_support/subscriber.rb +120 -0
- data/lib/active_support/tagged_logging.rb +78 -0
- data/lib/active_support/test_case.rb +69 -17
- data/lib/active_support/testing/assertions.rb +43 -41
- data/lib/active_support/testing/autorun.rb +12 -0
- data/lib/active_support/testing/constant_lookup.rb +50 -0
- data/lib/active_support/testing/declarative.rb +7 -21
- data/lib/active_support/testing/deprecation.rb +14 -33
- data/lib/active_support/testing/file_fixtures.rb +34 -0
- data/lib/active_support/testing/isolation.rb +53 -95
- data/lib/active_support/testing/method_call_assertions.rb +41 -0
- data/lib/active_support/testing/setup_and_teardown.rb +21 -82
- data/lib/active_support/testing/stream.rb +42 -0
- data/lib/active_support/testing/tagged_logging.rb +25 -0
- data/lib/active_support/testing/time_helpers.rb +134 -0
- data/lib/active_support/time.rb +6 -23
- data/lib/active_support/time_with_zone.rb +239 -92
- data/lib/active_support/values/time_zone.rb +236 -160
- data/lib/active_support/values/unicode_tables.dat +0 -0
- data/lib/active_support/version.rb +5 -7
- data/lib/active_support/xml_mini/jdom.rb +19 -13
- data/lib/active_support/xml_mini/libxml.rb +3 -4
- data/lib/active_support/xml_mini/libxmlsax.rb +2 -3
- data/lib/active_support/xml_mini/nokogiri.rb +3 -4
- data/lib/active_support/xml_mini/nokogirisax.rb +2 -3
- data/lib/active_support/xml_mini/rexml.rb +8 -10
- data/lib/active_support/xml_mini.rb +66 -34
- data/lib/active_support.rb +40 -23
- metadata +185 -134
- data/CHANGELOG +0 -1534
- data/lib/active_support/base64.rb +0 -42
- data/lib/active_support/basic_object.rb +0 -21
- data/lib/active_support/buffered_logger.rb +0 -137
- data/lib/active_support/cache/compressed_mem_cache_store.rb +0 -13
- data/lib/active_support/cache/synchronized_memory_store.rb +0 -11
- data/lib/active_support/core_ext/array/random_access.rb +0 -30
- data/lib/active_support/core_ext/array/uniq_by.rb +0 -16
- data/lib/active_support/core_ext/class/delegating_attributes.rb +0 -44
- data/lib/active_support/core_ext/class/inheritable_attributes.rb +0 -178
- data/lib/active_support/core_ext/date/freeze.rb +0 -31
- data/lib/active_support/core_ext/date_time/zones.rb +0 -21
- data/lib/active_support/core_ext/exception.rb +0 -3
- data/lib/active_support/core_ext/file/path.rb +0 -5
- data/lib/active_support/core_ext/float/rounding.rb +0 -19
- data/lib/active_support/core_ext/float.rb +0 -1
- data/lib/active_support/core_ext/hash/deep_dup.rb +0 -11
- data/lib/active_support/core_ext/hash/diff.rb +0 -13
- data/lib/active_support/core_ext/kernel/requires.rb +0 -28
- data/lib/active_support/core_ext/logger.rb +0 -81
- data/lib/active_support/core_ext/module/attr_accessor_with_default.rb +0 -31
- data/lib/active_support/core_ext/module/method_names.rb +0 -14
- data/lib/active_support/core_ext/module/synchronization.rb +0 -43
- data/lib/active_support/core_ext/object/to_json.rb +0 -19
- data/lib/active_support/core_ext/proc.rb +0 -14
- data/lib/active_support/core_ext/process/daemon.rb +0 -23
- data/lib/active_support/core_ext/process.rb +0 -1
- data/lib/active_support/core_ext/range/blockless_step.rb +0 -29
- data/lib/active_support/core_ext/range/cover.rb +0 -3
- data/lib/active_support/core_ext/rexml.rb +0 -46
- data/lib/active_support/core_ext/string/encoding.rb +0 -11
- data/lib/active_support/core_ext/string/interpolation.rb +0 -2
- data/lib/active_support/core_ext/string/xchar.rb +0 -18
- data/lib/active_support/core_ext/time/publicize_conversion_methods.rb +0 -10
- data/lib/active_support/file_watcher.rb +0 -36
- data/lib/active_support/json/variable.rb +0 -9
- data/lib/active_support/memoizable.rb +0 -105
- data/lib/active_support/multibyte/exceptions.rb +0 -8
- data/lib/active_support/multibyte/utils.rb +0 -60
- data/lib/active_support/ruby/shim.rb +0 -22
- data/lib/active_support/secure_random.rb +0 -6
- data/lib/active_support/testing/mochaing.rb +0 -7
- data/lib/active_support/testing/pending.rb +0 -52
- data/lib/active_support/testing/performance/jruby.rb +0 -115
- data/lib/active_support/testing/performance/rubinius.rb +0 -113
- data/lib/active_support/testing/performance/ruby/mri.rb +0 -57
- data/lib/active_support/testing/performance/ruby/yarv.rb +0 -57
- data/lib/active_support/testing/performance/ruby.rb +0 -152
- data/lib/active_support/testing/performance.rb +0 -317
- data/lib/active_support/time/autoload.rb +0 -5
- data/lib/active_support/whiny_nil.rb +0 -60
@@ -1,52 +0,0 @@
|
|
1
|
-
# Some code from jeremymcanally's "pending"
|
2
|
-
# https://github.com/jeremymcanally/pending/tree/master
|
3
|
-
|
4
|
-
module ActiveSupport
|
5
|
-
module Testing
|
6
|
-
module Pending
|
7
|
-
|
8
|
-
unless defined?(Spec)
|
9
|
-
|
10
|
-
@@pending_cases = []
|
11
|
-
@@at_exit = false
|
12
|
-
|
13
|
-
def pending(description = "", &block)
|
14
|
-
if defined?(::MiniTest)
|
15
|
-
skip(description.blank? ? nil : description)
|
16
|
-
else
|
17
|
-
if description.is_a?(Symbol)
|
18
|
-
is_pending = $tags[description]
|
19
|
-
return block.call unless is_pending
|
20
|
-
end
|
21
|
-
|
22
|
-
if block_given?
|
23
|
-
failed = false
|
24
|
-
|
25
|
-
begin
|
26
|
-
block.call
|
27
|
-
rescue Exception
|
28
|
-
failed = true
|
29
|
-
end
|
30
|
-
|
31
|
-
flunk("<#{description}> did not fail.") unless failed
|
32
|
-
end
|
33
|
-
|
34
|
-
caller[0] =~ (/(.*):(.*):in `(.*)'/)
|
35
|
-
@@pending_cases << "#{$3} at #{$1}, line #{$2}"
|
36
|
-
print "P"
|
37
|
-
|
38
|
-
@@at_exit ||= begin
|
39
|
-
at_exit do
|
40
|
-
puts "\nPending Cases:"
|
41
|
-
@@pending_cases.each do |test_case|
|
42
|
-
puts test_case
|
43
|
-
end
|
44
|
-
end
|
45
|
-
end
|
46
|
-
end
|
47
|
-
end
|
48
|
-
end
|
49
|
-
|
50
|
-
end
|
51
|
-
end
|
52
|
-
end
|
@@ -1,115 +0,0 @@
|
|
1
|
-
require 'jruby/profiler'
|
2
|
-
require 'java'
|
3
|
-
java_import java.lang.management.ManagementFactory
|
4
|
-
|
5
|
-
module ActiveSupport
|
6
|
-
module Testing
|
7
|
-
module Performance
|
8
|
-
DEFAULTS.merge!(
|
9
|
-
if ARGV.include?('--benchmark')
|
10
|
-
{:metrics => [:wall_time, :user_time, :memory, :gc_runs, :gc_time]}
|
11
|
-
else
|
12
|
-
{ :metrics => [:wall_time],
|
13
|
-
:formats => [:flat, :graph] }
|
14
|
-
end).freeze
|
15
|
-
|
16
|
-
protected
|
17
|
-
def run_gc
|
18
|
-
ManagementFactory.memory_mx_bean.gc
|
19
|
-
end
|
20
|
-
|
21
|
-
class Profiler < Performer
|
22
|
-
def initialize(*args)
|
23
|
-
super
|
24
|
-
@supported = @metric.is_a?(Metrics::WallTime)
|
25
|
-
end
|
26
|
-
|
27
|
-
def run
|
28
|
-
return unless @supported
|
29
|
-
|
30
|
-
@total = time_with_block do
|
31
|
-
@data = JRuby::Profiler.profile do
|
32
|
-
full_profile_options[:runs].to_i.times { run_test(@metric, :profile) }
|
33
|
-
end
|
34
|
-
end
|
35
|
-
end
|
36
|
-
|
37
|
-
def record
|
38
|
-
return unless @supported
|
39
|
-
|
40
|
-
klasses = full_profile_options[:formats].map { |f| JRuby::Profiler.const_get("#{f.to_s.camelize}ProfilePrinter") }.compact
|
41
|
-
|
42
|
-
klasses.each do |klass|
|
43
|
-
fname = output_filename(klass)
|
44
|
-
FileUtils.mkdir_p(File.dirname(fname))
|
45
|
-
file = File.open(fname, 'wb') do |file|
|
46
|
-
klass.new(@data).printProfile(file)
|
47
|
-
end
|
48
|
-
end
|
49
|
-
end
|
50
|
-
|
51
|
-
protected
|
52
|
-
def output_filename(printer_class)
|
53
|
-
suffix =
|
54
|
-
case printer_class.name.demodulize
|
55
|
-
when 'FlatProfilePrinter'; 'flat.txt'
|
56
|
-
when 'GraphProfilePrinter'; 'graph.txt'
|
57
|
-
else printer_class.name.sub(/ProfilePrinter$/, '').underscore
|
58
|
-
end
|
59
|
-
|
60
|
-
"#{super()}_#{suffix}"
|
61
|
-
end
|
62
|
-
end
|
63
|
-
|
64
|
-
module Metrics
|
65
|
-
class Base
|
66
|
-
def profile
|
67
|
-
yield
|
68
|
-
end
|
69
|
-
|
70
|
-
protected
|
71
|
-
def with_gc_stats
|
72
|
-
ManagementFactory.memory_mx_bean.gc
|
73
|
-
yield
|
74
|
-
end
|
75
|
-
end
|
76
|
-
|
77
|
-
class WallTime < Time
|
78
|
-
def measure
|
79
|
-
super
|
80
|
-
end
|
81
|
-
end
|
82
|
-
|
83
|
-
class CpuTime < Time
|
84
|
-
def measure
|
85
|
-
ManagementFactory.thread_mx_bean.get_current_thread_cpu_time / 1000 / 1000 / 1000.0 # seconds
|
86
|
-
end
|
87
|
-
end
|
88
|
-
|
89
|
-
class UserTime < Time
|
90
|
-
def measure
|
91
|
-
ManagementFactory.thread_mx_bean.get_current_thread_user_time / 1000 / 1000 / 1000.0 # seconds
|
92
|
-
end
|
93
|
-
end
|
94
|
-
|
95
|
-
class Memory < DigitalInformationUnit
|
96
|
-
def measure
|
97
|
-
ManagementFactory.memory_mx_bean.non_heap_memory_usage.used + ManagementFactory.memory_mx_bean.heap_memory_usage.used
|
98
|
-
end
|
99
|
-
end
|
100
|
-
|
101
|
-
class GcRuns < Amount
|
102
|
-
def measure
|
103
|
-
ManagementFactory.garbage_collector_mx_beans.inject(0) { |total_runs, current_gc| total_runs += current_gc.collection_count }
|
104
|
-
end
|
105
|
-
end
|
106
|
-
|
107
|
-
class GcTime < Time
|
108
|
-
def measure
|
109
|
-
ManagementFactory.garbage_collector_mx_beans.inject(0) { |total_time, current_gc| total_time += current_gc.collection_time } / 1000.0 # seconds
|
110
|
-
end
|
111
|
-
end
|
112
|
-
end
|
113
|
-
end
|
114
|
-
end
|
115
|
-
end
|
@@ -1,113 +0,0 @@
|
|
1
|
-
require 'rubinius/agent'
|
2
|
-
|
3
|
-
module ActiveSupport
|
4
|
-
module Testing
|
5
|
-
module Performance
|
6
|
-
DEFAULTS.merge!(
|
7
|
-
if ARGV.include?('--benchmark')
|
8
|
-
{:metrics => [:wall_time, :memory, :objects, :gc_runs, :gc_time]}
|
9
|
-
else
|
10
|
-
{ :metrics => [:wall_time],
|
11
|
-
:formats => [:flat, :graph] }
|
12
|
-
end).freeze
|
13
|
-
|
14
|
-
protected
|
15
|
-
def run_gc
|
16
|
-
GC.run(true)
|
17
|
-
end
|
18
|
-
|
19
|
-
class Performer; end
|
20
|
-
|
21
|
-
class Profiler < Performer
|
22
|
-
def initialize(*args)
|
23
|
-
super
|
24
|
-
@supported = @metric.is_a?(Metrics::WallTime)
|
25
|
-
end
|
26
|
-
|
27
|
-
def run
|
28
|
-
return unless @supported
|
29
|
-
|
30
|
-
@profiler = Rubinius::Profiler::Instrumenter.new
|
31
|
-
|
32
|
-
@total = time_with_block do
|
33
|
-
@profiler.profile(false) do
|
34
|
-
full_profile_options[:runs].to_i.times { run_test(@metric, :profile) }
|
35
|
-
end
|
36
|
-
end
|
37
|
-
end
|
38
|
-
|
39
|
-
def record
|
40
|
-
return unless @supported
|
41
|
-
|
42
|
-
if(full_profile_options[:formats].include?(:flat))
|
43
|
-
create_path_and_open_file(:flat) do |file|
|
44
|
-
@profiler.show(file)
|
45
|
-
end
|
46
|
-
end
|
47
|
-
|
48
|
-
if(full_profile_options[:formats].include?(:graph))
|
49
|
-
create_path_and_open_file(:graph) do |file|
|
50
|
-
@profiler.show(file)
|
51
|
-
end
|
52
|
-
end
|
53
|
-
end
|
54
|
-
|
55
|
-
protected
|
56
|
-
def create_path_and_open_file(printer_name)
|
57
|
-
fname = "#{output_filename}_#{printer_name}.txt"
|
58
|
-
FileUtils.mkdir_p(File.dirname(fname))
|
59
|
-
File.open(fname, 'wb') do |file|
|
60
|
-
yield(file)
|
61
|
-
end
|
62
|
-
end
|
63
|
-
end
|
64
|
-
|
65
|
-
module Metrics
|
66
|
-
class Base
|
67
|
-
attr_reader :loopback
|
68
|
-
|
69
|
-
def profile
|
70
|
-
yield
|
71
|
-
end
|
72
|
-
|
73
|
-
protected
|
74
|
-
def with_gc_stats
|
75
|
-
@loopback = Rubinius::Agent.loopback
|
76
|
-
GC.run(true)
|
77
|
-
yield
|
78
|
-
end
|
79
|
-
end
|
80
|
-
|
81
|
-
class WallTime < Time
|
82
|
-
def measure
|
83
|
-
super
|
84
|
-
end
|
85
|
-
end
|
86
|
-
|
87
|
-
class Memory < DigitalInformationUnit
|
88
|
-
def measure
|
89
|
-
loopback.get("system.memory.counter.bytes").last
|
90
|
-
end
|
91
|
-
end
|
92
|
-
|
93
|
-
class Objects < Amount
|
94
|
-
def measure
|
95
|
-
loopback.get("system.memory.counter.objects").last
|
96
|
-
end
|
97
|
-
end
|
98
|
-
|
99
|
-
class GcRuns < Amount
|
100
|
-
def measure
|
101
|
-
loopback.get("system.gc.full.count").last + loopback.get("system.gc.young.count").last
|
102
|
-
end
|
103
|
-
end
|
104
|
-
|
105
|
-
class GcTime < Time
|
106
|
-
def measure
|
107
|
-
(loopback.get("system.gc.full.wallclock").last + loopback.get("system.gc.young.wallclock").last) / 1000.0
|
108
|
-
end
|
109
|
-
end
|
110
|
-
end
|
111
|
-
end
|
112
|
-
end
|
113
|
-
end
|
@@ -1,57 +0,0 @@
|
|
1
|
-
module ActiveSupport
|
2
|
-
module Testing
|
3
|
-
module Performance
|
4
|
-
module Metrics
|
5
|
-
class Base
|
6
|
-
protected
|
7
|
-
# Ruby 1.8 + ruby-prof wrapper (enable/disable stats for Benchmarker)
|
8
|
-
if GC.respond_to?(:enable_stats)
|
9
|
-
def with_gc_stats
|
10
|
-
GC.enable_stats
|
11
|
-
GC.start
|
12
|
-
yield
|
13
|
-
ensure
|
14
|
-
GC.disable_stats
|
15
|
-
end
|
16
|
-
end
|
17
|
-
end
|
18
|
-
|
19
|
-
class Memory < DigitalInformationUnit
|
20
|
-
# Ruby 1.8 + ruby-prof wrapper
|
21
|
-
if RubyProf.respond_to?(:measure_memory)
|
22
|
-
def measure
|
23
|
-
RubyProf.measure_memory
|
24
|
-
end
|
25
|
-
end
|
26
|
-
end
|
27
|
-
|
28
|
-
class Objects < Amount
|
29
|
-
# Ruby 1.8 + ruby-prof wrapper
|
30
|
-
if RubyProf.respond_to?(:measure_allocations)
|
31
|
-
def measure
|
32
|
-
RubyProf.measure_allocations
|
33
|
-
end
|
34
|
-
end
|
35
|
-
end
|
36
|
-
|
37
|
-
class GcRuns < Amount
|
38
|
-
# Ruby 1.8 + ruby-prof wrapper
|
39
|
-
if RubyProf.respond_to?(:measure_gc_runs)
|
40
|
-
def measure
|
41
|
-
RubyProf.measure_gc_runs
|
42
|
-
end
|
43
|
-
end
|
44
|
-
end
|
45
|
-
|
46
|
-
class GcTime < Time
|
47
|
-
# Ruby 1.8 + ruby-prof wrapper
|
48
|
-
if RubyProf.respond_to?(:measure_gc_time)
|
49
|
-
def measure
|
50
|
-
RubyProf.measure_gc_time / 1000.0 / 1000.0
|
51
|
-
end
|
52
|
-
end
|
53
|
-
end
|
54
|
-
end
|
55
|
-
end
|
56
|
-
end
|
57
|
-
end
|
@@ -1,57 +0,0 @@
|
|
1
|
-
module ActiveSupport
|
2
|
-
module Testing
|
3
|
-
module Performance
|
4
|
-
module Metrics
|
5
|
-
class Base
|
6
|
-
protected
|
7
|
-
# Ruby 1.9 with GC::Profiler
|
8
|
-
if defined?(GC::Profiler)
|
9
|
-
def with_gc_stats
|
10
|
-
GC::Profiler.enable
|
11
|
-
GC.start
|
12
|
-
yield
|
13
|
-
ensure
|
14
|
-
GC::Profiler.disable
|
15
|
-
end
|
16
|
-
end
|
17
|
-
end
|
18
|
-
|
19
|
-
class Memory < DigitalInformationUnit
|
20
|
-
# Ruby 1.9 + GCdata patch
|
21
|
-
if GC.respond_to?(:malloc_allocated_size)
|
22
|
-
def measure
|
23
|
-
GC.malloc_allocated_size
|
24
|
-
end
|
25
|
-
end
|
26
|
-
end
|
27
|
-
|
28
|
-
class Objects < Amount
|
29
|
-
# Ruby 1.9 + GCdata patch
|
30
|
-
if GC.respond_to?(:malloc_allocations)
|
31
|
-
def measure
|
32
|
-
GC.malloc_allocations
|
33
|
-
end
|
34
|
-
end
|
35
|
-
end
|
36
|
-
|
37
|
-
class GcRuns < Amount
|
38
|
-
# Ruby 1.9
|
39
|
-
if GC.respond_to?(:count)
|
40
|
-
def measure
|
41
|
-
GC.count
|
42
|
-
end
|
43
|
-
end
|
44
|
-
end
|
45
|
-
|
46
|
-
class GcTime < Time
|
47
|
-
# Ruby 1.9 with GC::Profiler
|
48
|
-
if defined?(GC::Profiler) && GC::Profiler.respond_to?(:total_time)
|
49
|
-
def measure
|
50
|
-
GC::Profiler.total_time
|
51
|
-
end
|
52
|
-
end
|
53
|
-
end
|
54
|
-
end
|
55
|
-
end
|
56
|
-
end
|
57
|
-
end
|
@@ -1,152 +0,0 @@
|
|
1
|
-
begin
|
2
|
-
require 'ruby-prof'
|
3
|
-
rescue LoadError
|
4
|
-
$stderr.puts 'Specify ruby-prof as application\'s dependency in Gemfile to run benchmarks.'
|
5
|
-
exit
|
6
|
-
end
|
7
|
-
|
8
|
-
module ActiveSupport
|
9
|
-
module Testing
|
10
|
-
module Performance
|
11
|
-
DEFAULTS.merge!(
|
12
|
-
if ARGV.include?('--benchmark')
|
13
|
-
{ :metrics => [:wall_time, :memory, :objects, :gc_runs, :gc_time] }
|
14
|
-
else
|
15
|
-
{ :min_percent => 0.01,
|
16
|
-
:metrics => [:process_time, :memory, :objects],
|
17
|
-
:formats => [:flat, :graph_html, :call_tree, :call_stack] }
|
18
|
-
end).freeze
|
19
|
-
|
20
|
-
protected
|
21
|
-
def run_gc
|
22
|
-
GC.start
|
23
|
-
end
|
24
|
-
|
25
|
-
class Profiler < Performer
|
26
|
-
def initialize(*args)
|
27
|
-
super
|
28
|
-
@supported = @metric.measure_mode rescue false
|
29
|
-
end
|
30
|
-
|
31
|
-
def run
|
32
|
-
return unless @supported
|
33
|
-
|
34
|
-
RubyProf.measure_mode = @metric.measure_mode
|
35
|
-
RubyProf.start
|
36
|
-
RubyProf.pause
|
37
|
-
full_profile_options[:runs].to_i.times { run_test(@metric, :profile) }
|
38
|
-
@data = RubyProf.stop
|
39
|
-
@total = @data.threads.values.sum(0) { |method_infos| method_infos.max.total_time }
|
40
|
-
end
|
41
|
-
|
42
|
-
def record
|
43
|
-
return unless @supported
|
44
|
-
|
45
|
-
klasses = full_profile_options[:formats].map { |f| RubyProf.const_get("#{f.to_s.camelize}Printer") }.compact
|
46
|
-
|
47
|
-
klasses.each do |klass|
|
48
|
-
fname = output_filename(klass)
|
49
|
-
FileUtils.mkdir_p(File.dirname(fname))
|
50
|
-
File.open(fname, 'wb') do |file|
|
51
|
-
klass.new(@data).print(file, full_profile_options.slice(:min_percent))
|
52
|
-
end
|
53
|
-
end
|
54
|
-
end
|
55
|
-
|
56
|
-
protected
|
57
|
-
def output_filename(printer_class)
|
58
|
-
suffix =
|
59
|
-
case printer_class.name.demodulize
|
60
|
-
when 'FlatPrinter'; 'flat.txt'
|
61
|
-
when 'FlatPrinterWithLineNumbers'; 'flat_line_numbers.txt'
|
62
|
-
when 'GraphPrinter'; 'graph.txt'
|
63
|
-
when 'GraphHtmlPrinter'; 'graph.html'
|
64
|
-
when 'GraphYamlPrinter'; 'graph.yml'
|
65
|
-
when 'CallTreePrinter'; 'tree.txt'
|
66
|
-
when 'CallStackPrinter'; 'stack.html'
|
67
|
-
when 'DotPrinter'; 'graph.dot'
|
68
|
-
else printer_class.name.sub(/Printer$/, '').underscore
|
69
|
-
end
|
70
|
-
|
71
|
-
"#{super()}_#{suffix}"
|
72
|
-
end
|
73
|
-
end
|
74
|
-
|
75
|
-
module Metrics
|
76
|
-
class Base
|
77
|
-
def measure_mode
|
78
|
-
self.class::Mode
|
79
|
-
end
|
80
|
-
|
81
|
-
def profile
|
82
|
-
RubyProf.resume
|
83
|
-
yield
|
84
|
-
ensure
|
85
|
-
RubyProf.pause
|
86
|
-
end
|
87
|
-
|
88
|
-
protected
|
89
|
-
# overridden by each implementation
|
90
|
-
def with_gc_stats
|
91
|
-
yield
|
92
|
-
end
|
93
|
-
end
|
94
|
-
|
95
|
-
class ProcessTime < Time
|
96
|
-
Mode = RubyProf::PROCESS_TIME if RubyProf.const_defined?(:PROCESS_TIME)
|
97
|
-
|
98
|
-
def measure
|
99
|
-
RubyProf.measure_process_time
|
100
|
-
end
|
101
|
-
end
|
102
|
-
|
103
|
-
class WallTime < Time
|
104
|
-
Mode = RubyProf::WALL_TIME if RubyProf.const_defined?(:WALL_TIME)
|
105
|
-
|
106
|
-
def measure
|
107
|
-
RubyProf.measure_wall_time
|
108
|
-
end
|
109
|
-
end
|
110
|
-
|
111
|
-
class CpuTime < Time
|
112
|
-
Mode = RubyProf::CPU_TIME if RubyProf.const_defined?(:CPU_TIME)
|
113
|
-
|
114
|
-
def initialize(*args)
|
115
|
-
# FIXME: yeah my CPU is 2.33 GHz
|
116
|
-
RubyProf.cpu_frequency = 2.33e9 unless RubyProf.cpu_frequency > 0
|
117
|
-
super
|
118
|
-
end
|
119
|
-
|
120
|
-
def measure
|
121
|
-
RubyProf.measure_cpu_time
|
122
|
-
end
|
123
|
-
end
|
124
|
-
|
125
|
-
class Memory < DigitalInformationUnit
|
126
|
-
Mode = RubyProf::MEMORY if RubyProf.const_defined?(:MEMORY)
|
127
|
-
end
|
128
|
-
|
129
|
-
class Objects < Amount
|
130
|
-
Mode = RubyProf::ALLOCATIONS if RubyProf.const_defined?(:ALLOCATIONS)
|
131
|
-
end
|
132
|
-
|
133
|
-
class GcRuns < Amount
|
134
|
-
Mode = RubyProf::GC_RUNS if RubyProf.const_defined?(:GC_RUNS)
|
135
|
-
end
|
136
|
-
|
137
|
-
class GcTime < Time
|
138
|
-
Mode = RubyProf::GC_TIME if RubyProf.const_defined?(:GC_TIME)
|
139
|
-
end
|
140
|
-
end
|
141
|
-
end
|
142
|
-
end
|
143
|
-
end
|
144
|
-
|
145
|
-
if RUBY_VERSION.between?('1.9.2', '2.0')
|
146
|
-
require 'active_support/testing/performance/ruby/yarv'
|
147
|
-
elsif RUBY_VERSION.between?('1.8.6', '1.9')
|
148
|
-
require 'active_support/testing/performance/ruby/mri'
|
149
|
-
else
|
150
|
-
$stderr.puts 'Update your ruby interpreter to be able to run benchmarks.'
|
151
|
-
exit
|
152
|
-
end
|