mmtrix_rpm 1.0.0.1
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 +7 -0
- data/.gitignore +27 -0
- data/.project +23 -0
- data/.travis.yml +12 -0
- data/.yardopts +21 -0
- data/CHANGELOG +2342 -0
- data/GUIDELINES_FOR_CONTRIBUTING.md +80 -0
- data/Gemfile +3 -0
- data/Guardfile +8 -0
- data/LICENSE +151 -0
- data/README.md +202 -0
- data/Rakefile +154 -0
- data/bin/mmtrix +13 -0
- data/bin/mmtrix_cmd +5 -0
- data/bin/mongrel_rpm +33 -0
- data/bin/nrdebug +279 -0
- data/cert/cacert.pem +1177 -0
- data/config/database.yml +5 -0
- data/config.dot +287 -0
- data/init.rb +32 -0
- data/install.rb +13 -0
- data/lib/conditional_vendored_dependency_detection.rb +7 -0
- data/lib/conditional_vendored_metric_parser.rb +9 -0
- data/lib/mmtrix/agent/agent.rb +1152 -0
- data/lib/mmtrix/agent/agent_logger.rb +184 -0
- data/lib/mmtrix/agent/attribute_filter.rb +242 -0
- data/lib/mmtrix/agent/attribute_processing.rb +62 -0
- data/lib/mmtrix/agent/audit_logger.rb +94 -0
- data/lib/mmtrix/agent/autostart.rb +65 -0
- data/lib/mmtrix/agent/aws_info.rb +90 -0
- data/lib/mmtrix/agent/busy_calculator.rb +117 -0
- data/lib/mmtrix/agent/chained_call.rb +17 -0
- data/lib/mmtrix/agent/commands/agent_command.rb +19 -0
- data/lib/mmtrix/agent/commands/agent_command_router.rb +160 -0
- data/lib/mmtrix/agent/commands/thread_profiler_session.rb +110 -0
- data/lib/mmtrix/agent/commands/xray_session.rb +55 -0
- data/lib/mmtrix/agent/commands/xray_session_collection.rb +161 -0
- data/lib/mmtrix/agent/configuration/default_source.rb +1471 -0
- data/lib/mmtrix/agent/configuration/dotted_hash.rb +50 -0
- data/lib/mmtrix/agent/configuration/environment_source.rb +116 -0
- data/lib/mmtrix/agent/configuration/high_security_source.rb +51 -0
- data/lib/mmtrix/agent/configuration/manager.rb +395 -0
- data/lib/mmtrix/agent/configuration/manual_source.rb +17 -0
- data/lib/mmtrix/agent/configuration/mask_defaults.rb +14 -0
- data/lib/mmtrix/agent/configuration/server_source.rb +117 -0
- data/lib/mmtrix/agent/configuration/yaml_source.rb +155 -0
- data/lib/mmtrix/agent/configuration.rb +35 -0
- data/lib/mmtrix/agent/cross_app_monitor.rb +178 -0
- data/lib/mmtrix/agent/cross_app_tracing.rb +339 -0
- data/lib/mmtrix/agent/custom_event_aggregator.rb +100 -0
- data/lib/mmtrix/agent/database/obfuscation_helpers.rb +78 -0
- data/lib/mmtrix/agent/database/obfuscator.rb +80 -0
- data/lib/mmtrix/agent/database/postgres_explain_obfuscator.rb +46 -0
- data/lib/mmtrix/agent/database.rb +325 -0
- data/lib/mmtrix/agent/datastores/metric_helper.rb +98 -0
- data/lib/mmtrix/agent/datastores/mongo/metric_translator.rb +191 -0
- data/lib/mmtrix/agent/datastores/mongo/obfuscator.rb +39 -0
- data/lib/mmtrix/agent/datastores/mongo/statement_formatter.rb +53 -0
- data/lib/mmtrix/agent/datastores/mongo.rb +29 -0
- data/lib/mmtrix/agent/datastores.rb +191 -0
- data/lib/mmtrix/agent/deprecator.rb +18 -0
- data/lib/mmtrix/agent/encoding_normalizer.rb +82 -0
- data/lib/mmtrix/agent/error_collector.rb +316 -0
- data/lib/mmtrix/agent/event_buffer.rb +84 -0
- data/lib/mmtrix/agent/event_listener.rb +47 -0
- data/lib/mmtrix/agent/event_loop.rb +193 -0
- data/lib/mmtrix/agent/harvester.rb +52 -0
- data/lib/mmtrix/agent/hash_extensions.rb +26 -0
- data/lib/mmtrix/agent/hostname.rb +30 -0
- data/lib/mmtrix/agent/http_clients/curb_wrappers.rb +67 -0
- data/lib/mmtrix/agent/http_clients/excon_wrappers.rb +67 -0
- data/lib/mmtrix/agent/http_clients/httpclient_wrappers.rb +63 -0
- data/lib/mmtrix/agent/http_clients/net_http_wrappers.rb +50 -0
- data/lib/mmtrix/agent/http_clients/typhoeus_wrappers.rb +75 -0
- data/lib/mmtrix/agent/http_clients/uri_util.rb +51 -0
- data/lib/mmtrix/agent/inbound_request_monitor.rb +41 -0
- data/lib/mmtrix/agent/instrumentation/action_controller_subscriber.rb +121 -0
- data/lib/mmtrix/agent/instrumentation/action_view_subscriber.rb +95 -0
- data/lib/mmtrix/agent/instrumentation/active_job.rb +90 -0
- data/lib/mmtrix/agent/instrumentation/active_merchant.rb +37 -0
- data/lib/mmtrix/agent/instrumentation/active_record.rb +105 -0
- data/lib/mmtrix/agent/instrumentation/active_record_4.rb +29 -0
- data/lib/mmtrix/agent/instrumentation/active_record_helper.rb +189 -0
- data/lib/mmtrix/agent/instrumentation/active_record_subscriber.rb +104 -0
- data/lib/mmtrix/agent/instrumentation/acts_as_solr.rb +72 -0
- data/lib/mmtrix/agent/instrumentation/authlogic.rb +25 -0
- data/lib/mmtrix/agent/instrumentation/controller_instrumentation.rb +458 -0
- data/lib/mmtrix/agent/instrumentation/curb.rb +191 -0
- data/lib/mmtrix/agent/instrumentation/data_mapper.rb +167 -0
- data/lib/mmtrix/agent/instrumentation/delayed_job_instrumentation.rb +56 -0
- data/lib/mmtrix/agent/instrumentation/evented_subscriber.rb +100 -0
- data/lib/mmtrix/agent/instrumentation/excon/connection.rb +33 -0
- data/lib/mmtrix/agent/instrumentation/excon/middleware.rb +57 -0
- data/lib/mmtrix/agent/instrumentation/excon.rb +72 -0
- data/lib/mmtrix/agent/instrumentation/grape.rb +111 -0
- data/lib/mmtrix/agent/instrumentation/httpclient.rb +46 -0
- data/lib/mmtrix/agent/instrumentation/ignore_actions.rb +41 -0
- data/lib/mmtrix/agent/instrumentation/memcache.rb +143 -0
- data/lib/mmtrix/agent/instrumentation/merb/controller.rb +44 -0
- data/lib/mmtrix/agent/instrumentation/merb/errors.rb +33 -0
- data/lib/mmtrix/agent/instrumentation/metric_frame.rb +39 -0
- data/lib/mmtrix/agent/instrumentation/middleware_proxy.rb +109 -0
- data/lib/mmtrix/agent/instrumentation/middleware_tracing.rb +87 -0
- data/lib/mmtrix/agent/instrumentation/mongo.rb +128 -0
- data/lib/mmtrix/agent/instrumentation/net.rb +36 -0
- data/lib/mmtrix/agent/instrumentation/padrino.rb +32 -0
- data/lib/mmtrix/agent/instrumentation/passenger_instrumentation.rb +27 -0
- data/lib/mmtrix/agent/instrumentation/queue_time.rb +78 -0
- data/lib/mmtrix/agent/instrumentation/rack.rb +186 -0
- data/lib/mmtrix/agent/instrumentation/rails/action_controller.rb +123 -0
- data/lib/mmtrix/agent/instrumentation/rails/action_web_service.rb +46 -0
- data/lib/mmtrix/agent/instrumentation/rails/errors.rb +51 -0
- data/lib/mmtrix/agent/instrumentation/rails3/action_controller.rb +173 -0
- data/lib/mmtrix/agent/instrumentation/rails3/errors.rb +47 -0
- data/lib/mmtrix/agent/instrumentation/rails4/action_controller.rb +29 -0
- data/lib/mmtrix/agent/instrumentation/rails4/action_view.rb +25 -0
- data/lib/mmtrix/agent/instrumentation/rails4/errors.rb +46 -0
- data/lib/mmtrix/agent/instrumentation/rails_middleware.rb +39 -0
- data/lib/mmtrix/agent/instrumentation/rainbows_instrumentation.rb +26 -0
- data/lib/mmtrix/agent/instrumentation/resque.rb +96 -0
- data/lib/mmtrix/agent/instrumentation/rubyprof.rb +26 -0
- data/lib/mmtrix/agent/instrumentation/sequel.rb +51 -0
- data/lib/mmtrix/agent/instrumentation/sequel_helper.rb +36 -0
- data/lib/mmtrix/agent/instrumentation/sidekiq.rb +72 -0
- data/lib/mmtrix/agent/instrumentation/sinatra/ignorer.rb +52 -0
- data/lib/mmtrix/agent/instrumentation/sinatra/transaction_namer.rb +56 -0
- data/lib/mmtrix/agent/instrumentation/sinatra.rb +188 -0
- data/lib/mmtrix/agent/instrumentation/sunspot.rb +33 -0
- data/lib/mmtrix/agent/instrumentation/typhoeus.rb +78 -0
- data/lib/mmtrix/agent/instrumentation.rb +13 -0
- data/lib/mmtrix/agent/internal_agent_error.rb +18 -0
- data/lib/mmtrix/agent/javascript_instrumentor.rb +196 -0
- data/lib/mmtrix/agent/log_once.rb +39 -0
- data/lib/mmtrix/agent/memory_logger.rb +59 -0
- data/lib/mmtrix/agent/method_tracer.rb +391 -0
- data/lib/mmtrix/agent/method_tracer_helpers.rb +92 -0
- data/lib/mmtrix/agent/mmtrix_service/encoders.rb +38 -0
- data/lib/mmtrix/agent/mmtrix_service/json_marshaller.rb +75 -0
- data/lib/mmtrix/agent/mmtrix_service/marshaller.rb +62 -0
- data/lib/mmtrix/agent/mmtrix_service/pruby_marshaller.rb +56 -0
- data/lib/mmtrix/agent/mmtrix_service.rb +580 -0
- data/lib/mmtrix/agent/null_logger.rb +21 -0
- data/lib/mmtrix/agent/obfuscator.rb +49 -0
- data/lib/mmtrix/agent/parameter_filtering.rb +44 -0
- data/lib/mmtrix/agent/pipe_channel_manager.rb +277 -0
- data/lib/mmtrix/agent/pipe_service.rb +84 -0
- data/lib/mmtrix/agent/rules_engine/replacement_rule.rb +76 -0
- data/lib/mmtrix/agent/rules_engine/segment_terms_rule.rb +48 -0
- data/lib/mmtrix/agent/rules_engine.rb +58 -0
- data/lib/mmtrix/agent/sampled_buffer.rb +51 -0
- data/lib/mmtrix/agent/sampler.rb +64 -0
- data/lib/mmtrix/agent/sampler_collection.rb +72 -0
- data/lib/mmtrix/agent/samplers/cpu_sampler.rb +76 -0
- data/lib/mmtrix/agent/samplers/delayed_job_sampler.rb +111 -0
- data/lib/mmtrix/agent/samplers/memory_sampler.rb +149 -0
- data/lib/mmtrix/agent/samplers/object_sampler.rb +24 -0
- data/lib/mmtrix/agent/samplers/vm_sampler.rb +126 -0
- data/lib/mmtrix/agent/sized_buffer.rb +23 -0
- data/lib/mmtrix/agent/sql_sampler.rb +322 -0
- data/lib/mmtrix/agent/stats.rb +159 -0
- data/lib/mmtrix/agent/stats_engine/gc_profiler.rb +109 -0
- data/lib/mmtrix/agent/stats_engine/metric_stats.rb +237 -0
- data/lib/mmtrix/agent/stats_engine/samplers.rb +22 -0
- data/lib/mmtrix/agent/stats_engine/stats_hash.rb +168 -0
- data/lib/mmtrix/agent/stats_engine.rb +32 -0
- data/lib/mmtrix/agent/supported_versions.rb +259 -0
- data/lib/mmtrix/agent/synthetics_event_buffer.rb +42 -0
- data/lib/mmtrix/agent/synthetics_monitor.rb +50 -0
- data/lib/mmtrix/agent/system_info.rb +251 -0
- data/lib/mmtrix/agent/threading/agent_thread.rb +76 -0
- data/lib/mmtrix/agent/threading/backtrace_node.rb +135 -0
- data/lib/mmtrix/agent/threading/backtrace_service.rb +283 -0
- data/lib/mmtrix/agent/threading/thread_profile.rb +149 -0
- data/lib/mmtrix/agent/traced_method_stack.rb +99 -0
- data/lib/mmtrix/agent/transaction/attributes.rb +163 -0
- data/lib/mmtrix/agent/transaction/developer_mode_sample_buffer.rb +62 -0
- data/lib/mmtrix/agent/transaction/slowest_sample_buffer.rb +25 -0
- data/lib/mmtrix/agent/transaction/synthetics_sample_buffer.rb +25 -0
- data/lib/mmtrix/agent/transaction/trace.rb +150 -0
- data/lib/mmtrix/agent/transaction/trace_node.rb +190 -0
- data/lib/mmtrix/agent/transaction/transaction_sample_buffer.rb +105 -0
- data/lib/mmtrix/agent/transaction/xray_sample_buffer.rb +64 -0
- data/lib/mmtrix/agent/transaction.rb +940 -0
- data/lib/mmtrix/agent/transaction_event_aggregator.rb +265 -0
- data/lib/mmtrix/agent/transaction_metrics.rb +57 -0
- data/lib/mmtrix/agent/transaction_sample_builder.rb +141 -0
- data/lib/mmtrix/agent/transaction_sampler.rb +317 -0
- data/lib/mmtrix/agent/transaction_state.rb +153 -0
- data/lib/mmtrix/agent/transaction_timings.rb +57 -0
- data/lib/mmtrix/agent/utilization_data.rb +64 -0
- data/lib/mmtrix/agent/vm/jruby_vm.rb +40 -0
- data/lib/mmtrix/agent/vm/monotonic_gc_profiler.rb +45 -0
- data/lib/mmtrix/agent/vm/mri_vm.rb +87 -0
- data/lib/mmtrix/agent/vm/rubinius_vm.rb +132 -0
- data/lib/mmtrix/agent/vm/snapshot.rb +20 -0
- data/lib/mmtrix/agent/vm.rb +32 -0
- data/lib/mmtrix/agent/worker_loop.rb +98 -0
- data/lib/mmtrix/agent.rb +714 -0
- data/lib/mmtrix/build.rb +2 -0
- data/lib/mmtrix/cli/command.rb +91 -0
- data/lib/mmtrix/cli/commands/deployments.rb +134 -0
- data/lib/mmtrix/cli/commands/install.rb +84 -0
- data/lib/mmtrix/coerce.rb +70 -0
- data/lib/mmtrix/collection_helper.rb +79 -0
- data/lib/mmtrix/control/class_methods.rb +62 -0
- data/lib/mmtrix/control/frameworks/external.rb +20 -0
- data/lib/mmtrix/control/frameworks/merb.rb +29 -0
- data/lib/mmtrix/control/frameworks/rails.rb +139 -0
- data/lib/mmtrix/control/frameworks/rails3.rb +45 -0
- data/lib/mmtrix/control/frameworks/rails4.rb +23 -0
- data/lib/mmtrix/control/frameworks/ruby.rb +24 -0
- data/lib/mmtrix/control/frameworks/sinatra.rb +14 -0
- data/lib/mmtrix/control/frameworks.rb +14 -0
- data/lib/mmtrix/control/instance_methods.rb +161 -0
- data/lib/mmtrix/control/instrumentation.rb +71 -0
- data/lib/mmtrix/control/server_methods.rb +32 -0
- data/lib/mmtrix/control.rb +43 -0
- data/lib/mmtrix/delayed_job_injection.rb +10 -0
- data/lib/mmtrix/environment_report.rb +131 -0
- data/lib/mmtrix/helper.rb +55 -0
- data/lib/mmtrix/json_wrapper.rb +78 -0
- data/lib/mmtrix/language_support.rb +144 -0
- data/lib/mmtrix/latest_changes.rb +64 -0
- data/lib/mmtrix/local_environment.rb +207 -0
- data/lib/mmtrix/merbtasks.rb +10 -0
- data/lib/mmtrix/metric_data.rb +74 -0
- data/lib/mmtrix/metric_spec.rb +81 -0
- data/lib/mmtrix/metrics.rb +13 -0
- data/lib/mmtrix/noticed_error.rb +164 -0
- data/lib/mmtrix/okjson.rb +602 -0
- data/lib/mmtrix/rack/agent_hooks.rb +33 -0
- data/lib/mmtrix/rack/agent_middleware.rb +40 -0
- data/lib/mmtrix/rack/browser_monitoring.rb +150 -0
- data/lib/mmtrix/rack/developer_mode/segment_summary.rb +56 -0
- data/lib/mmtrix/rack/developer_mode.rb +321 -0
- data/lib/mmtrix/rack/error_collector.rb +27 -0
- data/lib/mmtrix/rack.rb +17 -0
- data/lib/mmtrix/recipes/capistrano3.rb +66 -0
- data/lib/mmtrix/recipes/capistrano_legacy.rb +98 -0
- data/lib/mmtrix/recipes.rb +24 -0
- data/lib/mmtrix/timer_lib.rb +31 -0
- data/lib/mmtrix/version.rb +70 -0
- data/lib/mmtrix_rpm.rb +54 -0
- data/lib/sequel/extensions/mmtrix_instrumentation.rb +79 -0
- data/lib/sequel/plugins/mmtrix_instrumentation.rb +65 -0
- data/lib/tasks/all.rb +8 -0
- data/lib/tasks/config.html.erb +28 -0
- data/lib/tasks/config.rake +134 -0
- data/lib/tasks/config.text.erb +7 -0
- data/lib/tasks/install.rake +11 -0
- data/lib/tasks/multiverse.rake +2 -0
- data/lib/tasks/multiverse.rb +50 -0
- data/lib/tasks/tests.rake +36 -0
- data/lib/tasks/versions.html.erb +27 -0
- data/lib/tasks/versions.rake +53 -0
- data/lib/tasks/versions.txt.erb +14 -0
- data/mmtrix.yml +47 -0
- data/mmtrix_rpm.gemspec +73 -0
- data/recipes/mmtrix.rb +10 -0
- data/test/agent_helper.rb +666 -0
- data/test/config/mmtrix.yml +46 -0
- data/test/config/test.cert.crt +18 -0
- data/test/config/test.cert.key +15 -0
- data/test/config/test_control.rb +54 -0
- data/test/environments/.gitignore +16 -0
- data/test/environments/lib/environments/runner.rb +113 -0
- data/test/environments/norails/Gemfile +21 -0
- data/test/environments/norails/Rakefile +9 -0
- data/test/environments/rails21/Gemfile +25 -0
- data/test/environments/rails21/Rakefile +16 -0
- data/test/environments/rails21/app/controllers/application.rb +20 -0
- data/test/environments/rails21/config/boot.rb +113 -0
- data/test/environments/rails21/config/database.yml +26 -0
- data/test/environments/rails21/config/environment.rb +26 -0
- data/test/environments/rails21/config/environments/development.rb +10 -0
- data/test/environments/rails21/config/environments/production.rb +8 -0
- data/test/environments/rails21/config/environments/test.rb +10 -0
- data/test/environments/rails21/config/routes.rb +5 -0
- data/test/environments/rails21/db/schema.rb +5 -0
- data/test/environments/rails22/Gemfile +25 -0
- data/test/environments/rails22/Rakefile +16 -0
- data/test/environments/rails22/app/controllers/application.rb +20 -0
- data/test/environments/rails22/config/boot.rb +113 -0
- data/test/environments/rails22/config/database.yml +26 -0
- data/test/environments/rails22/config/environment.rb +25 -0
- data/test/environments/rails22/config/environments/development.rb +10 -0
- data/test/environments/rails22/config/environments/production.rb +8 -0
- data/test/environments/rails22/config/environments/test.rb +10 -0
- data/test/environments/rails22/config/routes.rb +5 -0
- data/test/environments/rails22/db/schema.rb +5 -0
- data/test/environments/rails23/Gemfile +24 -0
- data/test/environments/rails23/Rakefile +16 -0
- data/test/environments/rails23/app/controllers/application.rb +20 -0
- data/test/environments/rails23/config/boot.rb +127 -0
- data/test/environments/rails23/config/database.yml +26 -0
- data/test/environments/rails23/config/environment.rb +16 -0
- data/test/environments/rails23/config/environments/production.rb +8 -0
- data/test/environments/rails23/config/environments/test.rb +10 -0
- data/test/environments/rails23/config/preinitializer.rb +25 -0
- data/test/environments/rails23/config/routes.rb +5 -0
- data/test/environments/rails23/db/schema.rb +5 -0
- data/test/environments/rails30/Gemfile +23 -0
- data/test/environments/rails30/Rakefile +11 -0
- data/test/environments/rails30/config/application.rb +17 -0
- data/test/environments/rails30/config/boot.rb +10 -0
- data/test/environments/rails30/config/database.yml +26 -0
- data/test/environments/rails30/config/environment.rb +6 -0
- data/test/environments/rails30/config/initializers/new_rails_defaults.rb +11 -0
- data/test/environments/rails30/db/schema.rb +5 -0
- data/test/environments/rails31/Gemfile +24 -0
- data/test/environments/rails31/Rakefile +11 -0
- data/test/environments/rails31/config/application.rb +18 -0
- data/test/environments/rails31/config/boot.rb +10 -0
- data/test/environments/rails31/config/database.yml +26 -0
- data/test/environments/rails31/config/environment.rb +6 -0
- data/test/environments/rails31/config/initializers/new_rails_defaults.rb +21 -0
- data/test/environments/rails31/db/schema.rb +5 -0
- data/test/environments/rails32/Gemfile +26 -0
- data/test/environments/rails32/Rakefile +11 -0
- data/test/environments/rails32/config/application.rb +19 -0
- data/test/environments/rails32/config/boot.rb +10 -0
- data/test/environments/rails32/config/database.yml +31 -0
- data/test/environments/rails32/config/environment.rb +6 -0
- data/test/environments/rails32/db/schema.rb +5 -0
- data/test/environments/rails40/Gemfile +43 -0
- data/test/environments/rails40/Rakefile +11 -0
- data/test/environments/rails40/config/application.rb +18 -0
- data/test/environments/rails40/config/boot.rb +10 -0
- data/test/environments/rails40/config/database.yml +26 -0
- data/test/environments/rails40/config/environment.rb +6 -0
- data/test/environments/rails40/db/schema.rb +5 -0
- data/test/environments/rails41/Gemfile +35 -0
- data/test/environments/rails41/Rakefile +11 -0
- data/test/environments/rails41/config/application.rb +18 -0
- data/test/environments/rails41/config/boot.rb +10 -0
- data/test/environments/rails41/config/database.yml +26 -0
- data/test/environments/rails41/config/environment.rb +6 -0
- data/test/environments/rails41/db/schema.rb +5 -0
- data/test/environments/rails42/Gemfile +39 -0
- data/test/environments/rails42/Rakefile +11 -0
- data/test/environments/rails42/config/application.rb +18 -0
- data/test/environments/rails42/config/boot.rb +10 -0
- data/test/environments/rails42/config/database.yml +26 -0
- data/test/environments/rails42/config/environment.rb +6 -0
- data/test/environments/rails42/db/schema.rb +5 -0
- data/test/fixtures/cross_agent_tests/README.md +56 -0
- data/test/fixtures/cross_agent_tests/attribute_configuration.json +384 -0
- data/test/fixtures/cross_agent_tests/aws.json +218 -0
- data/test/fixtures/cross_agent_tests/cat_map.json +597 -0
- data/test/fixtures/cross_agent_tests/docker_container_id/README.md +6 -0
- data/test/fixtures/cross_agent_tests/docker_container_id/cases.json +75 -0
- data/test/fixtures/cross_agent_tests/docker_container_id/docker-0.9.1.txt +10 -0
- data/test/fixtures/cross_agent_tests/docker_container_id/docker-1.0.0.txt +10 -0
- data/test/fixtures/cross_agent_tests/docker_container_id/docker-1.1.2-lxc-driver.txt +10 -0
- data/test/fixtures/cross_agent_tests/docker_container_id/docker-1.1.2-native-driver-fs.txt +10 -0
- data/test/fixtures/cross_agent_tests/docker_container_id/docker-1.1.2-native-driver-systemd.txt +10 -0
- data/test/fixtures/cross_agent_tests/docker_container_id/docker-1.3.txt +9 -0
- data/test/fixtures/cross_agent_tests/docker_container_id/empty.txt +0 -0
- data/test/fixtures/cross_agent_tests/docker_container_id/heroku.txt +1 -0
- data/test/fixtures/cross_agent_tests/docker_container_id/invalid-characters.txt +9 -0
- data/test/fixtures/cross_agent_tests/docker_container_id/invalid-length.txt +9 -0
- data/test/fixtures/cross_agent_tests/docker_container_id/ubuntu-14.04-lxc-container.txt +10 -0
- data/test/fixtures/cross_agent_tests/docker_container_id/ubuntu-14.04-no-container.txt +10 -0
- data/test/fixtures/cross_agent_tests/docker_container_id/ubuntu-14.10-no-container.txt +10 -0
- data/test/fixtures/cross_agent_tests/labels.json +133 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/README.md +16 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/basic_where.colon_obfuscated.txt +3 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/basic_where.explain.txt +3 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/basic_where.obfuscated.txt +3 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/basic_where.query.txt +1 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/current_date.colon_obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/current_date.explain.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/current_date.obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/current_date.query.txt +1 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/date.colon_obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/date.explain.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/date.obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/date.query.txt +1 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/embedded_newline.colon_obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/embedded_newline.explain.txt +3 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/embedded_newline.obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/embedded_newline.query.txt +1 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/embedded_quote.colon_obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/embedded_quote.explain.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/embedded_quote.obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/embedded_quote.query.txt +1 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/floating_point.colon_obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/floating_point.explain.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/floating_point.obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/floating_point.query.txt +1 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/function_with_strings.colon_obfuscated.txt +5 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/function_with_strings.explain.txt +5 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/function_with_strings.obfuscated.txt +5 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/function_with_strings.query.txt +1 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/quote_in_table_name.colon_obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/quote_in_table_name.explain.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/quote_in_table_name.obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/quote_in_table_name.query.txt +1 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/subplan.colon_obfuscated.txt +5 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/subplan.explain.txt +5 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/subplan.obfuscated.txt +5 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/subplan.query.txt +1 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_integer.colon_obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_integer.explain.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_integer.obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_integer.query.txt +1 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_regex_chars.colon_obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_regex_chars.explain.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_regex_chars.obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_regex_chars.query.txt +1 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_substring.colon_obfuscated.txt +3 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_substring.explain.txt +3 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_substring.obfuscated.txt +3 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_substring.query.txt +1 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case1.colon_obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case1.explain.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case1.obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case1.query.txt +1 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case2.colon_obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case2.explain.txt +3 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case2.obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case2.query.txt +1 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case3.colon_obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case3.explain.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case3.obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case3.query.txt +1 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case4.colon_obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case4.explain.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case4.obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case4.query.txt +1 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case5.colon_obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case5.explain.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case5.obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case5.query.txt +1 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case6.colon_obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case6.explain.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case6.obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case6.query.txt +1 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case7.colon_obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case7.explain.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case7.obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case7.query.txt +1 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case8.colon_obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case8.explain.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case8.obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case8.query.txt +1 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case9.colon_obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case9.explain.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case9.obfuscated.txt +2 -0
- data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case9.query.txt +1 -0
- data/test/fixtures/cross_agent_tests/proc_cpuinfo/1pack_1core_1logical.txt +3 -0
- data/test/fixtures/cross_agent_tests/proc_cpuinfo/1pack_1core_2logical.txt +14 -0
- data/test/fixtures/cross_agent_tests/proc_cpuinfo/1pack_2core_2logical.txt +14 -0
- data/test/fixtures/cross_agent_tests/proc_cpuinfo/1pack_4core_4logical.txt +28 -0
- data/test/fixtures/cross_agent_tests/proc_cpuinfo/2pack_12core_24logical.txt +575 -0
- data/test/fixtures/cross_agent_tests/proc_cpuinfo/2pack_20core_40logical.txt +999 -0
- data/test/fixtures/cross_agent_tests/proc_cpuinfo/2pack_2core_2logical.txt +51 -0
- data/test/fixtures/cross_agent_tests/proc_cpuinfo/2pack_2core_4logical.txt +28 -0
- data/test/fixtures/cross_agent_tests/proc_cpuinfo/2pack_4core_4logical.txt +28 -0
- data/test/fixtures/cross_agent_tests/proc_cpuinfo/4pack_4core_4logical.txt +103 -0
- data/test/fixtures/cross_agent_tests/proc_cpuinfo/8pack_8core_8logical.txt +199 -0
- data/test/fixtures/cross_agent_tests/proc_cpuinfo/README.md +24 -0
- data/test/fixtures/cross_agent_tests/proc_cpuinfo/Xpack_Xcore_2logical.txt +43 -0
- data/test/fixtures/cross_agent_tests/proc_meminfo/README.md +7 -0
- data/test/fixtures/cross_agent_tests/proc_meminfo/meminfo_4096MB.txt +47 -0
- data/test/fixtures/cross_agent_tests/rules.json +165 -0
- data/test/fixtures/cross_agent_tests/rum_client_config.json +62 -0
- data/test/fixtures/cross_agent_tests/rum_footer_insertion_location/close-body-in-comment.html +10 -0
- data/test/fixtures/cross_agent_tests/rum_footer_insertion_location/dynamic-iframe.html +19 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/basic.html +10 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/body_with_attributes.html +3 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/charset_tag.html +11 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/charset_tag_after_x_ua_tag.html +11 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/charset_tag_before_x_ua_tag.html +11 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/charset_tag_with_spaces.html +11 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/comments1.html +24 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/comments2.html +24 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/content_type_charset_tag.html +11 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/content_type_charset_tag_after_x_ua_tag.html +11 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/content_type_charset_tag_before_x_ua_tag.html +11 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/empty_head +4 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/gt_in_quotes1.html +27 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/gt_in_quotes2.html +24 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/gt_in_quotes_mismatch.html +24 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/gt_in_single_quotes1.html +25 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/gt_in_single_quotes_mismatch.html +25 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/head_with_attributes.html +10 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/incomplete_non_meta_tags.html +10 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/no_end_header.html +6 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/no_header.html +7 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/no_html_and_no_header.html +3 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/no_start_header.html +9 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/script1.html +19 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/script2.html +17 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/x_ua_meta_tag.html +10 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/x_ua_meta_tag_multiline.html +11 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/x_ua_meta_tag_multiple_tags.html +12 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/x_ua_meta_tag_spaces_around_equals.html +10 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/x_ua_meta_tag_with_others.html +11 -0
- data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/x_ua_meta_tag_with_spaces.html +10 -0
- data/test/fixtures/cross_agent_tests/sql_obfuscation/README.md +30 -0
- data/test/fixtures/cross_agent_tests/sql_obfuscation/sql_obfuscation.json +365 -0
- data/test/fixtures/cross_agent_tests/sql_parsing.json +55 -0
- data/test/fixtures/cross_agent_tests/synthetics/README.md +65 -0
- data/test/fixtures/cross_agent_tests/synthetics/synthetics.json +317 -0
- data/test/fixtures/cross_agent_tests/transaction_segment_terms.json +101 -0
- data/test/fixtures/cross_agent_tests/url_clean.json +15 -0
- data/test/fixtures/cross_agent_tests/url_domain_extraction.json +35 -0
- data/test/helpers/exceptions.rb +16 -0
- data/test/helpers/file_searching.rb +28 -0
- data/test/helpers/mongo_metric_builder.rb +28 -0
- data/test/helpers/runtime_detection.rb +17 -0
- data/test/intentional_fail.rb +13 -0
- data/test/mmtrix/FAKECHANGELOG +21 -0
- data/test/mmtrix/agent/agent/connect_test.rb +308 -0
- data/test/mmtrix/agent/agent/start_test.rb +191 -0
- data/test/mmtrix/agent/agent/start_worker_thread_test.rb +74 -0
- data/test/mmtrix/agent/agent_logger_test.rb +392 -0
- data/test/mmtrix/agent/agent_test.rb +631 -0
- data/test/mmtrix/agent/agent_test_controller.rb +84 -0
- data/test/mmtrix/agent/apdex_from_server_test.rb +13 -0
- data/test/mmtrix/agent/attribute_filter_test.rb +218 -0
- data/test/mmtrix/agent/attribute_processing_test.rb +165 -0
- data/test/mmtrix/agent/audit_logger_test.rb +213 -0
- data/test/mmtrix/agent/autostart_test.rb +79 -0
- data/test/mmtrix/agent/aws_info_test.rb +61 -0
- data/test/mmtrix/agent/busy_calculator_test.rb +98 -0
- data/test/mmtrix/agent/commands/agent_command_router_test.rb +256 -0
- data/test/mmtrix/agent/commands/agent_command_test.rb +37 -0
- data/test/mmtrix/agent/commands/thread_profiler_session_test.rb +215 -0
- data/test/mmtrix/agent/commands/xray_session_collection_test.rb +332 -0
- data/test/mmtrix/agent/commands/xray_session_test.rb +42 -0
- data/test/mmtrix/agent/configuration/default_source_test.rb +226 -0
- data/test/mmtrix/agent/configuration/dotted_hash_test.rb +53 -0
- data/test/mmtrix/agent/configuration/environment_source_test.rb +201 -0
- data/test/mmtrix/agent/configuration/high_security_source_test.rb +83 -0
- data/test/mmtrix/agent/configuration/manager_test.rb +460 -0
- data/test/mmtrix/agent/configuration/manual_source_test.rb +18 -0
- data/test/mmtrix/agent/configuration/orphan_configuration_test.rb +89 -0
- data/test/mmtrix/agent/configuration/server_source_test.rb +202 -0
- data/test/mmtrix/agent/configuration/yaml_source_test.rb +117 -0
- data/test/mmtrix/agent/cross_app_monitor_test.rb +248 -0
- data/test/mmtrix/agent/cross_app_tracing_test.rb +71 -0
- data/test/mmtrix/agent/custom_event_aggregator_test.rb +88 -0
- data/test/mmtrix/agent/database/postgres_explain_obfuscator_test.rb +34 -0
- data/test/mmtrix/agent/database/sql_obfuscation_test.rb +59 -0
- data/test/mmtrix/agent/database_test.rb +401 -0
- data/test/mmtrix/agent/datastores/metric_helper_test.rb +132 -0
- data/test/mmtrix/agent/datastores/mongo/metric_translator_test.rb +320 -0
- data/test/mmtrix/agent/datastores/mongo/obfuscator_test.rb +91 -0
- data/test/mmtrix/agent/datastores/mongo/statement_formatter_test.rb +72 -0
- data/test/mmtrix/agent/datastores_test.rb +195 -0
- data/test/mmtrix/agent/deprecator_test.rb +52 -0
- data/test/mmtrix/agent/encoding_normalizer_test.rb +66 -0
- data/test/mmtrix/agent/error_collector_test.rb +618 -0
- data/test/mmtrix/agent/event_buffer_test_cases.rb +152 -0
- data/test/mmtrix/agent/event_listener_test.rb +70 -0
- data/test/mmtrix/agent/event_loop_test.rb +202 -0
- data/test/mmtrix/agent/harvester_test.rb +79 -0
- data/test/mmtrix/agent/hash_extensions_test.rb +34 -0
- data/test/mmtrix/agent/hostname_test.rb +93 -0
- data/test/mmtrix/agent/http_clients/uri_util_test.rb +64 -0
- data/test/mmtrix/agent/inbound_request_monitor_test.rb +49 -0
- data/test/mmtrix/agent/instrumentation/action_controller_subscriber_test.rb +299 -0
- data/test/mmtrix/agent/instrumentation/action_view_subscriber_test.rb +239 -0
- data/test/mmtrix/agent/instrumentation/active_job_test.rb +20 -0
- data/test/mmtrix/agent/instrumentation/active_record_helper_test.rb +77 -0
- data/test/mmtrix/agent/instrumentation/active_record_subscriber_test.rb +132 -0
- data/test/mmtrix/agent/instrumentation/controller_instrumentation_test.rb +328 -0
- data/test/mmtrix/agent/instrumentation/instrumentation_test.rb +14 -0
- data/test/mmtrix/agent/instrumentation/metric_frame_test.rb +22 -0
- data/test/mmtrix/agent/instrumentation/middleware_proxy_test.rb +257 -0
- data/test/mmtrix/agent/instrumentation/middleware_tracing_test.rb +49 -0
- data/test/mmtrix/agent/instrumentation/net_instrumentation_test.rb +35 -0
- data/test/mmtrix/agent/instrumentation/queue_time_test.rb +103 -0
- data/test/mmtrix/agent/instrumentation/rack_test.rb +47 -0
- data/test/mmtrix/agent/instrumentation/sequel_helper_test.rb +36 -0
- data/test/mmtrix/agent/instrumentation/sinatra/transaction_namer_test.rb +55 -0
- data/test/mmtrix/agent/instrumentation/sinatra_test.rb +80 -0
- data/test/mmtrix/agent/instrumentation/task_instrumentation_test.rb +196 -0
- data/test/mmtrix/agent/javascript_instrumentor_test.rb +340 -0
- data/test/mmtrix/agent/memory_logger_test.rb +85 -0
- data/test/mmtrix/agent/method_interrobang_test.rb +31 -0
- data/test/mmtrix/agent/method_tracer/class_methods/add_method_tracer_test.rb +122 -0
- data/test/mmtrix/agent/method_tracer/instance_methods/trace_execution_scoped_test.rb +224 -0
- data/test/mmtrix/agent/method_tracer_test.rb +474 -0
- data/test/mmtrix/agent/method_visibility_test.rb +90 -0
- data/test/mmtrix/agent/mmtrix_service_test.rb +1056 -0
- data/test/mmtrix/agent/mock_scope_listener.rb +27 -0
- data/test/mmtrix/agent/obfuscator_test.rb +77 -0
- data/test/mmtrix/agent/parameter_filtering_test.rb +39 -0
- data/test/mmtrix/agent/pipe_channel_manager_test.rb +278 -0
- data/test/mmtrix/agent/pipe_service_test.rb +145 -0
- data/test/mmtrix/agent/rpm_agent_test.rb +94 -0
- data/test/mmtrix/agent/rules_engine_test.rb +136 -0
- data/test/mmtrix/agent/sampled_buffer_test.rb +106 -0
- data/test/mmtrix/agent/sampler_collection_test.rb +90 -0
- data/test/mmtrix/agent/sampler_test.rb +66 -0
- data/test/mmtrix/agent/samplers/cpu_sampler_test.rb +51 -0
- data/test/mmtrix/agent/samplers/vm_sampler_test.rb +349 -0
- data/test/mmtrix/agent/sized_buffer_test.rb +29 -0
- data/test/mmtrix/agent/sql_sampler_test.rb +403 -0
- data/test/mmtrix/agent/stats_engine/gc_profiler_test.rb +188 -0
- data/test/mmtrix/agent/stats_engine/metric_stats_test.rb +347 -0
- data/test/mmtrix/agent/stats_engine/samplers_test.rb +98 -0
- data/test/mmtrix/agent/stats_engine/stats_hash_test.rb +194 -0
- data/test/mmtrix/agent/stats_engine_test.rb +32 -0
- data/test/mmtrix/agent/stats_test.rb +189 -0
- data/test/mmtrix/agent/synthetics_event_buffer_test.rb +54 -0
- data/test/mmtrix/agent/synthetics_monitor_test.rb +93 -0
- data/test/mmtrix/agent/system_info_test.rb +119 -0
- data/test/mmtrix/agent/threading/agent_thread_test.rb +149 -0
- data/test/mmtrix/agent/threading/backtrace_node_test.rb +184 -0
- data/test/mmtrix/agent/threading/backtrace_service_test.rb +595 -0
- data/test/mmtrix/agent/threading/fake_thread.rb +43 -0
- data/test/mmtrix/agent/threading/thread_profile_test.rb +272 -0
- data/test/mmtrix/agent/threading/threaded_test_case.rb +18 -0
- data/test/mmtrix/agent/traced_method_stack_test.rb +187 -0
- data/test/mmtrix/agent/transaction/attributes_test.rb +276 -0
- data/test/mmtrix/agent/transaction/developer_mode_sample_buffer_test.rb +75 -0
- data/test/mmtrix/agent/transaction/slowest_sample_buffer_test.rb +67 -0
- data/test/mmtrix/agent/transaction/synthetics_sample_buffer_test.rb +38 -0
- data/test/mmtrix/agent/transaction/trace_node_test.rb +361 -0
- data/test/mmtrix/agent/transaction/trace_test.rb +394 -0
- data/test/mmtrix/agent/transaction/xray_sample_buffer_test.rb +71 -0
- data/test/mmtrix/agent/transaction_event_aggregator_test.rb +426 -0
- data/test/mmtrix/agent/transaction_interrobang_test.rb +33 -0
- data/test/mmtrix/agent/transaction_metrics_test.rb +113 -0
- data/test/mmtrix/agent/transaction_sample_builder_test.rb +215 -0
- data/test/mmtrix/agent/transaction_sampler_test.rb +849 -0
- data/test/mmtrix/agent/transaction_state_test.rb +122 -0
- data/test/mmtrix/agent/transaction_test.rb +1435 -0
- data/test/mmtrix/agent/transaction_timings_test.rb +91 -0
- data/test/mmtrix/agent/utilization_data_test.rb +147 -0
- data/test/mmtrix/agent/vm/monotonic_gc_profiler_test.rb +42 -0
- data/test/mmtrix/agent/vm/mri_vm_test.rb +42 -0
- data/test/mmtrix/agent/vm/rubinius_vm_test.rb +69 -0
- data/test/mmtrix/agent/vm/snapshot_test.rb +13 -0
- data/test/mmtrix/agent/vm_test.rb +48 -0
- data/test/mmtrix/agent/worker_loop_test.rb +98 -0
- data/test/mmtrix/agent_test.rb +471 -0
- data/test/mmtrix/cli/commands/deployments_test.rb +131 -0
- data/test/mmtrix/cli/commands/install_test.rb +27 -0
- data/test/mmtrix/coerce_test.rb +95 -0
- data/test/mmtrix/collection_helper_test.rb +151 -0
- data/test/mmtrix/control/class_methods_test.rb +48 -0
- data/test/mmtrix/control/frameworks/rails_test.rb +29 -0
- data/test/mmtrix/control/instance_methods_test.rb +50 -0
- data/test/mmtrix/control/instrumentation_test.rb +41 -0
- data/test/mmtrix/control_test.rb +169 -0
- data/test/mmtrix/data_container_tests.rb +76 -0
- data/test/mmtrix/dependency_detection_test.rb +155 -0
- data/test/mmtrix/dispatcher_test.rb +59 -0
- data/test/mmtrix/environment_report_test.rb +107 -0
- data/test/mmtrix/evil_server.rb +55 -0
- data/test/mmtrix/fake_collector.rb +385 -0
- data/test/mmtrix/fake_external_server.rb +65 -0
- data/test/mmtrix/fake_instance_metadata_service.rb +45 -0
- data/test/mmtrix/fake_rpm_site.rb +35 -0
- data/test/mmtrix/fake_server.rb +104 -0
- data/test/mmtrix/filtering_test_app.rb +19 -0
- data/test/mmtrix/framework_test.rb +58 -0
- data/test/mmtrix/http_client_test_cases.rb +621 -0
- data/test/mmtrix/json_wrapper_test.rb +32 -0
- data/test/mmtrix/language_support_test.rb +104 -0
- data/test/mmtrix/latest_changes_test.rb +45 -0
- data/test/mmtrix/license_test.rb +128 -0
- data/test/mmtrix/load_test.rb +15 -0
- data/test/mmtrix/local_environment_test.rb +103 -0
- data/test/mmtrix/marshalling_test_cases.rb +140 -0
- data/test/mmtrix/metric_data_test.rb +191 -0
- data/test/mmtrix/metric_parser/metric_parser_test.rb +17 -0
- data/test/mmtrix/metric_spec_test.rb +145 -0
- data/test/mmtrix/multiverse_helpers.rb +283 -0
- data/test/mmtrix/noticed_error_test.rb +197 -0
- data/test/mmtrix/rack/agent_hooks_test.rb +44 -0
- data/test/mmtrix/rack/agent_middleware_test.rb +32 -0
- data/test/mmtrix/rack/browser_monitoring_test.rb +197 -0
- data/test/mmtrix/rack/deferred_instrumentation_test.rb +33 -0
- data/test/mmtrix/rack/developer_mode/segment_summary_test.rb +96 -0
- data/test/mmtrix/rack/developer_mode_helper_test.rb +136 -0
- data/test/mmtrix/rack/developer_mode_test.rb +93 -0
- data/test/mmtrix/rack/error_collector_test.rb +77 -0
- data/test/mmtrix/transaction_ignoring_test_cases.rb +102 -0
- data/test/mmtrix/version_number_test.rb +101 -0
- data/test/multiverse/.gitignore +13 -0
- data/test/multiverse/README.md +85 -0
- data/test/multiverse/lib/multiverse/color.rb +23 -0
- data/test/multiverse/lib/multiverse/envfile.rb +66 -0
- data/test/multiverse/lib/multiverse/environment.rb +19 -0
- data/test/multiverse/lib/multiverse/output_collector.rb +82 -0
- data/test/multiverse/lib/multiverse/runner.rb +117 -0
- data/test/multiverse/lib/multiverse/suite.rb +528 -0
- data/test/multiverse/script/runner +5 -0
- data/test/multiverse/suites/active_record/.gitignore +1 -0
- data/test/multiverse/suites/active_record/Envfile +73 -0
- data/test/multiverse/suites/active_record/Rakefile +9 -0
- data/test/multiverse/suites/active_record/active_record_test.rb +568 -0
- data/test/multiverse/suites/active_record/app/models/models.rb +34 -0
- data/test/multiverse/suites/active_record/ar_method_aliasing.rb +43 -0
- data/test/multiverse/suites/active_record/before_suite.rb +23 -0
- data/test/multiverse/suites/active_record/config/database.rb +80 -0
- data/test/multiverse/suites/active_record/config/database.yml +19 -0
- data/test/multiverse/suites/active_record/config/mmtrix.yml +18 -0
- data/test/multiverse/suites/active_record/db/migrate/20141105131800_create_users_and_aliases.rb +21 -0
- data/test/multiverse/suites/active_record/db/migrate/20141106082200_create_orders_and_shipments.rb +25 -0
- data/test/multiverse/suites/active_record/db/migrate/20150413011200_add_timestamps_to_orders.rb +16 -0
- data/test/multiverse/suites/active_record/db/migrate/20150414084400_create_groups.rb +21 -0
- data/test/multiverse/suites/activemerchant/Envfile +36 -0
- data/test/multiverse/suites/activemerchant/activemerchant_test.rb +62 -0
- data/test/multiverse/suites/agent_only/Envfile +4 -0
- data/test/multiverse/suites/agent_only/agent_attributes_test.rb +168 -0
- data/test/multiverse/suites/agent_only/agent_run_id_handling_test.rb +39 -0
- data/test/multiverse/suites/agent_only/audit_log_test.rb +58 -0
- data/test/multiverse/suites/agent_only/collector_exception_handling_test.rb +87 -0
- data/test/multiverse/suites/agent_only/config/mmtrix.yml +27 -0
- data/test/multiverse/suites/agent_only/cross_application_tracing_test.rb +94 -0
- data/test/multiverse/suites/agent_only/custom_analytics_events_test.rb +67 -0
- data/test/multiverse/suites/agent_only/custom_queue_time_test.rb +60 -0
- data/test/multiverse/suites/agent_only/encoding_handling_test.rb +130 -0
- data/test/multiverse/suites/agent_only/exclusive_time_test.rb +176 -0
- data/test/multiverse/suites/agent_only/harvest_timestamps_test.rb +83 -0
- data/test/multiverse/suites/agent_only/http_response_code_test.rb +38 -0
- data/test/multiverse/suites/agent_only/keepalive_test.rb +24 -0
- data/test/multiverse/suites/agent_only/key_transactions_test.rb +118 -0
- data/test/multiverse/suites/agent_only/labels_test.rb +83 -0
- data/test/multiverse/suites/agent_only/logging_test.rb +162 -0
- data/test/multiverse/suites/agent_only/marshaling_test.rb +88 -0
- data/test/multiverse/suites/agent_only/pipe_manager_test.rb +41 -0
- data/test/multiverse/suites/agent_only/rename_rule_test.rb +91 -0
- data/test/multiverse/suites/agent_only/rum_instrumentation_test.rb +97 -0
- data/test/multiverse/suites/agent_only/script/env_change.rb +10 -0
- data/test/multiverse/suites/agent_only/script/loading.rb +20 -0
- data/test/multiverse/suites/agent_only/script/public_api_when_disabled.rb +68 -0
- data/test/multiverse/suites/agent_only/script/symbol_env.rb +10 -0
- data/test/multiverse/suites/agent_only/service_timeout_test.rb +39 -0
- data/test/multiverse/suites/agent_only/set_transaction_name_test.rb +118 -0
- data/test/multiverse/suites/agent_only/ssl_test.rb +21 -0
- data/test/multiverse/suites/agent_only/start_up_test.rb +74 -0
- data/test/multiverse/suites/agent_only/synthetics_test.rb +131 -0
- data/test/multiverse/suites/agent_only/testing_app.rb +58 -0
- data/test/multiverse/suites/agent_only/thread_profiling_test.rb +160 -0
- data/test/multiverse/suites/agent_only/transaction_ignoring_test.rb +42 -0
- data/test/multiverse/suites/agent_only/utilization_data_collection_test.rb +110 -0
- data/test/multiverse/suites/agent_only/xray_sessions_test.rb +199 -0
- data/test/multiverse/suites/bare/Envfile +3 -0
- data/test/multiverse/suites/bare/standalone_instrumentation_test.rb +43 -0
- data/test/multiverse/suites/capistrano/Capfile +26 -0
- data/test/multiverse/suites/capistrano/Envfile +18 -0
- data/test/multiverse/suites/capistrano/config/deploy/production.rb +9 -0
- data/test/multiverse/suites/capistrano/config/deploy.rb +14 -0
- data/test/multiverse/suites/capistrano/config/mmtrix.yml +21 -0
- data/test/multiverse/suites/capistrano/deployment_test.rb +54 -0
- data/test/multiverse/suites/capistrano2/Capfile +4 -0
- data/test/multiverse/suites/capistrano2/Envfile +8 -0
- data/test/multiverse/suites/capistrano2/config/deploy.rb +19 -0
- data/test/multiverse/suites/capistrano2/config/mmtrix.yml +21 -0
- data/test/multiverse/suites/capistrano2/deployment_test.rb +37 -0
- data/test/multiverse/suites/config_file_loading/Envfile +13 -0
- data/test/multiverse/suites/config_file_loading/config_file_loading_test.rb +213 -0
- data/test/multiverse/suites/curb/Envfile +31 -0
- data/test/multiverse/suites/curb/config/mmtrix.yml +18 -0
- data/test/multiverse/suites/curb/curb_test.rb +213 -0
- data/test/multiverse/suites/datamapper/Envfile +30 -0
- data/test/multiverse/suites/datamapper/config/mmtrix.yml +20 -0
- data/test/multiverse/suites/datamapper/datamapper_test.rb +335 -0
- data/test/multiverse/suites/deferred_instrumentation/Envfile +15 -0
- data/test/multiverse/suites/deferred_instrumentation/config/mmtrix.yml +20 -0
- data/test/multiverse/suites/deferred_instrumentation/sinatra_test.rb +107 -0
- data/test/multiverse/suites/delayed_job/Envfile +102 -0
- data/test/multiverse/suites/delayed_job/before_suite.rb +33 -0
- data/test/multiverse/suites/delayed_job/config/mmtrix.yml +18 -0
- data/test/multiverse/suites/delayed_job/delayed_job_sampler_test.rb +128 -0
- data/test/multiverse/suites/delayed_job/unsupported_backend_test.rb +21 -0
- data/test/multiverse/suites/excon/Envfile +21 -0
- data/test/multiverse/suites/excon/config/mmtrix.yml +18 -0
- data/test/multiverse/suites/excon/excon_test.rb +81 -0
- data/test/multiverse/suites/grape/Envfile +13 -0
- data/test/multiverse/suites/grape/config/mmtrix.yml +19 -0
- data/test/multiverse/suites/grape/grape_test.rb +202 -0
- data/test/multiverse/suites/grape/grape_test_api.rb +64 -0
- data/test/multiverse/suites/grape/grape_versioning_test.rb +64 -0
- data/test/multiverse/suites/grape/grape_versioning_test_api.rb +72 -0
- data/test/multiverse/suites/grape/unsupported_version_test.rb +28 -0
- data/test/multiverse/suites/high_security/Envfile +3 -0
- data/test/multiverse/suites/high_security/config/mmtrix.yml +70 -0
- data/test/multiverse/suites/high_security/high_security_test.rb +214 -0
- data/test/multiverse/suites/httpclient/Envfile +13 -0
- data/test/multiverse/suites/httpclient/config/mmtrix.yml +18 -0
- data/test/multiverse/suites/httpclient/httpclient_test.rb +75 -0
- data/test/multiverse/suites/json/Envfile +25 -0
- data/test/multiverse/suites/json/config/mmtrix.yml +22 -0
- data/test/multiverse/suites/json/json_test.rb +16 -0
- data/test/multiverse/suites/marshalling/Envfile +12 -0
- data/test/multiverse/suites/marshalling/config/mmtrix.yml +20 -0
- data/test/multiverse/suites/marshalling/marshalling_test.rb +16 -0
- data/test/multiverse/suites/memcached/Envfile +52 -0
- data/test/multiverse/suites/memcached/dalli_test.rb +89 -0
- data/test/multiverse/suites/memcached/memcache_client_test.rb +25 -0
- data/test/multiverse/suites/memcached/memcache_test_cases.rb +302 -0
- data/test/multiverse/suites/memcached/memcached_test.rb +159 -0
- data/test/multiverse/suites/mongo/Envfile +69 -0
- data/test/multiverse/suites/mongo/config/mmtrix.yml +18 -0
- data/test/multiverse/suites/mongo/helpers/mongo_operation_tests.rb +489 -0
- data/test/multiverse/suites/mongo/helpers/mongo_replica_set.rb +97 -0
- data/test/multiverse/suites/mongo/helpers/mongo_replica_set_test.rb +82 -0
- data/test/multiverse/suites/mongo/helpers/mongo_server.rb +241 -0
- data/test/multiverse/suites/mongo/helpers/mongo_server_test.rb +176 -0
- data/test/multiverse/suites/mongo/mongo_connection_test.rb +39 -0
- data/test/multiverse/suites/mongo/mongo_instrumentation_test.rb +39 -0
- data/test/multiverse/suites/mongo/mongo_unsupported_version_test.rb +72 -0
- data/test/multiverse/suites/net_http/Envfile +4 -0
- data/test/multiverse/suites/net_http/config/mmtrix.yml +18 -0
- data/test/multiverse/suites/net_http/net_http_test.rb +111 -0
- data/test/multiverse/suites/padrino/Envfile +14 -0
- data/test/multiverse/suites/padrino/config/mmtrix.yml +20 -0
- data/test/multiverse/suites/padrino/padrino_test.rb +52 -0
- data/test/multiverse/suites/rack/Envfile +35 -0
- data/test/multiverse/suites/rack/builder_map_test.rb +128 -0
- data/test/multiverse/suites/rack/example_app.rb +100 -0
- data/test/multiverse/suites/rack/http_response_code_test.rb +50 -0
- data/test/multiverse/suites/rack/nested_non_rack_app_test.rb +66 -0
- data/test/multiverse/suites/rack/rack_auto_instrumentation_test.rb +144 -0
- data/test/multiverse/suites/rack/rack_cascade_test.rb +45 -0
- data/test/multiverse/suites/rack/rack_env_mutation_test.rb +53 -0
- data/test/multiverse/suites/rack/rack_parameter_filtering_test.rb +49 -0
- data/test/multiverse/suites/rack/rack_unsupported_version_test.rb +43 -0
- data/test/multiverse/suites/rack/url_map_test.rb +117 -0
- data/test/multiverse/suites/rails/Envfile +61 -0
- data/test/multiverse/suites/rails/action_controller_live_rum_test.rb +39 -0
- data/test/multiverse/suites/rails/activejob_test.rb +152 -0
- data/test/multiverse/suites/rails/app/views/foos/_foo.html.haml +1 -0
- data/test/multiverse/suites/rails/app/views/views/_a_partial.html.erb +2 -0
- data/test/multiverse/suites/rails/app/views/views/_mid_partial.html.erb +1 -0
- data/test/multiverse/suites/rails/app/views/views/_top_partial.html.erb +3 -0
- data/test/multiverse/suites/rails/app/views/views/deep_partial.html.erb +3 -0
- data/test/multiverse/suites/rails/app/views/views/haml_view.html.haml +6 -0
- data/test/multiverse/suites/rails/app/views/views/index.html.erb +4 -0
- data/test/multiverse/suites/rails/app.rb +44 -0
- data/test/multiverse/suites/rails/bad_instrumentation_test.rb +29 -0
- data/test/multiverse/suites/rails/config/mmtrix.yml +30 -0
- data/test/multiverse/suites/rails/dummy.txt +1 -0
- data/test/multiverse/suites/rails/error_tracing_test.rb +322 -0
- data/test/multiverse/suites/rails/gc_instrumentation_test.rb +93 -0
- data/test/multiverse/suites/rails/ignore_test.rb +79 -0
- data/test/multiverse/suites/rails/middleware_instrumentation_test.rb +41 -0
- data/test/multiverse/suites/rails/middlewares.rb +19 -0
- data/test/multiverse/suites/rails/parameter_capture_test.rb +299 -0
- data/test/multiverse/suites/rails/queue_time_test.rb +89 -0
- data/test/multiverse/suites/rails/rails2_app/app/controllers/application.rb +7 -0
- data/test/multiverse/suites/rails/rails2_app/config/boot.rb +127 -0
- data/test/multiverse/suites/rails/rails2_app/config/database.yml +18 -0
- data/test/multiverse/suites/rails/rails2_app/config/environment.rb +16 -0
- data/test/multiverse/suites/rails/rails2_app/config/environments/development.rb +10 -0
- data/test/multiverse/suites/rails/rails2_app/config/initializers/load_mmtrix_rpm.rb +9 -0
- data/test/multiverse/suites/rails/rails2_app/config/preinitializer.rb +25 -0
- data/test/multiverse/suites/rails/rails2_app/config/routes.rb +19 -0
- data/test/multiverse/suites/rails/rails2_app/db/schema.rb +5 -0
- data/test/multiverse/suites/rails/rails3_app/app_rails3_plus.rb +92 -0
- data/test/multiverse/suites/rails/request_statistics_test.rb +192 -0
- data/test/multiverse/suites/rails/transaction_ignoring_test.rb +41 -0
- data/test/multiverse/suites/rails/view_instrumentation_test.rb +254 -0
- data/test/multiverse/suites/resque/Envfile +11 -0
- data/test/multiverse/suites/resque/Rakefile +3 -0
- data/test/multiverse/suites/resque/config/mmtrix.yml +19 -0
- data/test/multiverse/suites/resque/instrumentation_test.rb +155 -0
- data/test/multiverse/suites/resque/resque_marshalling_test.rb +53 -0
- data/test/multiverse/suites/sequel/Envfile +34 -0
- data/test/multiverse/suites/sequel/config/mmtrix.yml +18 -0
- data/test/multiverse/suites/sequel/database.rb +57 -0
- data/test/multiverse/suites/sequel/sequel_extension_test.rb +142 -0
- data/test/multiverse/suites/sequel/sequel_helpers.rb +62 -0
- data/test/multiverse/suites/sequel/sequel_plugin_test.rb +230 -0
- data/test/multiverse/suites/sequel/sequel_safety_test.rb +30 -0
- data/test/multiverse/suites/sidekiq/Envfile +31 -0
- data/test/multiverse/suites/sidekiq/after_suite.rb +16 -0
- data/test/multiverse/suites/sidekiq/config/mmtrix.yml +20 -0
- data/test/multiverse/suites/sidekiq/log/.gitkeep +0 -0
- data/test/multiverse/suites/sidekiq/sidekiq_instrumentation_test.rb +219 -0
- data/test/multiverse/suites/sidekiq/sidekiq_server.rb +31 -0
- data/test/multiverse/suites/sidekiq/test_worker.rb +71 -0
- data/test/multiverse/suites/sinatra/Envfile +17 -0
- data/test/multiverse/suites/sinatra/config/mmtrix.yml +21 -0
- data/test/multiverse/suites/sinatra/ignoring_test.rb +208 -0
- data/test/multiverse/suites/sinatra/nested_middleware_test.rb +39 -0
- data/test/multiverse/suites/sinatra/sinatra_classic_test.rb +99 -0
- data/test/multiverse/suites/sinatra/sinatra_error_tracing_test.rb +45 -0
- data/test/multiverse/suites/sinatra/sinatra_metric_explosion_test.rb +96 -0
- data/test/multiverse/suites/sinatra/sinatra_modular_test.rb +89 -0
- data/test/multiverse/suites/sinatra/sinatra_parameter_capture_test.rb +65 -0
- data/test/multiverse/suites/sinatra/sinatra_routes_test.rb +49 -0
- data/test/multiverse/suites/sinatra/sinatra_test_cases.rb +137 -0
- data/test/multiverse/suites/typhoeus/Envfile +57 -0
- data/test/multiverse/suites/typhoeus/config/mmtrix.yml +18 -0
- data/test/multiverse/suites/typhoeus/typhoeus_test.rb +144 -0
- data/test/multiverse/suites/yajl/Envfile +13 -0
- data/test/multiverse/suites/yajl/config/mmtrix.yml +21 -0
- data/test/multiverse/suites/yajl/yajl_test.rb +18 -0
- data/test/multiverse/test/multiverse_test.rb +59 -0
- data/test/multiverse/test/suite_examples/one/a/Envfile +3 -0
- data/test/multiverse/test/suite_examples/one/a/a_test.rb +14 -0
- data/test/multiverse/test/suite_examples/one/a/config/mmtrix.yml +22 -0
- data/test/multiverse/test/suite_examples/one/b/Envfile +3 -0
- data/test/multiverse/test/suite_examples/one/b/b_test.rb +14 -0
- data/test/multiverse/test/suite_examples/one/b/config/mmtrix.yml +22 -0
- data/test/multiverse/test/suite_examples/three/a/Envfile +2 -0
- data/test/multiverse/test/suite_examples/three/a/fail_test.rb +10 -0
- data/test/multiverse/test/suite_examples/three/b/Envfile +2 -0
- data/test/multiverse/test/suite_examples/three/b/win_test.rb +10 -0
- data/test/multiverse/test/suite_examples/two/a/Envfile +1 -0
- data/test/multiverse/test/suite_examples/two/a/fail_test.rb +10 -0
- data/test/performance/README.md +182 -0
- data/test/performance/lib/performance/baseline.rb +36 -0
- data/test/performance/lib/performance/baseline_compare_reporter.rb +103 -0
- data/test/performance/lib/performance/baseline_save_reporter.rb +24 -0
- data/test/performance/lib/performance/console_reporter.rb +66 -0
- data/test/performance/lib/performance/formatting_helpers.rb +22 -0
- data/test/performance/lib/performance/hako_client.rb +31 -0
- data/test/performance/lib/performance/hako_reporter.rb +26 -0
- data/test/performance/lib/performance/instrumentation/cpu_usage.rb +26 -0
- data/test/performance/lib/performance/instrumentation/gc_stats.rb +58 -0
- data/test/performance/lib/performance/instrumentation/perf_tools.rb +30 -0
- data/test/performance/lib/performance/instrumentation/stackprof.rb +46 -0
- data/test/performance/lib/performance/instrumentor.rb +96 -0
- data/test/performance/lib/performance/json_reporter.rb +15 -0
- data/test/performance/lib/performance/platform.rb +37 -0
- data/test/performance/lib/performance/reporting.rb +36 -0
- data/test/performance/lib/performance/result.rb +104 -0
- data/test/performance/lib/performance/runner.rb +221 -0
- data/test/performance/lib/performance/table.rb +105 -0
- data/test/performance/lib/performance/test_case.rb +152 -0
- data/test/performance/lib/performance/timer.rb +40 -0
- data/test/performance/lib/performance.rb +38 -0
- data/test/performance/script/baselines +102 -0
- data/test/performance/script/mega-runner +37 -0
- data/test/performance/script/runner +133 -0
- data/test/performance/suites/active_record.rb +47 -0
- data/test/performance/suites/agent_attributes.rb +62 -0
- data/test/performance/suites/config.rb +35 -0
- data/test/performance/suites/marshalling.rb +156 -0
- data/test/performance/suites/queue_time.rb +21 -0
- data/test/performance/suites/rack_middleware.rb +136 -0
- data/test/performance/suites/rum_autoinsertion.rb +75 -0
- data/test/performance/suites/sql_obfuscation.rb +30 -0
- data/test/performance/suites/startup.rb +12 -0
- data/test/performance/suites/stats_hash.rb +31 -0
- data/test/performance/suites/thread_profiling.rb +116 -0
- data/test/performance/suites/trace_execution_scoped.rb +32 -0
- data/test/performance/suites/transaction_tracing.rb +106 -0
- data/test/script/build_test_gem.sh +57 -0
- data/test/script/ci.sh +170 -0
- data/test/script/ci_agent-tests_runner.sh +82 -0
- data/test/script/ci_bench.sh +52 -0
- data/test/script/ci_multiverse_runner.sh +63 -0
- data/test/script/path_hash.rb +49 -0
- data/test/test_helper.rb +266 -0
- data/ui/helpers/developer_mode_helper.rb +324 -0
- data/ui/helpers/google_pie_chart.rb +53 -0
- data/ui/views/layouts/mmtrix_default.rhtml +48 -0
- data/ui/views/mmtrix/_explain_plans.rhtml +27 -0
- data/ui/views/mmtrix/_sample.rhtml +20 -0
- data/ui/views/mmtrix/_segment.rhtml +28 -0
- data/ui/views/mmtrix/_segment_limit_message.rhtml +1 -0
- data/ui/views/mmtrix/_segment_row.rhtml +12 -0
- data/ui/views/mmtrix/_show_sample_detail.rhtml +24 -0
- data/ui/views/mmtrix/_show_sample_sql.rhtml +24 -0
- data/ui/views/mmtrix/_show_sample_summary.rhtml +3 -0
- data/ui/views/mmtrix/_sql_row.rhtml +16 -0
- data/ui/views/mmtrix/_stack_trace.rhtml +15 -0
- data/ui/views/mmtrix/_table.rhtml +12 -0
- data/ui/views/mmtrix/explain_sql.rhtml +43 -0
- data/ui/views/mmtrix/file/images/arrow-close.png +0 -0
- data/ui/views/mmtrix/file/images/arrow-open.png +0 -0
- data/ui/views/mmtrix/file/images/blue_bar.gif +0 -0
- data/ui/views/mmtrix/file/images/file_icon.png +0 -0
- data/ui/views/mmtrix/file/images/gray_bar.gif +0 -0
- data/ui/views/mmtrix/file/images/mmtrix-rpm-desktop.gif +0 -0
- data/ui/views/mmtrix/file/images/mmtrix_rpm_desktop.gif +0 -0
- data/ui/views/mmtrix/file/images/textmate.png +0 -0
- data/ui/views/mmtrix/file/javascript/jquery-1.4.2.js +6243 -0
- data/ui/views/mmtrix/file/javascript/transaction_sample.js +123 -0
- data/ui/views/mmtrix/file/stylesheets/style.css +490 -0
- data/ui/views/mmtrix/index.rhtml +70 -0
- data/ui/views/mmtrix/sample_not_found.rhtml +2 -0
- data/ui/views/mmtrix/show_sample.rhtml +81 -0
- data/ui/views/mmtrix/threads.rhtml +45 -0
- data/vendor/gems/dependency_detection-0.0.1.build/lib/dependency_detection/version.rb +7 -0
- data/vendor/gems/dependency_detection-0.0.1.build/lib/dependency_detection.rb +122 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/.specification +116 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/metric_parser.rb +5 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/action_mailer.rb +18 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/active_merchant.rb +35 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/active_record.rb +37 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/apdex.rb +93 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/background_transaction.rb +11 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/client.rb +50 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/controller.rb +71 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/controller_cpu.rb +47 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/controller_ext.rb +21 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/database.rb +52 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/database_pool.rb +28 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/dot_net.rb +32 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/dot_net_parser.rb +21 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/errors.rb +15 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/external.rb +59 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/frontend.rb +44 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/gc.rb +24 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/hibernate_session.rb +11 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/java.rb +35 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/java_parser.rb +21 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/jsp.rb +38 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/jsp_tag.rb +11 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/mem_cache.rb +59 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/metric_parser.rb +138 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/middleware.rb +34 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/nested.rb +24 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/orm.rb +31 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/other_transaction.rb +44 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/servlet.rb +11 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/servlet_context_listener.rb +11 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/servlet_filter.rb +11 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/servlet_init.rb +11 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/solr.rb +31 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/solr_request_handler.rb +19 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/spring.rb +58 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/spring_controller.rb +10 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/spring_view.rb +10 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/struts_action.rb +24 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/struts_result.rb +24 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/version.rb +9 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/view.rb +74 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/web_frontend.rb +22 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/web_service.rb +18 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser/web_transaction.rb +137 -0
- data/vendor/gems/metric_parser-0.1.0.pre1/lib/mmtrix/metric_parser.rb +70 -0
- metadata +1263 -0
data/lib/mmtrix/agent.rb
ADDED
@@ -0,0 +1,714 @@
|
|
1
|
+
# encoding: utf-8
|
2
|
+
# This file is distributed under Mmtrix's license terms.
|
3
|
+
# See https://github.com/mmtrix/rpm/blob/master/LICENSE for complete details.
|
4
|
+
|
5
|
+
require 'forwardable'
|
6
|
+
|
7
|
+
# @api public
|
8
|
+
module Mmtrix
|
9
|
+
# This module contains most of the public API methods for the Ruby Agent.
|
10
|
+
#
|
11
|
+
# For adding custom instrumentation to method invocations, see
|
12
|
+
# the docs for {Mmtrix::Agent::MethodTracer} and
|
13
|
+
# {Mmtrix::Agent::MethodTracer::ClassMethods}.
|
14
|
+
#
|
15
|
+
# For information on how to trace transactions in non-Rack contexts,
|
16
|
+
# see {Mmtrix::Agent::Instrumentation::ControllerInstrumentation}.
|
17
|
+
#
|
18
|
+
# For general documentation about the Ruby agent, see:
|
19
|
+
# https://docs.mmtrix.com/docs/agents/ruby-agent
|
20
|
+
#
|
21
|
+
# @api public
|
22
|
+
#
|
23
|
+
module Agent
|
24
|
+
extend self
|
25
|
+
extend Forwardable
|
26
|
+
|
27
|
+
require 'mmtrix/version'
|
28
|
+
require 'mmtrix/local_environment'
|
29
|
+
require 'mmtrix/metrics'
|
30
|
+
require 'mmtrix/metric_spec'
|
31
|
+
require 'mmtrix/metric_data'
|
32
|
+
require 'mmtrix/collection_helper'
|
33
|
+
require 'mmtrix/noticed_error'
|
34
|
+
require 'mmtrix/timer_lib'
|
35
|
+
|
36
|
+
require 'mmtrix/agent/stats'
|
37
|
+
require 'mmtrix/agent/chained_call'
|
38
|
+
require 'mmtrix/agent/cross_app_monitor'
|
39
|
+
require 'mmtrix/agent/agent'
|
40
|
+
require 'mmtrix/agent/method_tracer'
|
41
|
+
require 'mmtrix/agent/worker_loop'
|
42
|
+
require 'mmtrix/agent/event_loop'
|
43
|
+
require 'mmtrix/agent/stats_engine'
|
44
|
+
require 'mmtrix/agent/transaction_sampler'
|
45
|
+
require 'mmtrix/agent/sql_sampler'
|
46
|
+
require 'mmtrix/agent/commands/thread_profiler_session'
|
47
|
+
require 'mmtrix/agent/error_collector'
|
48
|
+
require 'mmtrix/agent/busy_calculator'
|
49
|
+
require 'mmtrix/agent/sampler'
|
50
|
+
require 'mmtrix/agent/database'
|
51
|
+
require 'mmtrix/agent/pipe_channel_manager'
|
52
|
+
require 'mmtrix/agent/configuration'
|
53
|
+
require 'mmtrix/agent/rules_engine'
|
54
|
+
require 'mmtrix/agent/http_clients/uri_util'
|
55
|
+
require 'mmtrix/agent/system_info'
|
56
|
+
|
57
|
+
require 'mmtrix/agent/instrumentation/controller_instrumentation'
|
58
|
+
|
59
|
+
# this is a shim that's here only for backwards compatibility
|
60
|
+
require 'mmtrix/agent/instrumentation/metric_frame'
|
61
|
+
|
62
|
+
require 'mmtrix/agent/samplers/cpu_sampler'
|
63
|
+
require 'mmtrix/agent/samplers/memory_sampler'
|
64
|
+
require 'mmtrix/agent/samplers/object_sampler'
|
65
|
+
require 'mmtrix/agent/samplers/delayed_job_sampler'
|
66
|
+
require 'mmtrix/agent/samplers/vm_sampler'
|
67
|
+
require 'set'
|
68
|
+
require 'thread'
|
69
|
+
require 'resolv'
|
70
|
+
|
71
|
+
# An exception that is thrown by the server if the agent license is invalid.
|
72
|
+
class LicenseException < StandardError; end
|
73
|
+
|
74
|
+
# An exception that forces an agent to stop reporting until its mongrel is restarted.
|
75
|
+
class ForceDisconnectException < StandardError; end
|
76
|
+
|
77
|
+
# An exception that forces an agent to restart.
|
78
|
+
class ForceRestartException < StandardError; end
|
79
|
+
|
80
|
+
# Used to blow out of a periodic task without logging a an error, such as for routine
|
81
|
+
# failures.
|
82
|
+
class ServerConnectionException < StandardError; end
|
83
|
+
|
84
|
+
# When a post is either too large or poorly formatted we should
|
85
|
+
# drop it and not try to resend
|
86
|
+
class UnrecoverableServerException < ServerConnectionException; end
|
87
|
+
|
88
|
+
# An unrecoverable client-side error that prevents the agent from continuing
|
89
|
+
class UnrecoverableAgentException < ServerConnectionException; end
|
90
|
+
|
91
|
+
# An error while serializing data for the collector
|
92
|
+
class SerializationError < StandardError; end
|
93
|
+
|
94
|
+
class BackgroundLoadingError < StandardError; end
|
95
|
+
|
96
|
+
# placeholder name used when we cannot determine a transaction's name
|
97
|
+
UNKNOWN_METRIC = '(unknown)'.freeze
|
98
|
+
|
99
|
+
@agent = nil
|
100
|
+
@logger = nil
|
101
|
+
|
102
|
+
# The singleton Agent instance. Used internally.
|
103
|
+
def agent #:nodoc:
|
104
|
+
return @agent if @agent
|
105
|
+
Mmtrix::Agent.logger.warn("Agent unavailable as it hasn't been started.")
|
106
|
+
Mmtrix::Agent.logger.warn(caller.join("\n"))
|
107
|
+
nil
|
108
|
+
end
|
109
|
+
|
110
|
+
def agent=(new_instance)#:nodoc:
|
111
|
+
@agent = new_instance
|
112
|
+
end
|
113
|
+
|
114
|
+
alias instance agent #:nodoc:
|
115
|
+
|
116
|
+
# Primary interface to logging is fronted by this accessor
|
117
|
+
# Access via ::Mmtrix::Agent.logger
|
118
|
+
def logger
|
119
|
+
@logger || StartupLogger.instance
|
120
|
+
end
|
121
|
+
|
122
|
+
def logger=(log)
|
123
|
+
@logger = log
|
124
|
+
end
|
125
|
+
|
126
|
+
# This needs to come after the definition of the logger method above, since
|
127
|
+
# instantiating the config writes to the Logger.
|
128
|
+
|
129
|
+
@config = Mmtrix::Agent::Configuration::Manager.new
|
130
|
+
|
131
|
+
attr_reader :config
|
132
|
+
|
133
|
+
# For testing
|
134
|
+
# Important that we don't change the instance or we orphan callbacks
|
135
|
+
def reset_config
|
136
|
+
@config.reset_to_defaults
|
137
|
+
end
|
138
|
+
|
139
|
+
# @!group Recording custom metrics
|
140
|
+
|
141
|
+
# Record a value for the given metric name.
|
142
|
+
#
|
143
|
+
# This method should be used to record event-based metrics such as method
|
144
|
+
# calls that are associated with a specific duration or magnitude.
|
145
|
+
#
|
146
|
+
# +metric_name+ should follow a slash separated path convention. Application
|
147
|
+
# specific metrics should begin with "Custom/".
|
148
|
+
#
|
149
|
+
# +value+ should be either a single Numeric value representing the duration/
|
150
|
+
# magnitude of the event being recorded, or a Hash containing :count,
|
151
|
+
# :total, :min, :max, and :sum_of_squares keys. The latter form is useful
|
152
|
+
# for recording pre-aggregated metrics collected externally.
|
153
|
+
#
|
154
|
+
# This method is safe to use from any thread.
|
155
|
+
#
|
156
|
+
# @api public
|
157
|
+
def record_metric(metric_name, value) #THREAD_LOCAL_ACCESS
|
158
|
+
return unless agent
|
159
|
+
|
160
|
+
if value.is_a?(Hash)
|
161
|
+
stats = Mmtrix::Agent::Stats.new
|
162
|
+
|
163
|
+
stats.call_count = value[:count] if value[:count]
|
164
|
+
stats.total_call_time = value[:total] if value[:total]
|
165
|
+
stats.total_exclusive_time = value[:total] if value[:total]
|
166
|
+
stats.min_call_time = value[:min] if value[:min]
|
167
|
+
stats.max_call_time = value[:max] if value[:max]
|
168
|
+
stats.sum_of_squares = value[:sum_of_squares] if value[:sum_of_squares]
|
169
|
+
value = stats
|
170
|
+
end
|
171
|
+
agent.stats_engine.tl_record_unscoped_metrics(metric_name, value)
|
172
|
+
end
|
173
|
+
|
174
|
+
# Increment a simple counter metric.
|
175
|
+
#
|
176
|
+
# +metric_name+ should follow a slash separated path convention. Application
|
177
|
+
# specific metrics should begin with "Custom/".
|
178
|
+
#
|
179
|
+
# This method is safe to use from any thread.
|
180
|
+
#
|
181
|
+
# @api public
|
182
|
+
def increment_metric(metric_name, amount=1) #THREAD_LOCAL_ACCESS
|
183
|
+
return unless agent
|
184
|
+
|
185
|
+
agent.stats_engine.tl_record_unscoped_metrics(metric_name) do |stats|
|
186
|
+
stats.increment_count(amount)
|
187
|
+
end
|
188
|
+
end
|
189
|
+
|
190
|
+
# @!endgroup
|
191
|
+
|
192
|
+
# @!group Recording custom errors
|
193
|
+
|
194
|
+
# Set a filter to be applied to errors that the Ruby Agent will
|
195
|
+
# track. The block should evalute to the exception to track
|
196
|
+
# (which could be different from the original exception) or nil to
|
197
|
+
# ignore this exception.
|
198
|
+
#
|
199
|
+
# The block is yielded to with the exception to filter.
|
200
|
+
#
|
201
|
+
# Return the new block or the existing filter Proc if no block is passed.
|
202
|
+
#
|
203
|
+
# @api public
|
204
|
+
#
|
205
|
+
def ignore_error_filter(&block)
|
206
|
+
if block
|
207
|
+
Mmtrix::Agent::ErrorCollector.ignore_error_filter = block
|
208
|
+
else
|
209
|
+
Mmtrix::Agent::ErrorCollector.ignore_error_filter
|
210
|
+
end
|
211
|
+
end
|
212
|
+
|
213
|
+
# Notice the error with the given available options:
|
214
|
+
#
|
215
|
+
# * <tt>:uri</tt> => Request path, minus request params or query string
|
216
|
+
# * <tt>:metric</tt> => The metric name associated with the transaction
|
217
|
+
# * <tt>:custom_params</tt> => Custom parameters
|
218
|
+
#
|
219
|
+
# Previous versions of the agent allowed passing :request_params but
|
220
|
+
# those are now ignored. Associate the request with the enclosing
|
221
|
+
# transaction, or record additional information as custom attributes.
|
222
|
+
# Anything left over is treated as custom params.
|
223
|
+
#
|
224
|
+
# @api public
|
225
|
+
#
|
226
|
+
def notice_error(exception, options={})
|
227
|
+
Transaction.notice_error(exception, options)
|
228
|
+
nil # don't return a noticed error datastructure. it can only hurt.
|
229
|
+
end
|
230
|
+
|
231
|
+
# @!endgroup
|
232
|
+
|
233
|
+
# @!group Recording custom Insights events
|
234
|
+
|
235
|
+
# Record a custom event to be sent to Mmtrix Insights.
|
236
|
+
# The recorded event will be buffered in memory until the next time the
|
237
|
+
# agent sends data to Mmtrix's servers.
|
238
|
+
#
|
239
|
+
# If you want to be able to tie the information recorded via this call back
|
240
|
+
# to the web request or background job that it happened in, you may want to
|
241
|
+
# instead use the add_custom_attributes API call to attach attributes to
|
242
|
+
# the Transaction event that will automatically be generated for the
|
243
|
+
# request.
|
244
|
+
#
|
245
|
+
# A timestamp will be automatically added to the recorded event when this
|
246
|
+
# method is called.
|
247
|
+
#
|
248
|
+
# @param [Symbol or String] event_type The name of the event type to record. Event
|
249
|
+
# types must consist of only alphanumeric
|
250
|
+
# characters, '_', ':', or ' '.
|
251
|
+
#
|
252
|
+
# @param [Hash] event_attrs A Hash of attributes to be attached to the event.
|
253
|
+
# Keys should be strings or symbols, and values
|
254
|
+
# may be strings, symbols, numeric values or
|
255
|
+
# booleans.
|
256
|
+
#
|
257
|
+
# @api public
|
258
|
+
#
|
259
|
+
def record_custom_event(event_type, event_attrs)
|
260
|
+
if agent && Mmtrix::Agent.config[:'custom_insights_events.enabled']
|
261
|
+
agent.custom_event_aggregator.record(event_type, event_attrs)
|
262
|
+
end
|
263
|
+
nil
|
264
|
+
end
|
265
|
+
|
266
|
+
# @!endgroup
|
267
|
+
|
268
|
+
# @!group Manual agent configuration and startup/shutdown
|
269
|
+
|
270
|
+
# Call this to manually start the Agent in situations where the Agent does
|
271
|
+
# not auto-start.
|
272
|
+
#
|
273
|
+
# When the app environment loads, so does the Agent. However, the
|
274
|
+
# Agent will only connect to the service if a web front-end is found. If
|
275
|
+
# you want to selectively monitor ruby processes that don't use
|
276
|
+
# web plugins, then call this method in your code and the Agent
|
277
|
+
# will fire up and start reporting to the service.
|
278
|
+
#
|
279
|
+
# Options are passed in as overrides for values in the
|
280
|
+
# mmtrix.yml, such as app_name. In addition, the option +log+
|
281
|
+
# will take a logger that will be used instead of the standard
|
282
|
+
# file logger. The setting for the mmtrix.yml section to use
|
283
|
+
# (ie, RAILS_ENV) can be overridden with an :env argument.
|
284
|
+
#
|
285
|
+
# @api public
|
286
|
+
#
|
287
|
+
def manual_start(options={})
|
288
|
+
raise "Options must be a hash" unless Hash === options
|
289
|
+
if options[:start_channel_listener]
|
290
|
+
Mmtrix::Agent::PipeChannelManager.listener.start
|
291
|
+
end
|
292
|
+
Mmtrix::Control.instance.init_plugin({ :agent_enabled => true, :sync_startup => true }.merge(options))
|
293
|
+
end
|
294
|
+
|
295
|
+
# Register this method as a callback for processes that fork
|
296
|
+
# jobs.
|
297
|
+
#
|
298
|
+
# If the master/parent connects to the agent prior to forking the
|
299
|
+
# agent in the forked process will use that agent_run. Otherwise
|
300
|
+
# the forked process will establish a new connection with the
|
301
|
+
# server.
|
302
|
+
#
|
303
|
+
# Use this especially when you fork the process to run background
|
304
|
+
# jobs or other work. If you are doing this with a web dispatcher
|
305
|
+
# that forks worker processes then you will need to force the
|
306
|
+
# agent to reconnect, which it won't do by default. Passenger and
|
307
|
+
# Rainbows and Unicorn are already handled, nothing special needed for them.
|
308
|
+
#
|
309
|
+
# Options:
|
310
|
+
# * <tt>:force_reconnect => true</tt> to force the spawned process to
|
311
|
+
# establish a new connection, such as when forking a long running process.
|
312
|
+
# The default is false--it will only connect to the server if the parent
|
313
|
+
# had not connected.
|
314
|
+
# * <tt>:keep_retrying => false</tt> if we try to initiate a new
|
315
|
+
# connection, this tells me to only try it once so this method returns
|
316
|
+
# quickly if there is some kind of latency with the server.
|
317
|
+
#
|
318
|
+
# @api public
|
319
|
+
#
|
320
|
+
def after_fork(options={})
|
321
|
+
agent.after_fork(options) if agent
|
322
|
+
end
|
323
|
+
|
324
|
+
# Shutdown the agent. Call this before exiting. Sends any queued data
|
325
|
+
# and kills the background thread.
|
326
|
+
#
|
327
|
+
# @param options [Hash] Unused options Hash, for back compatibility only
|
328
|
+
#
|
329
|
+
# @api public
|
330
|
+
#
|
331
|
+
def shutdown(options={})
|
332
|
+
agent.shutdown if agent
|
333
|
+
end
|
334
|
+
|
335
|
+
# Clear out any data the agent has buffered but has not yet transmitted
|
336
|
+
# to the collector.
|
337
|
+
#
|
338
|
+
# @api public
|
339
|
+
def drop_buffered_data
|
340
|
+
agent.drop_buffered_data if agent
|
341
|
+
end
|
342
|
+
|
343
|
+
# Add instrumentation files to the agent. The argument should be
|
344
|
+
# a glob matching ruby scripts which will be executed at the time
|
345
|
+
# instrumentation is loaded. Since instrumentation is not loaded
|
346
|
+
# when the agent is not running it's better to use this method to
|
347
|
+
# register instrumentation than just loading the files directly,
|
348
|
+
# although that probably also works.
|
349
|
+
#
|
350
|
+
# @api public
|
351
|
+
#
|
352
|
+
def add_instrumentation(file_pattern)
|
353
|
+
Mmtrix::Control.instance.add_instrumentation file_pattern
|
354
|
+
end
|
355
|
+
|
356
|
+
# Require agent testing helper methods
|
357
|
+
#
|
358
|
+
# @api public
|
359
|
+
def require_test_helper
|
360
|
+
path = File.join(__FILE__, '..', '..', '..', 'test', 'agent_helper')
|
361
|
+
require File.expand_path(path)
|
362
|
+
end
|
363
|
+
|
364
|
+
# This method sets the block sent to this method as a sql
|
365
|
+
# obfuscator. The block will be called with a single String SQL
|
366
|
+
# statement to obfuscate. The method must return the obfuscated
|
367
|
+
# String SQL. If chaining of obfuscators is required, use type =
|
368
|
+
# :before or :after
|
369
|
+
#
|
370
|
+
# type = :before, :replace, :after
|
371
|
+
#
|
372
|
+
# Example:
|
373
|
+
#
|
374
|
+
# Mmtrix::Agent.set_sql_obfuscator(:replace) do |sql|
|
375
|
+
# my_obfuscator(sql)
|
376
|
+
# end
|
377
|
+
#
|
378
|
+
# @api public
|
379
|
+
#
|
380
|
+
def set_sql_obfuscator(type = :replace, &block)
|
381
|
+
Mmtrix::Agent::Database.set_sql_obfuscator(type, &block)
|
382
|
+
end
|
383
|
+
|
384
|
+
# @!endgroup
|
385
|
+
|
386
|
+
# @!group Ignoring or excluding data
|
387
|
+
|
388
|
+
# This method disables the recording of the current transaction. No metrics,
|
389
|
+
# traced errors, transaction traces, Insights events, slow SQL traces,
|
390
|
+
# or RUM injection will happen for this transaction.
|
391
|
+
#
|
392
|
+
# @api public
|
393
|
+
#
|
394
|
+
def ignore_transaction
|
395
|
+
txn = Mmtrix::Agent::Transaction.tl_current
|
396
|
+
txn.ignore! if txn
|
397
|
+
end
|
398
|
+
|
399
|
+
# This method disables the recording of Apdex metrics in the current
|
400
|
+
# transaction.
|
401
|
+
#
|
402
|
+
# @api public
|
403
|
+
#
|
404
|
+
def ignore_apdex
|
405
|
+
txn = Mmtrix::Agent::Transaction.tl_current
|
406
|
+
txn.ignore_apdex! if txn
|
407
|
+
end
|
408
|
+
|
409
|
+
# This method disables browser monitoring javascript injection in the
|
410
|
+
# current transaction.
|
411
|
+
#
|
412
|
+
# @api public
|
413
|
+
#
|
414
|
+
def ignore_enduser
|
415
|
+
txn = Mmtrix::Agent::Transaction.tl_current
|
416
|
+
txn.ignore_enduser! if txn
|
417
|
+
end
|
418
|
+
|
419
|
+
# Yield to the block without collecting any metrics or traces in
|
420
|
+
# any of the subsequent calls. If executed recursively, will keep
|
421
|
+
# track of the first entry point and turn on tracing again after
|
422
|
+
# leaving that block. This uses the thread local TransactionState.
|
423
|
+
#
|
424
|
+
# @api public
|
425
|
+
#
|
426
|
+
def disable_all_tracing
|
427
|
+
return yield unless agent
|
428
|
+
|
429
|
+
begin
|
430
|
+
agent.push_trace_execution_flag(false)
|
431
|
+
yield
|
432
|
+
ensure
|
433
|
+
agent.pop_trace_execution_flag
|
434
|
+
end
|
435
|
+
end
|
436
|
+
|
437
|
+
# This method disables the recording of transaction traces in the given
|
438
|
+
# block. See also #disable_all_tracing
|
439
|
+
#
|
440
|
+
# @api public
|
441
|
+
#
|
442
|
+
def disable_transaction_tracing
|
443
|
+
return yield unless agent
|
444
|
+
|
445
|
+
state = agent.set_record_tt(false)
|
446
|
+
begin
|
447
|
+
yield
|
448
|
+
ensure
|
449
|
+
agent.set_record_tt(state)
|
450
|
+
end
|
451
|
+
end
|
452
|
+
|
453
|
+
# This method sets the state of sql recording in the transaction
|
454
|
+
# sampler feature. Within the given block, no sql will be recorded
|
455
|
+
#
|
456
|
+
# usage:
|
457
|
+
#
|
458
|
+
# Mmtrix::Agent.disable_sql_recording do
|
459
|
+
# ...
|
460
|
+
# end
|
461
|
+
#
|
462
|
+
# @api public
|
463
|
+
#
|
464
|
+
def disable_sql_recording
|
465
|
+
return yield unless agent
|
466
|
+
|
467
|
+
state = agent.set_record_sql(false)
|
468
|
+
begin
|
469
|
+
yield
|
470
|
+
ensure
|
471
|
+
agent.set_record_sql(state)
|
472
|
+
end
|
473
|
+
end
|
474
|
+
|
475
|
+
# @!endgroup
|
476
|
+
|
477
|
+
# Check to see if we are capturing metrics currently on this thread.
|
478
|
+
def tl_is_execution_traced?
|
479
|
+
Mmtrix::Agent::TransactionState.tl_get.is_execution_traced?
|
480
|
+
end
|
481
|
+
|
482
|
+
# helper method to check the thread local to determine whether the
|
483
|
+
# transaction in progress is traced or not
|
484
|
+
def tl_is_transaction_traced?
|
485
|
+
Mmtrix::Agent::TransactionState.tl_get.is_transaction_traced?
|
486
|
+
end
|
487
|
+
|
488
|
+
# helper method to check the thread local to determine whether sql
|
489
|
+
# is being recorded or not
|
490
|
+
def tl_is_sql_recorded?
|
491
|
+
Mmtrix::Agent::TransactionState.tl_get.is_sql_recorded?
|
492
|
+
end
|
493
|
+
|
494
|
+
# @!group Adding custom attributes to traces
|
495
|
+
|
496
|
+
# Add attributes to the transaction trace, Insights Transaction event, and
|
497
|
+
# any traced errors recorded for the current transaction.
|
498
|
+
#
|
499
|
+
# If Browser Monitoring is enabled, and the
|
500
|
+
# browser_monitoring.attributes.enabled configuration setting is true,
|
501
|
+
# these custom attributes will also be present in the script injected into
|
502
|
+
# the response body, making them available on Insights PageView events.
|
503
|
+
#
|
504
|
+
# @api public
|
505
|
+
#
|
506
|
+
def add_custom_attributes(params) #THREAD_LOCAL_ACCESS
|
507
|
+
if params.is_a? Hash
|
508
|
+
txn = Transaction.tl_current
|
509
|
+
txn.add_custom_attributes(params) if txn
|
510
|
+
else
|
511
|
+
::Mmtrix::Agent.logger.warn("Bad argument passed to #add_custom_attributes. Expected Hash but got #{params.class}")
|
512
|
+
end
|
513
|
+
end
|
514
|
+
|
515
|
+
# @!endgroup
|
516
|
+
|
517
|
+
# @!group Transaction naming
|
518
|
+
|
519
|
+
# Set the name of the current running transaction. The agent will
|
520
|
+
# apply a reasonable default based on framework routing, but in
|
521
|
+
# cases where this is insufficient, this can be used to manually
|
522
|
+
# control the name of the transaction.
|
523
|
+
# The category of transaction can be specified via the +:category+ option:
|
524
|
+
#
|
525
|
+
# * <tt>:category => :controller</tt> indicates that this is a
|
526
|
+
# controller action and will appear with all the other actions.
|
527
|
+
# * <tt>:category => :task</tt> indicates that this is a
|
528
|
+
# background task and will show up in Mmtrix with other background
|
529
|
+
# tasks instead of in the controllers list
|
530
|
+
# * <tt>:category => :middleware</tt> if you are instrumenting a rack
|
531
|
+
# middleware call. The <tt>:name</tt> is optional, useful if you
|
532
|
+
# have more than one potential transaction in the #call.
|
533
|
+
# * <tt>:category => :uri</tt> indicates that this is a
|
534
|
+
# web transaction whose name is a normalized URI, where 'normalized'
|
535
|
+
# means the URI does not have any elements with data in them such
|
536
|
+
# as in many REST URIs.
|
537
|
+
#
|
538
|
+
# The default category is the same as the running transaction.
|
539
|
+
#
|
540
|
+
# @api public
|
541
|
+
#
|
542
|
+
def set_transaction_name(name, options={})
|
543
|
+
Transaction.set_overriding_transaction_name(name, options[:category])
|
544
|
+
end
|
545
|
+
|
546
|
+
# Get the name of the current running transaction. This is useful if you
|
547
|
+
# want to modify the default name.
|
548
|
+
#
|
549
|
+
# @api public
|
550
|
+
#
|
551
|
+
def get_transaction_name #THREAD_LOCAL_ACCESS
|
552
|
+
txn = Transaction.tl_current
|
553
|
+
if txn
|
554
|
+
namer = Instrumentation::ControllerInstrumentation::TransactionNamer
|
555
|
+
txn.best_name.sub(Regexp.new("\\A#{Regexp.escape(namer.prefix_for_category(txn))}"), '')
|
556
|
+
end
|
557
|
+
end
|
558
|
+
|
559
|
+
# @!endgroup
|
560
|
+
|
561
|
+
# Yield to a block that is run with a database metric name context. This means
|
562
|
+
# the Database instrumentation will use this for the metric name if it does not
|
563
|
+
# otherwise know about a model. This is re-entrant.
|
564
|
+
#
|
565
|
+
# @param [String,Class,#to_s] model the DB model class
|
566
|
+
#
|
567
|
+
# @param [String] method the name of the finder method or other method to
|
568
|
+
# identify the operation with.
|
569
|
+
#
|
570
|
+
def with_database_metric_name(model, method = nil, product = nil, &block) #THREAD_LOCAL_ACCESS
|
571
|
+
if txn = Transaction.tl_current
|
572
|
+
txn.with_database_metric_name(model, method, product, &block)
|
573
|
+
else
|
574
|
+
yield
|
575
|
+
end
|
576
|
+
end
|
577
|
+
|
578
|
+
# Subscribe to events of +event_type+, calling the given +handler+
|
579
|
+
# when one is sent.
|
580
|
+
def subscribe(event_type, &handler)
|
581
|
+
agent.events.subscribe( event_type, &handler )
|
582
|
+
end
|
583
|
+
|
584
|
+
# Fire an event of the specified +event_type+, passing it an the given +args+
|
585
|
+
# to any registered handlers.
|
586
|
+
def notify(event_type, *args)
|
587
|
+
agent.events.notify( event_type, *args )
|
588
|
+
rescue
|
589
|
+
Mmtrix::Agent.logger.debug "Ignoring exception during %p event notification" % [event_type]
|
590
|
+
end
|
591
|
+
|
592
|
+
# @!group Manual browser monitoring configuration
|
593
|
+
|
594
|
+
# This method returns a string suitable for inclusion in a page - known as
|
595
|
+
# 'manual instrumentation' for Real User Monitoring. Can return either a
|
596
|
+
# script tag with associated javascript, or in the case of disabled Real
|
597
|
+
# User Monitoring, an empty string
|
598
|
+
#
|
599
|
+
# This is the header string - it should be placed as high in the page as is
|
600
|
+
# reasonably possible - that is, before any style or javascript inclusions,
|
601
|
+
# but after any header-related meta tags
|
602
|
+
#
|
603
|
+
# In previous agents there was a corresponding footer required, but all the
|
604
|
+
# work is now done by this single method.
|
605
|
+
#
|
606
|
+
# @api public
|
607
|
+
#
|
608
|
+
def browser_timing_header
|
609
|
+
return "" unless agent
|
610
|
+
agent.javascript_instrumentor.browser_timing_header
|
611
|
+
end
|
612
|
+
|
613
|
+
# @!endgroup
|
614
|
+
|
615
|
+
# @!group Deprecated methods
|
616
|
+
|
617
|
+
# In previous agent releases, this method was required for manual RUM
|
618
|
+
# instrumentation. That work is now all done by the browser_timing_header
|
619
|
+
# method, but this is left for compatibility.
|
620
|
+
#
|
621
|
+
# @api public
|
622
|
+
# @deprecated
|
623
|
+
#
|
624
|
+
def browser_timing_footer
|
625
|
+
""
|
626
|
+
end
|
627
|
+
|
628
|
+
ADD_CUSTOM_ATTRIBUTES = "Mmtrix::Agent.add_custom_attributes".freeze
|
629
|
+
ADD_CUSTOM_PARAMETERS = "Mmtrix::Agent.add_custom_parameters".freeze
|
630
|
+
ADD_REQUEST_PARAMETERS = "Mmtrix::Agent.add_request_parameters".freeze
|
631
|
+
SET_USER_ATTRIBUTES = "Mmtrix::Agent.set_user_attributes".freeze
|
632
|
+
|
633
|
+
# Deprecated. Use add_custom_attributes instead.
|
634
|
+
#
|
635
|
+
# @deprecated
|
636
|
+
# @api public
|
637
|
+
#
|
638
|
+
def add_custom_parameters(*args)
|
639
|
+
Mmtrix::Agent::Deprecator.deprecate(ADD_CUSTOM_PARAMETERS, ADD_CUSTOM_ATTRIBUTES)
|
640
|
+
add_custom_attributes(*args)
|
641
|
+
end
|
642
|
+
|
643
|
+
# Deprecated. Use add_custom_attributes instead.
|
644
|
+
#
|
645
|
+
# @deprecated
|
646
|
+
# @api public
|
647
|
+
#
|
648
|
+
def add_request_parameters(*args)
|
649
|
+
Mmtrix::Agent::Deprecator.deprecate(ADD_REQUEST_PARAMETERS, ADD_CUSTOM_ATTRIBUTES)
|
650
|
+
add_custom_attributes(*args)
|
651
|
+
end
|
652
|
+
|
653
|
+
# Deprecated. Use add_custom_attributes instead.
|
654
|
+
#
|
655
|
+
# @deprecated
|
656
|
+
# @api public
|
657
|
+
#
|
658
|
+
def set_user_attributes(*args)
|
659
|
+
Mmtrix::Agent::Deprecator.deprecate(SET_USER_ATTRIBUTES, ADD_CUSTOM_ATTRIBUTES)
|
660
|
+
add_custom_attributes(*args)
|
661
|
+
end
|
662
|
+
|
663
|
+
# Get or create a statistics gatherer that will aggregate numerical data
|
664
|
+
# under a metric name.
|
665
|
+
#
|
666
|
+
# +metric_name+ should follow a slash separated path convention. Application
|
667
|
+
# specific metrics should begin with "Custom/".
|
668
|
+
#
|
669
|
+
# Return a Mmtrix::Agent::Stats that accepts data
|
670
|
+
# via calls to add_data_point(value).
|
671
|
+
#
|
672
|
+
# This method is deprecated in favor of record_metric and increment_metric,
|
673
|
+
# and is not thread-safe.
|
674
|
+
#
|
675
|
+
# @api public
|
676
|
+
# @deprecated
|
677
|
+
#
|
678
|
+
def get_stats(metric_name, use_scope=false)
|
679
|
+
return unless agent
|
680
|
+
agent.stats_engine.get_stats(metric_name, use_scope)
|
681
|
+
end
|
682
|
+
|
683
|
+
alias get_stats_no_scope get_stats
|
684
|
+
|
685
|
+
# Deprecated in favor of drop_buffered_data
|
686
|
+
#
|
687
|
+
# @api public
|
688
|
+
# @deprecated
|
689
|
+
def reset_stats; drop_buffered_data; end
|
690
|
+
|
691
|
+
# Cancel the collection of the current transaction in progress, if
|
692
|
+
# any. Only affects the transaction started on this thread once
|
693
|
+
# it has started and before it has completed.
|
694
|
+
#
|
695
|
+
# This method has been deprecated in favor of ignore_transaction,
|
696
|
+
# which does what people expect this method to do.
|
697
|
+
#
|
698
|
+
# @api public
|
699
|
+
# @deprecated
|
700
|
+
#
|
701
|
+
def abort_transaction!
|
702
|
+
Transaction.abort_transaction!
|
703
|
+
end
|
704
|
+
|
705
|
+
# Remove after 5/9/15
|
706
|
+
def record_transaction(*args)
|
707
|
+
Mmtrix::Agent.logger.warn('This method has been deprecated, please see https://docs.mmtrix.com/docs/ruby/ruby-agent-api for current API documentation.')
|
708
|
+
end
|
709
|
+
|
710
|
+
# @!endgroup
|
711
|
+
|
712
|
+
def_delegator :'Mmtrix::Agent::PipeChannelManager', :register_report_channel
|
713
|
+
end
|
714
|
+
end
|