newrelic_rpm 4.0.0.332 → 6.13.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1193) hide show
  1. checksums.yaml +5 -5
  2. data/.github/ISSUE_TEMPLATE/bug_report.md +31 -0
  3. data/.github/ISSUE_TEMPLATE/config.yml +5 -0
  4. data/.github/ISSUE_TEMPLATE/feature_request.md +24 -0
  5. data/.github/actions/annotate/README.md +79 -0
  6. data/.github/actions/annotate/action.yml +6 -0
  7. data/.github/actions/annotate/dist/index.js +433 -0
  8. data/.github/actions/annotate/index.js +25 -0
  9. data/.github/actions/annotate/package-lock.json +172 -0
  10. data/.github/actions/annotate/package.json +30 -0
  11. data/.github/actions/annotate/pre-commit +5 -0
  12. data/.github/actions/build-ruby/README.md +79 -0
  13. data/.github/actions/build-ruby/action.yml +15 -0
  14. data/.github/actions/build-ruby/dist/index.js +52683 -0
  15. data/.github/actions/build-ruby/index.js +514 -0
  16. data/.github/actions/build-ruby/package-lock.json +581 -0
  17. data/.github/actions/build-ruby/package.json +32 -0
  18. data/.github/actions/build-ruby/pre-commit +5 -0
  19. data/.github/pull_request_template.md +16 -0
  20. data/.github/workflows/ci.yml +212 -0
  21. data/.github/workflows/pr_review_checklist.yml +22 -0
  22. data/.github/workflows/release.yml +78 -0
  23. data/.github/workflows/scripts/rubygems-authenticate.py +13 -0
  24. data/.github/workflows/scripts/rubygems-publish.rb +32 -0
  25. data/.github/workflows/snyk.yml +27 -0
  26. data/.github/workflows/stale.yml +21 -0
  27. data/.gitignore +9 -0
  28. data/.yardopts +7 -2
  29. data/CHANGELOG.md +1130 -0
  30. data/CONTRIBUTING.md +106 -19
  31. data/Gemfile +6 -2
  32. data/Guardfile +18 -1
  33. data/LICENSE +208 -64
  34. data/README.md +75 -135
  35. data/ROADMAP.md +24 -0
  36. data/Rakefile +2 -0
  37. data/THIRD_PARTY_NOTICES.md +213 -0
  38. data/bin/nrdebug +1 -1
  39. data/config.dot +3 -12
  40. data/init.rb +1 -1
  41. data/install.rb +1 -1
  42. data/lib/new_relic/agent.rb +189 -35
  43. data/lib/new_relic/agent/adaptive_sampler.rb +104 -0
  44. data/lib/new_relic/agent/agent.rb +204 -186
  45. data/lib/new_relic/agent/agent_logger.rb +5 -1
  46. data/lib/new_relic/agent/attribute_filter.rb +85 -28
  47. data/lib/new_relic/agent/attribute_processing.rb +1 -1
  48. data/lib/new_relic/agent/attributes.rb +152 -0
  49. data/lib/new_relic/agent/audit_logger.rb +1 -1
  50. data/lib/new_relic/agent/autostart.rb +20 -15
  51. data/lib/new_relic/agent/chained_call.rb +1 -1
  52. data/lib/new_relic/agent/commands/agent_command.rb +1 -1
  53. data/lib/new_relic/agent/commands/agent_command_router.rb +3 -22
  54. data/lib/new_relic/agent/commands/thread_profiler_session.rb +1 -1
  55. data/lib/new_relic/agent/configuration.rb +1 -1
  56. data/lib/new_relic/agent/configuration/default_source.rb +436 -96
  57. data/lib/new_relic/agent/configuration/dotted_hash.rb +1 -1
  58. data/lib/new_relic/agent/configuration/environment_source.rb +5 -3
  59. data/lib/new_relic/agent/configuration/event_harvest_config.rb +45 -0
  60. data/lib/new_relic/agent/configuration/high_security_source.rb +2 -3
  61. data/lib/new_relic/agent/configuration/manager.rb +54 -43
  62. data/lib/new_relic/agent/configuration/manual_source.rb +1 -1
  63. data/lib/new_relic/agent/configuration/mask_defaults.rb +1 -1
  64. data/lib/new_relic/agent/configuration/security_policy_source.rb +238 -0
  65. data/lib/new_relic/agent/configuration/server_source.rb +46 -5
  66. data/lib/new_relic/agent/configuration/yaml_source.rb +20 -17
  67. data/lib/new_relic/agent/connect/request_builder.rb +61 -0
  68. data/lib/new_relic/agent/connect/response_handler.rb +61 -0
  69. data/lib/new_relic/agent/custom_event_aggregator.rb +17 -6
  70. data/lib/new_relic/agent/database.rb +32 -7
  71. data/lib/new_relic/agent/database/explain_plan_helpers.rb +12 -1
  72. data/lib/new_relic/agent/database/obfuscation_helpers.rb +2 -2
  73. data/lib/new_relic/agent/database/obfuscator.rb +1 -1
  74. data/lib/new_relic/agent/database/postgres_explain_obfuscator.rb +1 -1
  75. data/lib/new_relic/agent/datastores.rb +32 -15
  76. data/lib/new_relic/agent/datastores/metric_helper.rb +2 -3
  77. data/lib/new_relic/agent/datastores/mongo.rb +2 -2
  78. data/lib/new_relic/agent/datastores/mongo/event_formatter.rb +3 -3
  79. data/lib/new_relic/agent/datastores/mongo/metric_translator.rb +1 -1
  80. data/lib/new_relic/agent/datastores/mongo/obfuscator.rb +9 -9
  81. data/lib/new_relic/agent/datastores/mongo/statement_formatter.rb +1 -1
  82. data/lib/new_relic/agent/datastores/redis.rb +1 -1
  83. data/lib/new_relic/agent/deprecator.rb +1 -1
  84. data/lib/new_relic/agent/distributed_tracing.rb +216 -0
  85. data/lib/new_relic/agent/distributed_tracing/cross_app_payload.rb +44 -0
  86. data/lib/new_relic/agent/distributed_tracing/cross_app_tracing.rb +248 -0
  87. data/lib/new_relic/agent/distributed_tracing/distributed_trace_attributes.rb +84 -0
  88. data/lib/new_relic/agent/distributed_tracing/distributed_trace_metrics.rb +75 -0
  89. data/lib/new_relic/agent/distributed_tracing/distributed_trace_payload.rb +165 -0
  90. data/lib/new_relic/agent/distributed_tracing/distributed_trace_transport_type.rb +39 -0
  91. data/lib/new_relic/agent/distributed_tracing/trace_context.rb +246 -0
  92. data/lib/new_relic/agent/distributed_tracing/trace_context_payload.rb +126 -0
  93. data/lib/new_relic/agent/encoding_normalizer.rb +1 -1
  94. data/lib/new_relic/agent/error_collector.rb +55 -24
  95. data/lib/new_relic/agent/error_event_aggregator.rb +14 -7
  96. data/lib/new_relic/agent/error_trace_aggregator.rb +2 -1
  97. data/lib/new_relic/agent/event_aggregator.rb +34 -15
  98. data/lib/new_relic/agent/event_buffer.rb +1 -1
  99. data/lib/new_relic/agent/event_listener.rb +1 -1
  100. data/lib/new_relic/agent/event_loop.rb +1 -1
  101. data/lib/new_relic/agent/external.rb +143 -0
  102. data/lib/new_relic/agent/guid_generator.rb +28 -0
  103. data/lib/new_relic/agent/harvester.rb +1 -1
  104. data/lib/new_relic/agent/heap.rb +140 -0
  105. data/lib/new_relic/agent/hostname.rb +16 -2
  106. data/lib/new_relic/agent/http_clients/abstract.rb +82 -0
  107. data/lib/new_relic/agent/http_clients/curb_wrappers.rb +26 -19
  108. data/lib/new_relic/agent/http_clients/excon_wrappers.rb +31 -12
  109. data/lib/new_relic/agent/http_clients/http_rb_wrappers.rb +20 -22
  110. data/lib/new_relic/agent/http_clients/httpclient_wrappers.rb +13 -12
  111. data/lib/new_relic/agent/http_clients/net_http_wrappers.rb +23 -7
  112. data/lib/new_relic/agent/http_clients/typhoeus_wrappers.rb +8 -8
  113. data/lib/new_relic/agent/http_clients/uri_util.rb +23 -17
  114. data/lib/new_relic/agent/instrumentation.rb +1 -1
  115. data/lib/new_relic/agent/instrumentation/action_cable_subscriber.rb +26 -43
  116. data/lib/new_relic/agent/instrumentation/action_controller_subscriber.rb +56 -75
  117. data/lib/new_relic/agent/instrumentation/action_view_subscriber.rb +82 -56
  118. data/lib/new_relic/agent/instrumentation/active_job.rb +21 -15
  119. data/lib/new_relic/agent/instrumentation/active_merchant.rb +1 -1
  120. data/lib/new_relic/agent/instrumentation/active_record.rb +94 -33
  121. data/lib/new_relic/agent/instrumentation/active_record_helper.rb +87 -25
  122. data/lib/new_relic/agent/instrumentation/active_record_notifications.rb +168 -0
  123. data/lib/new_relic/agent/instrumentation/active_record_prepend.rb +132 -0
  124. data/lib/new_relic/agent/instrumentation/active_record_subscriber.rb +70 -58
  125. data/lib/new_relic/agent/instrumentation/active_storage.rb +23 -0
  126. data/lib/new_relic/agent/instrumentation/active_storage_subscriber.rb +63 -0
  127. data/lib/new_relic/agent/instrumentation/acts_as_solr.rb +26 -8
  128. data/lib/new_relic/agent/instrumentation/authlogic.rb +1 -1
  129. data/lib/new_relic/agent/instrumentation/bunny.rb +219 -0
  130. data/lib/new_relic/agent/instrumentation/controller_instrumentation.rb +27 -16
  131. data/lib/new_relic/agent/instrumentation/curb.rb +126 -37
  132. data/lib/new_relic/agent/instrumentation/data_mapper.rb +16 -7
  133. data/lib/new_relic/agent/instrumentation/delayed_job_instrumentation.rb +61 -25
  134. data/lib/new_relic/agent/instrumentation/excon.rb +2 -2
  135. data/lib/new_relic/agent/instrumentation/excon/connection.rb +13 -7
  136. data/lib/new_relic/agent/instrumentation/excon/middleware.rb +9 -5
  137. data/lib/new_relic/agent/instrumentation/grape.rb +46 -35
  138. data/lib/new_relic/agent/instrumentation/http.rb +12 -6
  139. data/lib/new_relic/agent/instrumentation/httpclient.rb +12 -7
  140. data/lib/new_relic/agent/instrumentation/ignore_actions.rb +1 -1
  141. data/lib/new_relic/agent/instrumentation/memcache.rb +9 -4
  142. data/lib/new_relic/agent/instrumentation/memcache/dalli.rb +15 -8
  143. data/lib/new_relic/agent/instrumentation/merb/controller.rb +1 -1
  144. data/lib/new_relic/agent/instrumentation/merb/errors.rb +1 -1
  145. data/lib/new_relic/agent/instrumentation/middleware_proxy.rb +13 -5
  146. data/lib/new_relic/agent/instrumentation/middleware_tracing.rb +20 -11
  147. data/lib/new_relic/agent/instrumentation/mongo.rb +21 -10
  148. data/lib/new_relic/agent/instrumentation/mongodb_command_subscriber.rb +43 -6
  149. data/lib/new_relic/agent/instrumentation/net.rb +60 -20
  150. data/lib/new_relic/agent/instrumentation/notifications_subscriber.rb +100 -0
  151. data/lib/new_relic/agent/instrumentation/padrino.rb +40 -16
  152. data/lib/new_relic/agent/instrumentation/passenger_instrumentation.rb +1 -1
  153. data/lib/new_relic/agent/instrumentation/queue_time.rb +1 -1
  154. data/lib/new_relic/agent/instrumentation/rack.rb +36 -13
  155. data/lib/new_relic/agent/instrumentation/rails/action_controller.rb +2 -2
  156. data/lib/new_relic/agent/instrumentation/rails/action_web_service.rb +1 -1
  157. data/lib/new_relic/agent/instrumentation/rails3/action_controller.rb +6 -4
  158. data/lib/new_relic/agent/instrumentation/rails_middleware.rb +2 -2
  159. data/lib/new_relic/agent/instrumentation/{rails5 → rails_notifications}/action_cable.rb +11 -5
  160. data/lib/new_relic/agent/instrumentation/rails_notifications/action_controller.rb +33 -0
  161. data/lib/new_relic/agent/instrumentation/{rails4 → rails_notifications}/action_view.rb +6 -4
  162. data/lib/new_relic/agent/instrumentation/rainbows_instrumentation.rb +1 -1
  163. data/lib/new_relic/agent/instrumentation/rake.rb +58 -22
  164. data/lib/new_relic/agent/instrumentation/redis.rb +141 -41
  165. data/lib/new_relic/agent/instrumentation/resque.rb +21 -37
  166. data/lib/new_relic/agent/instrumentation/sequel.rb +2 -3
  167. data/lib/new_relic/agent/instrumentation/sequel_helper.rb +1 -1
  168. data/lib/new_relic/agent/instrumentation/sidekiq.rb +48 -24
  169. data/lib/new_relic/agent/instrumentation/sinatra.rb +62 -23
  170. data/lib/new_relic/agent/instrumentation/sinatra/ignorer.rb +1 -1
  171. data/lib/new_relic/agent/instrumentation/sinatra/transaction_namer.rb +1 -1
  172. data/lib/new_relic/agent/instrumentation/sunspot.rb +1 -1
  173. data/lib/new_relic/agent/instrumentation/typhoeus.rb +67 -26
  174. data/lib/new_relic/agent/internal_agent_error.rb +1 -1
  175. data/lib/new_relic/agent/javascript_instrumentor.rb +19 -16
  176. data/lib/new_relic/agent/log_once.rb +1 -1
  177. data/lib/new_relic/agent/logging.rb +139 -0
  178. data/lib/new_relic/agent/memory_logger.rb +1 -1
  179. data/lib/new_relic/agent/messaging.rb +372 -0
  180. data/lib/new_relic/agent/method_tracer.rb +45 -24
  181. data/lib/new_relic/agent/method_tracer_helpers.rb +10 -63
  182. data/lib/new_relic/agent/monitors.rb +27 -0
  183. data/lib/new_relic/agent/monitors/cross_app_monitor.rb +110 -0
  184. data/lib/new_relic/agent/monitors/distributed_tracing_monitor.rb +27 -0
  185. data/lib/new_relic/agent/{inbound_request_monitor.rb → monitors/inbound_request_monitor.rb} +4 -4
  186. data/lib/new_relic/agent/monitors/synthetics_monitor.rb +56 -0
  187. data/lib/new_relic/agent/new_relic_service.rb +174 -63
  188. data/lib/new_relic/agent/new_relic_service/encoders.rb +1 -1
  189. data/lib/new_relic/agent/new_relic_service/json_marshaller.rb +1 -2
  190. data/lib/new_relic/agent/new_relic_service/marshaller.rb +6 -27
  191. data/lib/new_relic/agent/new_relic_service/security_policy_settings.rb +61 -0
  192. data/lib/new_relic/agent/noticible_error.rb +22 -0
  193. data/lib/new_relic/agent/null_logger.rb +1 -1
  194. data/lib/new_relic/agent/obfuscator.rb +1 -1
  195. data/lib/new_relic/agent/parameter_filtering.rb +19 -6
  196. data/lib/new_relic/agent/payload_metric_mapping.rb +1 -1
  197. data/lib/new_relic/agent/pipe_channel_manager.rb +1 -1
  198. data/lib/new_relic/agent/pipe_service.rb +5 -1
  199. data/lib/new_relic/agent/prepend_supportability.rb +16 -0
  200. data/lib/new_relic/agent/priority_sampled_buffer.rb +95 -0
  201. data/lib/new_relic/agent/range_extensions.rb +47 -0
  202. data/lib/new_relic/agent/rules_engine.rb +1 -1
  203. data/lib/new_relic/agent/rules_engine/replacement_rule.rb +1 -1
  204. data/lib/new_relic/agent/rules_engine/segment_terms_rule.rb +1 -1
  205. data/lib/new_relic/agent/sampler.rb +1 -1
  206. data/lib/new_relic/agent/sampler_collection.rb +1 -1
  207. data/lib/new_relic/agent/samplers/cpu_sampler.rb +4 -3
  208. data/lib/new_relic/agent/samplers/delayed_job_sampler.rb +1 -1
  209. data/lib/new_relic/agent/samplers/memory_sampler.rb +1 -1
  210. data/lib/new_relic/agent/samplers/object_sampler.rb +1 -1
  211. data/lib/new_relic/agent/samplers/vm_sampler.rb +1 -1
  212. data/lib/new_relic/agent/span_event_aggregator.rb +49 -0
  213. data/lib/new_relic/agent/span_event_primitive.rb +206 -0
  214. data/lib/new_relic/agent/sql_sampler.rb +25 -9
  215. data/lib/new_relic/agent/stats.rb +1 -15
  216. data/lib/new_relic/agent/stats_engine.rb +172 -4
  217. data/lib/new_relic/agent/stats_engine/gc_profiler.rb +1 -1
  218. data/lib/new_relic/agent/stats_engine/stats_hash.rb +1 -1
  219. data/lib/new_relic/agent/supported_versions.rb +15 -14
  220. data/lib/new_relic/agent/synthetics_event_aggregator.rb +6 -13
  221. data/lib/new_relic/agent/system_info.rb +52 -8
  222. data/lib/new_relic/agent/threading/agent_thread.rb +6 -4
  223. data/lib/new_relic/agent/threading/backtrace_node.rb +1 -1
  224. data/lib/new_relic/agent/threading/backtrace_service.rb +4 -4
  225. data/lib/new_relic/agent/threading/thread_profile.rb +10 -24
  226. data/lib/new_relic/agent/timestamp_sampled_buffer.rb +19 -0
  227. data/lib/new_relic/agent/tracer.rb +509 -0
  228. data/lib/new_relic/agent/transaction.rb +270 -295
  229. data/lib/new_relic/agent/transaction/abstract_segment.rb +204 -20
  230. data/lib/new_relic/agent/transaction/datastore_segment.rb +55 -26
  231. data/lib/new_relic/agent/transaction/distributed_tracer.rb +171 -0
  232. data/lib/new_relic/agent/transaction/distributed_tracing.rb +173 -0
  233. data/lib/new_relic/agent/transaction/external_request_segment.rb +159 -36
  234. data/lib/new_relic/agent/transaction/message_broker_segment.rb +103 -0
  235. data/lib/new_relic/agent/transaction/request_attributes.rb +6 -14
  236. data/lib/new_relic/agent/transaction/segment.rb +67 -5
  237. data/lib/new_relic/agent/transaction/slowest_sample_buffer.rb +1 -1
  238. data/lib/new_relic/agent/transaction/synthetics_sample_buffer.rb +1 -1
  239. data/lib/new_relic/agent/transaction/trace.rb +35 -34
  240. data/lib/new_relic/agent/transaction/trace_builder.rb +56 -0
  241. data/lib/new_relic/agent/transaction/trace_context.rb +168 -0
  242. data/lib/new_relic/agent/transaction/trace_node.rb +39 -43
  243. data/lib/new_relic/agent/transaction/tracing.rb +42 -45
  244. data/lib/new_relic/agent/transaction/transaction_sample_buffer.rb +1 -1
  245. data/lib/new_relic/agent/transaction_error_primitive.rb +15 -4
  246. data/lib/new_relic/agent/transaction_event_aggregator.rb +9 -4
  247. data/lib/new_relic/agent/transaction_event_primitive.rb +32 -29
  248. data/lib/new_relic/agent/transaction_event_recorder.rb +7 -7
  249. data/lib/new_relic/agent/transaction_metrics.rb +1 -1
  250. data/lib/new_relic/agent/transaction_sampler.rb +16 -196
  251. data/lib/new_relic/agent/transaction_time_aggregator.rb +155 -0
  252. data/lib/new_relic/agent/utilization/aws.rb +18 -0
  253. data/lib/new_relic/agent/utilization/azure.rb +17 -0
  254. data/lib/new_relic/agent/utilization/gcp.rb +35 -0
  255. data/lib/new_relic/agent/utilization/pcf.rb +32 -0
  256. data/lib/new_relic/agent/utilization/vendor.rb +144 -0
  257. data/lib/new_relic/agent/utilization_data.rb +65 -11
  258. data/lib/new_relic/agent/vm.rb +1 -1
  259. data/lib/new_relic/agent/vm/jruby_vm.rb +1 -1
  260. data/lib/new_relic/agent/vm/monotonic_gc_profiler.rb +1 -1
  261. data/lib/new_relic/agent/vm/mri_vm.rb +1 -1
  262. data/lib/new_relic/agent/vm/snapshot.rb +1 -1
  263. data/lib/new_relic/agent/worker_loop.rb +1 -1
  264. data/lib/new_relic/cli/command.rb +1 -1
  265. data/lib/new_relic/cli/commands/deployments.rb +2 -2
  266. data/lib/new_relic/cli/commands/install.rb +4 -3
  267. data/lib/new_relic/coerce.rb +32 -7
  268. data/lib/new_relic/collection_helper.rb +1 -19
  269. data/lib/new_relic/constants.rb +38 -0
  270. data/lib/new_relic/control.rb +1 -1
  271. data/lib/new_relic/control/class_methods.rb +8 -2
  272. data/lib/new_relic/control/frameworks.rb +1 -1
  273. data/lib/new_relic/control/frameworks/external.rb +1 -1
  274. data/lib/new_relic/control/frameworks/merb.rb +1 -1
  275. data/lib/new_relic/control/frameworks/rails.rb +2 -22
  276. data/lib/new_relic/control/frameworks/rails3.rb +2 -2
  277. data/lib/new_relic/control/frameworks/rails4.rb +1 -1
  278. data/lib/new_relic/control/frameworks/{rails5.rb → rails_notifications.rb} +2 -2
  279. data/lib/new_relic/control/frameworks/ruby.rb +3 -3
  280. data/lib/new_relic/control/frameworks/sinatra.rb +1 -1
  281. data/lib/new_relic/control/instance_methods.rb +30 -4
  282. data/lib/new_relic/control/instrumentation.rb +1 -1
  283. data/lib/new_relic/control/server_methods.rb +1 -1
  284. data/lib/new_relic/delayed_job_injection.rb +1 -1
  285. data/lib/new_relic/dependency_detection.rb +5 -5
  286. data/lib/new_relic/environment_report.rb +6 -2
  287. data/lib/new_relic/helper.rb +1 -1
  288. data/lib/new_relic/language_support.rb +1 -1
  289. data/lib/new_relic/latest_changes.rb +4 -4
  290. data/lib/new_relic/local_environment.rb +1 -1
  291. data/lib/new_relic/metric_data.rb +1 -1
  292. data/lib/new_relic/metric_spec.rb +1 -1
  293. data/lib/new_relic/noticed_error.rb +63 -30
  294. data/lib/new_relic/rack.rb +1 -1
  295. data/lib/new_relic/rack/agent_hooks.rb +1 -1
  296. data/lib/new_relic/rack/agent_middleware.rb +2 -2
  297. data/lib/new_relic/rack/browser_monitoring.rb +16 -9
  298. data/lib/new_relic/recipes.rb +1 -1
  299. data/lib/new_relic/recipes/capistrano3.rb +6 -3
  300. data/lib/new_relic/recipes/capistrano_legacy.rb +1 -1
  301. data/lib/new_relic/supportability_helper.rb +82 -0
  302. data/lib/new_relic/version.rb +4 -4
  303. data/lib/newrelic_rpm.rb +2 -2
  304. data/lib/sequel/extensions/newrelic_instrumentation.rb +27 -12
  305. data/lib/sequel/plugins/newrelic_instrumentation.rb +7 -3
  306. data/lib/tasks/all.rb +1 -1
  307. data/lib/tasks/config.rake +1 -2
  308. data/lib/tasks/multiverse.rb +35 -1
  309. data/lib/tasks/newrelic.rb +1 -1
  310. data/lib/tasks/tests.rake +6 -1
  311. data/newrelic.yml +1 -5
  312. data/newrelic_rpm.gemspec +23 -17
  313. data/recipes/newrelic.rb +1 -1
  314. data/test/agent_helper.rb +395 -83
  315. metadata +169 -910
  316. data/.travis.yml +0 -149
  317. data/lib/conditional_vendored_metric_parser.rb +0 -9
  318. data/lib/new_relic/agent/aws_info.rb +0 -90
  319. data/lib/new_relic/agent/busy_calculator.rb +0 -117
  320. data/lib/new_relic/agent/commands/xray_session.rb +0 -55
  321. data/lib/new_relic/agent/commands/xray_session_collection.rb +0 -161
  322. data/lib/new_relic/agent/cross_app_monitor.rb +0 -179
  323. data/lib/new_relic/agent/cross_app_tracing.rb +0 -106
  324. data/lib/new_relic/agent/instrumentation/active_record_4.rb +0 -32
  325. data/lib/new_relic/agent/instrumentation/active_record_5.rb +0 -89
  326. data/lib/new_relic/agent/instrumentation/evented_subscriber.rb +0 -104
  327. data/lib/new_relic/agent/instrumentation/rails4/action_controller.rb +0 -29
  328. data/lib/new_relic/agent/instrumentation/rails5/action_controller.rb +0 -30
  329. data/lib/new_relic/agent/instrumentation/rails5/action_view.rb +0 -25
  330. data/lib/new_relic/agent/instrumentation/rubyprof.rb +0 -26
  331. data/lib/new_relic/agent/sampled_buffer.rb +0 -68
  332. data/lib/new_relic/agent/sized_buffer.rb +0 -23
  333. data/lib/new_relic/agent/stats_engine/metric_stats.rb +0 -188
  334. data/lib/new_relic/agent/synthetics_event_buffer.rb +0 -40
  335. data/lib/new_relic/agent/synthetics_monitor.rb +0 -50
  336. data/lib/new_relic/agent/traced_method_stack.rb +0 -109
  337. data/lib/new_relic/agent/transaction/attributes.rb +0 -155
  338. data/lib/new_relic/agent/transaction/developer_mode_sample_buffer.rb +0 -62
  339. data/lib/new_relic/agent/transaction/xray_sample_buffer.rb +0 -64
  340. data/lib/new_relic/agent/transaction_sample_builder.rb +0 -141
  341. data/lib/new_relic/agent/transaction_state.rb +0 -155
  342. data/lib/new_relic/agent/transaction_timings.rb +0 -57
  343. data/lib/new_relic/merbtasks.rb +0 -10
  344. data/lib/new_relic/metrics.rb +0 -13
  345. data/lib/new_relic/rack/developer_mode.rb +0 -321
  346. data/lib/new_relic/rack/developer_mode/segment_summary.rb +0 -56
  347. data/lib/tasks/versions.html.erb +0 -28
  348. data/lib/tasks/versions.postface.html +0 -8
  349. data/lib/tasks/versions.preface.html +0 -9
  350. data/lib/tasks/versions.rake +0 -65
  351. data/lib/tasks/versions.txt.erb +0 -14
  352. data/test/config/newrelic.yml +0 -46
  353. data/test/config/test.cert.crt +0 -18
  354. data/test/config/test.cert.key +0 -15
  355. data/test/config/test_control.rb +0 -54
  356. data/test/environments/.gitignore +0 -16
  357. data/test/environments/lib/environments/runner.rb +0 -111
  358. data/test/environments/norails/Gemfile +0 -19
  359. data/test/environments/norails/Rakefile +0 -9
  360. data/test/environments/rails21/Gemfile +0 -23
  361. data/test/environments/rails21/Rakefile +0 -16
  362. data/test/environments/rails21/app/controllers/application.rb +0 -20
  363. data/test/environments/rails21/config/boot.rb +0 -113
  364. data/test/environments/rails21/config/database.yml +0 -26
  365. data/test/environments/rails21/config/environment.rb +0 -26
  366. data/test/environments/rails21/config/environments/development.rb +0 -10
  367. data/test/environments/rails21/config/environments/production.rb +0 -8
  368. data/test/environments/rails21/config/environments/test.rb +0 -10
  369. data/test/environments/rails21/config/routes.rb +0 -5
  370. data/test/environments/rails21/db/schema.rb +0 -5
  371. data/test/environments/rails22/Gemfile +0 -24
  372. data/test/environments/rails22/Rakefile +0 -16
  373. data/test/environments/rails22/app/controllers/application.rb +0 -20
  374. data/test/environments/rails22/config/boot.rb +0 -113
  375. data/test/environments/rails22/config/database.yml +0 -26
  376. data/test/environments/rails22/config/environment.rb +0 -25
  377. data/test/environments/rails22/config/environments/development.rb +0 -10
  378. data/test/environments/rails22/config/environments/production.rb +0 -8
  379. data/test/environments/rails22/config/environments/test.rb +0 -10
  380. data/test/environments/rails22/config/routes.rb +0 -5
  381. data/test/environments/rails22/db/schema.rb +0 -5
  382. data/test/environments/rails23/Gemfile +0 -24
  383. data/test/environments/rails23/Rakefile +0 -16
  384. data/test/environments/rails23/app/controllers/application.rb +0 -20
  385. data/test/environments/rails23/config/boot.rb +0 -127
  386. data/test/environments/rails23/config/database.yml +0 -26
  387. data/test/environments/rails23/config/environment.rb +0 -16
  388. data/test/environments/rails23/config/environments/production.rb +0 -8
  389. data/test/environments/rails23/config/environments/test.rb +0 -10
  390. data/test/environments/rails23/config/preinitializer.rb +0 -25
  391. data/test/environments/rails23/config/routes.rb +0 -5
  392. data/test/environments/rails23/db/schema.rb +0 -5
  393. data/test/environments/rails30/Gemfile +0 -23
  394. data/test/environments/rails30/Rakefile +0 -11
  395. data/test/environments/rails30/config/application.rb +0 -17
  396. data/test/environments/rails30/config/boot.rb +0 -10
  397. data/test/environments/rails30/config/database.yml +0 -26
  398. data/test/environments/rails30/config/environment.rb +0 -6
  399. data/test/environments/rails30/config/initializers/new_rails_defaults.rb +0 -11
  400. data/test/environments/rails30/db/schema.rb +0 -5
  401. data/test/environments/rails31/Gemfile +0 -24
  402. data/test/environments/rails31/Rakefile +0 -11
  403. data/test/environments/rails31/config/application.rb +0 -18
  404. data/test/environments/rails31/config/boot.rb +0 -10
  405. data/test/environments/rails31/config/database.yml +0 -26
  406. data/test/environments/rails31/config/environment.rb +0 -6
  407. data/test/environments/rails31/config/initializers/new_rails_defaults.rb +0 -21
  408. data/test/environments/rails31/db/schema.rb +0 -5
  409. data/test/environments/rails32/Gemfile +0 -26
  410. data/test/environments/rails32/Rakefile +0 -12
  411. data/test/environments/rails32/config/application.rb +0 -19
  412. data/test/environments/rails32/config/boot.rb +0 -10
  413. data/test/environments/rails32/config/database.yml +0 -26
  414. data/test/environments/rails32/config/environment.rb +0 -6
  415. data/test/environments/rails32/db/schema.rb +0 -5
  416. data/test/environments/rails40/Gemfile +0 -26
  417. data/test/environments/rails40/Rakefile +0 -11
  418. data/test/environments/rails40/config/application.rb +0 -18
  419. data/test/environments/rails40/config/boot.rb +0 -10
  420. data/test/environments/rails40/config/database.yml +0 -26
  421. data/test/environments/rails40/config/environment.rb +0 -6
  422. data/test/environments/rails40/db/schema.rb +0 -5
  423. data/test/environments/rails41/Gemfile +0 -26
  424. data/test/environments/rails41/Rakefile +0 -11
  425. data/test/environments/rails41/config/application.rb +0 -18
  426. data/test/environments/rails41/config/boot.rb +0 -10
  427. data/test/environments/rails41/config/database.yml +0 -26
  428. data/test/environments/rails41/config/environment.rb +0 -6
  429. data/test/environments/rails41/db/schema.rb +0 -5
  430. data/test/environments/rails42/Gemfile +0 -27
  431. data/test/environments/rails42/Rakefile +0 -11
  432. data/test/environments/rails42/config/application.rb +0 -18
  433. data/test/environments/rails42/config/boot.rb +0 -10
  434. data/test/environments/rails42/config/database.yml +0 -26
  435. data/test/environments/rails42/config/environment.rb +0 -6
  436. data/test/environments/rails42/db/schema.rb +0 -5
  437. data/test/environments/rails50/Gemfile +0 -23
  438. data/test/environments/rails50/Rakefile +0 -11
  439. data/test/environments/rails50/config/application.rb +0 -18
  440. data/test/environments/rails50/config/boot.rb +0 -10
  441. data/test/environments/rails50/config/database.yml +0 -26
  442. data/test/environments/rails50/config/environment.rb +0 -6
  443. data/test/environments/rails50/db/schema.rb +0 -5
  444. data/test/fixtures/cross_agent_tests/README.md +0 -34
  445. data/test/fixtures/cross_agent_tests/attribute_configuration.json +0 -384
  446. data/test/fixtures/cross_agent_tests/aws.json +0 -312
  447. data/test/fixtures/cross_agent_tests/cat/README.md +0 -28
  448. data/test/fixtures/cross_agent_tests/cat/cat_map.json +0 -595
  449. data/test/fixtures/cross_agent_tests/cat/path_hashing.json +0 -51
  450. data/test/fixtures/cross_agent_tests/cat_map.json +0 -597
  451. data/test/fixtures/cross_agent_tests/data_transport/data_transport.json +0 -1441
  452. data/test/fixtures/cross_agent_tests/data_transport/data_transport.md +0 -35
  453. data/test/fixtures/cross_agent_tests/datastores/README.md +0 -16
  454. data/test/fixtures/cross_agent_tests/datastores/datastore_api.json +0 -443
  455. data/test/fixtures/cross_agent_tests/datastores/datastore_instances.json +0 -73
  456. data/test/fixtures/cross_agent_tests/docker_container_id/README.md +0 -6
  457. data/test/fixtures/cross_agent_tests/docker_container_id/cases.json +0 -75
  458. data/test/fixtures/cross_agent_tests/docker_container_id/docker-0.9.1.txt +0 -10
  459. data/test/fixtures/cross_agent_tests/docker_container_id/docker-1.0.0.txt +0 -10
  460. data/test/fixtures/cross_agent_tests/docker_container_id/docker-1.1.2-lxc-driver.txt +0 -10
  461. data/test/fixtures/cross_agent_tests/docker_container_id/docker-1.1.2-native-driver-fs.txt +0 -10
  462. data/test/fixtures/cross_agent_tests/docker_container_id/docker-1.1.2-native-driver-systemd.txt +0 -10
  463. data/test/fixtures/cross_agent_tests/docker_container_id/docker-1.3.txt +0 -9
  464. data/test/fixtures/cross_agent_tests/docker_container_id/empty.txt +0 -0
  465. data/test/fixtures/cross_agent_tests/docker_container_id/heroku.txt +0 -1
  466. data/test/fixtures/cross_agent_tests/docker_container_id/invalid-characters.txt +0 -9
  467. data/test/fixtures/cross_agent_tests/docker_container_id/invalid-length.txt +0 -9
  468. data/test/fixtures/cross_agent_tests/docker_container_id/ubuntu-14.04-lxc-container.txt +0 -10
  469. data/test/fixtures/cross_agent_tests/docker_container_id/ubuntu-14.04-no-container.txt +0 -10
  470. data/test/fixtures/cross_agent_tests/docker_container_id/ubuntu-14.10-no-container.txt +0 -10
  471. data/test/fixtures/cross_agent_tests/labels.json +0 -195
  472. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/README.md +0 -16
  473. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/basic_where.colon_obfuscated.txt +0 -3
  474. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/basic_where.explain.txt +0 -3
  475. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/basic_where.obfuscated.txt +0 -3
  476. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/basic_where.query.txt +0 -1
  477. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/current_date.colon_obfuscated.txt +0 -2
  478. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/current_date.explain.txt +0 -2
  479. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/current_date.obfuscated.txt +0 -2
  480. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/current_date.query.txt +0 -1
  481. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/date.colon_obfuscated.txt +0 -2
  482. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/date.explain.txt +0 -2
  483. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/date.obfuscated.txt +0 -2
  484. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/date.query.txt +0 -1
  485. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/embedded_newline.colon_obfuscated.txt +0 -2
  486. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/embedded_newline.explain.txt +0 -3
  487. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/embedded_newline.obfuscated.txt +0 -2
  488. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/embedded_newline.query.txt +0 -1
  489. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/embedded_quote.colon_obfuscated.txt +0 -2
  490. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/embedded_quote.explain.txt +0 -2
  491. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/embedded_quote.obfuscated.txt +0 -2
  492. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/embedded_quote.query.txt +0 -1
  493. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/floating_point.colon_obfuscated.txt +0 -2
  494. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/floating_point.explain.txt +0 -2
  495. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/floating_point.obfuscated.txt +0 -2
  496. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/floating_point.query.txt +0 -1
  497. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/function_with_strings.colon_obfuscated.txt +0 -5
  498. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/function_with_strings.explain.txt +0 -5
  499. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/function_with_strings.obfuscated.txt +0 -5
  500. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/function_with_strings.query.txt +0 -1
  501. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/quote_in_table_name.colon_obfuscated.txt +0 -2
  502. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/quote_in_table_name.explain.txt +0 -2
  503. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/quote_in_table_name.obfuscated.txt +0 -2
  504. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/quote_in_table_name.query.txt +0 -1
  505. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/subplan.colon_obfuscated.txt +0 -5
  506. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/subplan.explain.txt +0 -5
  507. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/subplan.obfuscated.txt +0 -5
  508. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/subplan.query.txt +0 -1
  509. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_integer.colon_obfuscated.txt +0 -2
  510. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_integer.explain.txt +0 -2
  511. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_integer.obfuscated.txt +0 -2
  512. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_integer.query.txt +0 -1
  513. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_regex_chars.colon_obfuscated.txt +0 -2
  514. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_regex_chars.explain.txt +0 -2
  515. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_regex_chars.obfuscated.txt +0 -2
  516. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_regex_chars.query.txt +0 -1
  517. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_substring.colon_obfuscated.txt +0 -3
  518. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_substring.explain.txt +0 -3
  519. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_substring.obfuscated.txt +0 -3
  520. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/where_with_substring.query.txt +0 -1
  521. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case1.colon_obfuscated.txt +0 -2
  522. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case1.explain.txt +0 -2
  523. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case1.obfuscated.txt +0 -2
  524. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case1.query.txt +0 -1
  525. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case2.colon_obfuscated.txt +0 -2
  526. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case2.explain.txt +0 -3
  527. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case2.obfuscated.txt +0 -2
  528. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case2.query.txt +0 -1
  529. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case3.colon_obfuscated.txt +0 -2
  530. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case3.explain.txt +0 -2
  531. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case3.obfuscated.txt +0 -2
  532. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case3.query.txt +0 -1
  533. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case4.colon_obfuscated.txt +0 -2
  534. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case4.explain.txt +0 -2
  535. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case4.obfuscated.txt +0 -2
  536. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case4.query.txt +0 -1
  537. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case5.colon_obfuscated.txt +0 -2
  538. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case5.explain.txt +0 -2
  539. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case5.obfuscated.txt +0 -2
  540. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case5.query.txt +0 -1
  541. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case6.colon_obfuscated.txt +0 -2
  542. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case6.explain.txt +0 -2
  543. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case6.obfuscated.txt +0 -2
  544. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case6.query.txt +0 -1
  545. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case7.colon_obfuscated.txt +0 -2
  546. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case7.explain.txt +0 -2
  547. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case7.obfuscated.txt +0 -2
  548. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case7.query.txt +0 -1
  549. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case8.colon_obfuscated.txt +0 -2
  550. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case8.explain.txt +0 -2
  551. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case8.obfuscated.txt +0 -2
  552. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case8.query.txt +0 -1
  553. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case9.colon_obfuscated.txt +0 -2
  554. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case9.explain.txt +0 -2
  555. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case9.obfuscated.txt +0 -2
  556. data/test/fixtures/cross_agent_tests/postgres_explain_obfuscation/with_escape_case9.query.txt +0 -1
  557. data/test/fixtures/cross_agent_tests/proc_cpuinfo/1pack_1core_1logical.txt +0 -3
  558. data/test/fixtures/cross_agent_tests/proc_cpuinfo/1pack_1core_2logical.txt +0 -14
  559. data/test/fixtures/cross_agent_tests/proc_cpuinfo/1pack_2core_2logical.txt +0 -14
  560. data/test/fixtures/cross_agent_tests/proc_cpuinfo/1pack_4core_4logical.txt +0 -28
  561. data/test/fixtures/cross_agent_tests/proc_cpuinfo/2pack_12core_24logical.txt +0 -575
  562. data/test/fixtures/cross_agent_tests/proc_cpuinfo/2pack_20core_40logical.txt +0 -999
  563. data/test/fixtures/cross_agent_tests/proc_cpuinfo/2pack_2core_2logical.txt +0 -51
  564. data/test/fixtures/cross_agent_tests/proc_cpuinfo/2pack_2core_4logical.txt +0 -28
  565. data/test/fixtures/cross_agent_tests/proc_cpuinfo/2pack_4core_4logical.txt +0 -28
  566. data/test/fixtures/cross_agent_tests/proc_cpuinfo/4pack_4core_4logical.txt +0 -103
  567. data/test/fixtures/cross_agent_tests/proc_cpuinfo/8pack_8core_8logical.txt +0 -199
  568. data/test/fixtures/cross_agent_tests/proc_cpuinfo/README.md +0 -28
  569. data/test/fixtures/cross_agent_tests/proc_cpuinfo/Xpack_Xcore_2logical.txt +0 -43
  570. data/test/fixtures/cross_agent_tests/proc_cpuinfo/malformed_file.txt +0 -3
  571. data/test/fixtures/cross_agent_tests/proc_meminfo/README.md +0 -7
  572. data/test/fixtures/cross_agent_tests/proc_meminfo/meminfo_4096MB.txt +0 -47
  573. data/test/fixtures/cross_agent_tests/rules.json +0 -165
  574. data/test/fixtures/cross_agent_tests/rum_client_config.json +0 -91
  575. data/test/fixtures/cross_agent_tests/rum_footer_insertion_location/close-body-in-comment.html +0 -10
  576. data/test/fixtures/cross_agent_tests/rum_footer_insertion_location/dynamic-iframe.html +0 -19
  577. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/basic.html +0 -10
  578. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/body_with_attributes.html +0 -3
  579. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/charset_tag.html +0 -11
  580. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/charset_tag_after_x_ua_tag.html +0 -11
  581. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/charset_tag_before_x_ua_tag.html +0 -11
  582. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/charset_tag_with_spaces.html +0 -11
  583. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/comments1.html +0 -24
  584. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/comments2.html +0 -24
  585. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/content_type_charset_tag.html +0 -11
  586. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/content_type_charset_tag_after_x_ua_tag.html +0 -11
  587. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/content_type_charset_tag_before_x_ua_tag.html +0 -11
  588. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/empty_head +0 -4
  589. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/gt_in_quotes1.html +0 -27
  590. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/gt_in_quotes2.html +0 -24
  591. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/gt_in_quotes_mismatch.html +0 -24
  592. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/gt_in_single_quotes1.html +0 -25
  593. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/gt_in_single_quotes_mismatch.html +0 -25
  594. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/head_with_attributes.html +0 -10
  595. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/incomplete_non_meta_tags.html +0 -10
  596. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/no_end_header.html +0 -6
  597. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/no_header.html +0 -7
  598. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/no_html_and_no_header.html +0 -3
  599. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/no_start_header.html +0 -9
  600. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/script1.html +0 -19
  601. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/script2.html +0 -17
  602. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/x_ua_meta_tag.html +0 -10
  603. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/x_ua_meta_tag_multiline.html +0 -11
  604. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/x_ua_meta_tag_multiple_tags.html +0 -12
  605. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/x_ua_meta_tag_spaces_around_equals.html +0 -10
  606. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/x_ua_meta_tag_with_others.html +0 -11
  607. data/test/fixtures/cross_agent_tests/rum_loader_insertion_location/x_ua_meta_tag_with_spaces.html +0 -10
  608. data/test/fixtures/cross_agent_tests/sql_obfuscation/README.md +0 -36
  609. data/test/fixtures/cross_agent_tests/sql_obfuscation/sql_obfuscation.json +0 -619
  610. data/test/fixtures/cross_agent_tests/sql_parsing.json +0 -55
  611. data/test/fixtures/cross_agent_tests/synthetics/README.md +0 -65
  612. data/test/fixtures/cross_agent_tests/synthetics/synthetics.json +0 -317
  613. data/test/fixtures/cross_agent_tests/transaction_segment_terms.json +0 -389
  614. data/test/fixtures/cross_agent_tests/url_clean.json +0 -15
  615. data/test/fixtures/cross_agent_tests/url_domain_extraction.json +0 -35
  616. data/test/fixtures/cross_agent_tests/utilization/README.md +0 -13
  617. data/test/fixtures/cross_agent_tests/utilization/utilization_json.json +0 -132
  618. data/test/helpers/exceptions.rb +0 -16
  619. data/test/helpers/file_searching.rb +0 -28
  620. data/test/helpers/logging.rb +0 -37
  621. data/test/helpers/minitest.rb +0 -50
  622. data/test/helpers/misc.rb +0 -87
  623. data/test/helpers/mongo_metric_builder.rb +0 -34
  624. data/test/helpers/transaction_sample.rb +0 -44
  625. data/test/intentional_fail.rb +0 -13
  626. data/test/multiverse/.gitignore +0 -13
  627. data/test/multiverse/README.md +0 -85
  628. data/test/multiverse/lib/multiverse.rb +0 -32
  629. data/test/multiverse/lib/multiverse/color.rb +0 -23
  630. data/test/multiverse/lib/multiverse/envfile.rb +0 -66
  631. data/test/multiverse/lib/multiverse/output_collector.rb +0 -82
  632. data/test/multiverse/lib/multiverse/runner.rb +0 -118
  633. data/test/multiverse/lib/multiverse/shell_utils.rb +0 -27
  634. data/test/multiverse/lib/multiverse/suite.rb +0 -536
  635. data/test/multiverse/script/runner +0 -5
  636. data/test/multiverse/suites/active_record/.gitignore +0 -1
  637. data/test/multiverse/suites/active_record/Envfile +0 -60
  638. data/test/multiverse/suites/active_record/Rakefile +0 -9
  639. data/test/multiverse/suites/active_record/active_record_test.rb +0 -618
  640. data/test/multiverse/suites/active_record/app/models/models.rb +0 -34
  641. data/test/multiverse/suites/active_record/ar_method_aliasing.rb +0 -43
  642. data/test/multiverse/suites/active_record/before_suite.rb +0 -23
  643. data/test/multiverse/suites/active_record/config/database.rb +0 -79
  644. data/test/multiverse/suites/active_record/config/database.yml +0 -20
  645. data/test/multiverse/suites/active_record/config/newrelic.yml +0 -18
  646. data/test/multiverse/suites/active_record/db/migrate/20141105131800_create_users_and_aliases.rb +0 -21
  647. data/test/multiverse/suites/active_record/db/migrate/20141106082200_create_orders_and_shipments.rb +0 -25
  648. data/test/multiverse/suites/active_record/db/migrate/20150413011200_add_timestamps_to_orders.rb +0 -16
  649. data/test/multiverse/suites/active_record/db/migrate/20150414084400_create_groups.rb +0 -21
  650. data/test/multiverse/suites/activemerchant/Envfile +0 -26
  651. data/test/multiverse/suites/activemerchant/activemerchant_test.rb +0 -62
  652. data/test/multiverse/suites/agent_only/Envfile +0 -5
  653. data/test/multiverse/suites/agent_only/agent_attributes_test.rb +0 -351
  654. data/test/multiverse/suites/agent_only/agent_run_id_handling_test.rb +0 -39
  655. data/test/multiverse/suites/agent_only/audit_log_test.rb +0 -57
  656. data/test/multiverse/suites/agent_only/collector_exception_handling_test.rb +0 -87
  657. data/test/multiverse/suites/agent_only/config/newrelic.yml +0 -27
  658. data/test/multiverse/suites/agent_only/cross_application_tracing_test.rb +0 -94
  659. data/test/multiverse/suites/agent_only/custom_analytics_events_test.rb +0 -82
  660. data/test/multiverse/suites/agent_only/custom_queue_time_test.rb +0 -60
  661. data/test/multiverse/suites/agent_only/encoding_handling_test.rb +0 -122
  662. data/test/multiverse/suites/agent_only/error_events_test.rb +0 -98
  663. data/test/multiverse/suites/agent_only/exclusive_time_test.rb +0 -176
  664. data/test/multiverse/suites/agent_only/harvest_timestamps_test.rb +0 -61
  665. data/test/multiverse/suites/agent_only/http_response_code_test.rb +0 -38
  666. data/test/multiverse/suites/agent_only/keepalive_test.rb +0 -24
  667. data/test/multiverse/suites/agent_only/key_transactions_test.rb +0 -118
  668. data/test/multiverse/suites/agent_only/labels_test.rb +0 -83
  669. data/test/multiverse/suites/agent_only/logging_test.rb +0 -162
  670. data/test/multiverse/suites/agent_only/marshaling_test.rb +0 -89
  671. data/test/multiverse/suites/agent_only/pipe_manager_test.rb +0 -41
  672. data/test/multiverse/suites/agent_only/rename_rule_test.rb +0 -91
  673. data/test/multiverse/suites/agent_only/rum_instrumentation_test.rb +0 -97
  674. data/test/multiverse/suites/agent_only/script/env_change.rb +0 -10
  675. data/test/multiverse/suites/agent_only/script/loading.rb +0 -20
  676. data/test/multiverse/suites/agent_only/script/public_api_when_disabled.rb +0 -57
  677. data/test/multiverse/suites/agent_only/script/symbol_env.rb +0 -10
  678. data/test/multiverse/suites/agent_only/script/warnings.rb +0 -15
  679. data/test/multiverse/suites/agent_only/service_timeout_test.rb +0 -39
  680. data/test/multiverse/suites/agent_only/set_transaction_name_test.rb +0 -118
  681. data/test/multiverse/suites/agent_only/ssl_test.rb +0 -21
  682. data/test/multiverse/suites/agent_only/start_up_test.rb +0 -107
  683. data/test/multiverse/suites/agent_only/synthetics_test.rb +0 -131
  684. data/test/multiverse/suites/agent_only/testing_app.rb +0 -58
  685. data/test/multiverse/suites/agent_only/thread_profiling_test.rb +0 -137
  686. data/test/multiverse/suites/agent_only/transaction_events_test.rb +0 -31
  687. data/test/multiverse/suites/agent_only/transaction_ignoring_test.rb +0 -42
  688. data/test/multiverse/suites/agent_only/utilization_data_collection_test.rb +0 -105
  689. data/test/multiverse/suites/agent_only/xray_sessions_test.rb +0 -196
  690. data/test/multiverse/suites/bare/Envfile +0 -3
  691. data/test/multiverse/suites/bare/standalone_instrumentation_test.rb +0 -43
  692. data/test/multiverse/suites/capistrano/Capfile +0 -26
  693. data/test/multiverse/suites/capistrano/Envfile +0 -23
  694. data/test/multiverse/suites/capistrano/config/deploy.rb +0 -14
  695. data/test/multiverse/suites/capistrano/config/deploy/production.rb +0 -9
  696. data/test/multiverse/suites/capistrano/config/newrelic.yml +0 -21
  697. data/test/multiverse/suites/capistrano/deployment_test.rb +0 -51
  698. data/test/multiverse/suites/capistrano2/Capfile +0 -4
  699. data/test/multiverse/suites/capistrano2/Envfile +0 -8
  700. data/test/multiverse/suites/capistrano2/config/deploy.rb +0 -19
  701. data/test/multiverse/suites/capistrano2/config/newrelic.yml +0 -21
  702. data/test/multiverse/suites/capistrano2/deployment_test.rb +0 -37
  703. data/test/multiverse/suites/config_file_loading/Envfile +0 -13
  704. data/test/multiverse/suites/config_file_loading/config_file_loading_test.rb +0 -213
  705. data/test/multiverse/suites/curb/Envfile +0 -27
  706. data/test/multiverse/suites/curb/config/newrelic.yml +0 -18
  707. data/test/multiverse/suites/curb/curb_test.rb +0 -212
  708. data/test/multiverse/suites/datamapper/Envfile +0 -36
  709. data/test/multiverse/suites/datamapper/config/newrelic.yml +0 -20
  710. data/test/multiverse/suites/datamapper/datamapper_test.rb +0 -429
  711. data/test/multiverse/suites/deferred_instrumentation/Envfile +0 -15
  712. data/test/multiverse/suites/deferred_instrumentation/config/newrelic.yml +0 -20
  713. data/test/multiverse/suites/deferred_instrumentation/sinatra_test.rb +0 -110
  714. data/test/multiverse/suites/delayed_job/Envfile +0 -101
  715. data/test/multiverse/suites/delayed_job/before_suite.rb +0 -43
  716. data/test/multiverse/suites/delayed_job/config/newrelic.yml +0 -18
  717. data/test/multiverse/suites/delayed_job/delayed_job_instrumentation_test.rb +0 -106
  718. data/test/multiverse/suites/delayed_job/delayed_job_sampler_test.rb +0 -128
  719. data/test/multiverse/suites/delayed_job/unsupported_backend_test.rb +0 -21
  720. data/test/multiverse/suites/excon/Envfile +0 -18
  721. data/test/multiverse/suites/excon/config/newrelic.yml +0 -18
  722. data/test/multiverse/suites/excon/excon_test.rb +0 -81
  723. data/test/multiverse/suites/grape/Envfile +0 -9
  724. data/test/multiverse/suites/grape/config/newrelic.yml +0 -19
  725. data/test/multiverse/suites/grape/grape_test.rb +0 -219
  726. data/test/multiverse/suites/grape/grape_test_api.rb +0 -64
  727. data/test/multiverse/suites/grape/grape_versioning_test.rb +0 -118
  728. data/test/multiverse/suites/grape/grape_versioning_test_api.rb +0 -130
  729. data/test/multiverse/suites/grape/unsupported_version_test.rb +0 -28
  730. data/test/multiverse/suites/high_security/Envfile +0 -3
  731. data/test/multiverse/suites/high_security/config/newrelic.yml +0 -70
  732. data/test/multiverse/suites/high_security/high_security_test.rb +0 -214
  733. data/test/multiverse/suites/httpclient/Envfile +0 -15
  734. data/test/multiverse/suites/httpclient/config/newrelic.yml +0 -18
  735. data/test/multiverse/suites/httpclient/httpclient_test.rb +0 -75
  736. data/test/multiverse/suites/httprb/Envfile +0 -21
  737. data/test/multiverse/suites/httprb/config/newrelic.yml +0 -18
  738. data/test/multiverse/suites/httprb/httprb_test.rb +0 -78
  739. data/test/multiverse/suites/json/Envfile +0 -22
  740. data/test/multiverse/suites/json/config/newrelic.yml +0 -22
  741. data/test/multiverse/suites/json/json_test.rb +0 -16
  742. data/test/multiverse/suites/marshalling/Envfile +0 -3
  743. data/test/multiverse/suites/marshalling/config/newrelic.yml +0 -20
  744. data/test/multiverse/suites/marshalling/marshalling_test.rb +0 -16
  745. data/test/multiverse/suites/memcached/Envfile +0 -36
  746. data/test/multiverse/suites/memcached/dalli_test.rb +0 -163
  747. data/test/multiverse/suites/memcached/memcache_client_test.rb +0 -25
  748. data/test/multiverse/suites/memcached/memcache_test_cases.rb +0 -315
  749. data/test/multiverse/suites/memcached/memcached_test.rb +0 -179
  750. data/test/multiverse/suites/mongo/Envfile +0 -74
  751. data/test/multiverse/suites/mongo/config/newrelic.yml +0 -18
  752. data/test/multiverse/suites/mongo/helpers/mongo_operation_tests.rb +0 -551
  753. data/test/multiverse/suites/mongo/helpers/mongo_replica_set.rb +0 -97
  754. data/test/multiverse/suites/mongo/helpers/mongo_replica_set_test.rb +0 -82
  755. data/test/multiverse/suites/mongo/helpers/mongo_server.rb +0 -241
  756. data/test/multiverse/suites/mongo/helpers/mongo_server_test.rb +0 -176
  757. data/test/multiverse/suites/mongo/mongo2_instrumentation_test.rb +0 -493
  758. data/test/multiverse/suites/mongo/mongo_connection_test.rb +0 -40
  759. data/test/multiverse/suites/mongo/mongo_instrumentation_test.rb +0 -58
  760. data/test/multiverse/suites/mongo/mongo_unsupported_version_test.rb +0 -72
  761. data/test/multiverse/suites/net_http/Envfile +0 -6
  762. data/test/multiverse/suites/net_http/config/newrelic.yml +0 -18
  763. data/test/multiverse/suites/net_http/net_http_test.rb +0 -115
  764. data/test/multiverse/suites/padrino/Envfile +0 -19
  765. data/test/multiverse/suites/padrino/config/newrelic.yml +0 -22
  766. data/test/multiverse/suites/padrino/padrino_test.rb +0 -52
  767. data/test/multiverse/suites/rack/Envfile +0 -64
  768. data/test/multiverse/suites/rack/before_suite.rb +0 -12
  769. data/test/multiverse/suites/rack/builder_map_test.rb +0 -128
  770. data/test/multiverse/suites/rack/config/newrelic.yml +0 -18
  771. data/test/multiverse/suites/rack/example_app.rb +0 -119
  772. data/test/multiverse/suites/rack/http_response_code_test.rb +0 -49
  773. data/test/multiverse/suites/rack/nested_non_rack_app_test.rb +0 -66
  774. data/test/multiverse/suites/rack/puma_rack_builder_test.rb +0 -84
  775. data/test/multiverse/suites/rack/rack_auto_instrumentation_test.rb +0 -151
  776. data/test/multiverse/suites/rack/rack_cascade_test.rb +0 -44
  777. data/test/multiverse/suites/rack/rack_env_mutation_test.rb +0 -52
  778. data/test/multiverse/suites/rack/rack_parameter_filtering_test.rb +0 -49
  779. data/test/multiverse/suites/rack/rack_unsupported_version_test.rb +0 -43
  780. data/test/multiverse/suites/rack/response_content_type_test.rb +0 -49
  781. data/test/multiverse/suites/rack/url_map_test.rb +0 -155
  782. data/test/multiverse/suites/rails/Envfile +0 -61
  783. data/test/multiverse/suites/rails/action_cable_test.rb +0 -81
  784. data/test/multiverse/suites/rails/action_controller_live_rum_test.rb +0 -39
  785. data/test/multiverse/suites/rails/activejob_test.rb +0 -151
  786. data/test/multiverse/suites/rails/app.rb +0 -44
  787. data/test/multiverse/suites/rails/app/views/foos/_foo.html.haml +0 -1
  788. data/test/multiverse/suites/rails/app/views/views/_a_partial.html.erb +0 -2
  789. data/test/multiverse/suites/rails/app/views/views/_mid_partial.html.erb +0 -1
  790. data/test/multiverse/suites/rails/app/views/views/_top_partial.html.erb +0 -3
  791. data/test/multiverse/suites/rails/app/views/views/deep_partial.html.erb +0 -3
  792. data/test/multiverse/suites/rails/app/views/views/haml_view.html.haml +0 -6
  793. data/test/multiverse/suites/rails/app/views/views/index.html.erb +0 -4
  794. data/test/multiverse/suites/rails/bad_instrumentation_test.rb +0 -29
  795. data/test/multiverse/suites/rails/config/newrelic.yml +0 -30
  796. data/test/multiverse/suites/rails/dummy.txt +0 -1
  797. data/test/multiverse/suites/rails/error_tracing_test.rb +0 -346
  798. data/test/multiverse/suites/rails/gc_instrumentation_test.rb +0 -73
  799. data/test/multiverse/suites/rails/ignore_test.rb +0 -79
  800. data/test/multiverse/suites/rails/middleware_instrumentation_test.rb +0 -41
  801. data/test/multiverse/suites/rails/middlewares.rb +0 -19
  802. data/test/multiverse/suites/rails/parameter_capture_test.rb +0 -328
  803. data/test/multiverse/suites/rails/queue_time_test.rb +0 -89
  804. data/test/multiverse/suites/rails/rails2_app/app/controllers/application.rb +0 -7
  805. data/test/multiverse/suites/rails/rails2_app/config/boot.rb +0 -127
  806. data/test/multiverse/suites/rails/rails2_app/config/database.yml +0 -18
  807. data/test/multiverse/suites/rails/rails2_app/config/environment.rb +0 -16
  808. data/test/multiverse/suites/rails/rails2_app/config/environments/development.rb +0 -10
  809. data/test/multiverse/suites/rails/rails2_app/config/initializers/load_newrelic_rpm.rb +0 -9
  810. data/test/multiverse/suites/rails/rails2_app/config/preinitializer.rb +0 -25
  811. data/test/multiverse/suites/rails/rails2_app/config/routes.rb +0 -19
  812. data/test/multiverse/suites/rails/rails2_app/db/schema.rb +0 -5
  813. data/test/multiverse/suites/rails/rails3_app/app_rails3_plus.rb +0 -99
  814. data/test/multiverse/suites/rails/request_statistics_test.rb +0 -192
  815. data/test/multiverse/suites/rails/transaction_ignoring_test.rb +0 -41
  816. data/test/multiverse/suites/rails/view_instrumentation_test.rb +0 -254
  817. data/test/multiverse/suites/rake/Envfile +0 -43
  818. data/test/multiverse/suites/rake/Rakefile +0 -54
  819. data/test/multiverse/suites/rake/config/newrelic.yml +0 -18
  820. data/test/multiverse/suites/rake/multitask_test.rb +0 -40
  821. data/test/multiverse/suites/rake/rake_test.rb +0 -209
  822. data/test/multiverse/suites/rake/rake_test_helper.rb +0 -66
  823. data/test/multiverse/suites/rake/unsupported_rake_test.rb +0 -19
  824. data/test/multiverse/suites/redis/Envfile +0 -23
  825. data/test/multiverse/suites/redis/config/newrelic.yml +0 -19
  826. data/test/multiverse/suites/redis/redis_instrumentation_test.rb +0 -331
  827. data/test/multiverse/suites/redis/redis_unsupported_version_test.rb +0 -20
  828. data/test/multiverse/suites/resque/Envfile +0 -9
  829. data/test/multiverse/suites/resque/Rakefile +0 -3
  830. data/test/multiverse/suites/resque/config/newrelic.yml +0 -19
  831. data/test/multiverse/suites/resque/instrumentation_test.rb +0 -159
  832. data/test/multiverse/suites/resque/resque_marshalling_test.rb +0 -61
  833. data/test/multiverse/suites/sequel/Envfile +0 -41
  834. data/test/multiverse/suites/sequel/config/newrelic.yml +0 -18
  835. data/test/multiverse/suites/sequel/database.rb +0 -54
  836. data/test/multiverse/suites/sequel/sequel_extension_test.rb +0 -142
  837. data/test/multiverse/suites/sequel/sequel_helpers.rb +0 -62
  838. data/test/multiverse/suites/sequel/sequel_plugin_test.rb +0 -230
  839. data/test/multiverse/suites/sequel/sequel_safety_test.rb +0 -30
  840. data/test/multiverse/suites/sidekiq/Envfile +0 -43
  841. data/test/multiverse/suites/sidekiq/after_suite.rb +0 -16
  842. data/test/multiverse/suites/sidekiq/config/newrelic.yml +0 -20
  843. data/test/multiverse/suites/sidekiq/log/.gitkeep +0 -0
  844. data/test/multiverse/suites/sidekiq/sidekiq_instrumentation_test.rb +0 -220
  845. data/test/multiverse/suites/sidekiq/sidekiq_server.rb +0 -35
  846. data/test/multiverse/suites/sidekiq/test_model.rb +0 -12
  847. data/test/multiverse/suites/sidekiq/test_worker.rb +0 -71
  848. data/test/multiverse/suites/sinatra/Envfile +0 -27
  849. data/test/multiverse/suites/sinatra/config/newrelic.yml +0 -21
  850. data/test/multiverse/suites/sinatra/ignoring_test.rb +0 -226
  851. data/test/multiverse/suites/sinatra/nested_middleware_test.rb +0 -47
  852. data/test/multiverse/suites/sinatra/sinatra_classic_test.rb +0 -103
  853. data/test/multiverse/suites/sinatra/sinatra_error_tracing_test.rb +0 -48
  854. data/test/multiverse/suites/sinatra/sinatra_metric_explosion_test.rb +0 -102
  855. data/test/multiverse/suites/sinatra/sinatra_modular_test.rb +0 -93
  856. data/test/multiverse/suites/sinatra/sinatra_parameter_capture_test.rb +0 -82
  857. data/test/multiverse/suites/sinatra/sinatra_routes_test.rb +0 -49
  858. data/test/multiverse/suites/sinatra/sinatra_test_cases.rb +0 -226
  859. data/test/multiverse/suites/typhoeus/Envfile +0 -68
  860. data/test/multiverse/suites/typhoeus/config/newrelic.yml +0 -18
  861. data/test/multiverse/suites/typhoeus/typhoeus_test.rb +0 -145
  862. data/test/multiverse/suites/yajl/Envfile +0 -20
  863. data/test/multiverse/suites/yajl/config/newrelic.yml +0 -21
  864. data/test/multiverse/suites/yajl/yajl_test.rb +0 -16
  865. data/test/multiverse/test/multiverse_test.rb +0 -59
  866. data/test/multiverse/test/suite_examples/one/a/Envfile +0 -3
  867. data/test/multiverse/test/suite_examples/one/a/a_test.rb +0 -14
  868. data/test/multiverse/test/suite_examples/one/a/config/newrelic.yml +0 -22
  869. data/test/multiverse/test/suite_examples/one/b/Envfile +0 -3
  870. data/test/multiverse/test/suite_examples/one/b/b_test.rb +0 -14
  871. data/test/multiverse/test/suite_examples/one/b/config/newrelic.yml +0 -22
  872. data/test/multiverse/test/suite_examples/three/a/Envfile +0 -2
  873. data/test/multiverse/test/suite_examples/three/a/fail_test.rb +0 -10
  874. data/test/multiverse/test/suite_examples/three/b/Envfile +0 -2
  875. data/test/multiverse/test/suite_examples/three/b/win_test.rb +0 -10
  876. data/test/multiverse/test/suite_examples/two/a/Envfile +0 -1
  877. data/test/multiverse/test/suite_examples/two/a/fail_test.rb +0 -10
  878. data/test/new_relic/FAKECHANGELOG +0 -21
  879. data/test/new_relic/agent/agent/connect_test.rb +0 -308
  880. data/test/new_relic/agent/agent/start_test.rb +0 -186
  881. data/test/new_relic/agent/agent/start_worker_thread_test.rb +0 -74
  882. data/test/new_relic/agent/agent_logger_test.rb +0 -389
  883. data/test/new_relic/agent/agent_test.rb +0 -710
  884. data/test/new_relic/agent/agent_test_controller.rb +0 -84
  885. data/test/new_relic/agent/apdex_from_server_test.rb +0 -13
  886. data/test/new_relic/agent/api_tests/datastore_api_test.rb +0 -64
  887. data/test/new_relic/agent/attribute_filter_test.rb +0 -218
  888. data/test/new_relic/agent/attribute_processing_test.rb +0 -164
  889. data/test/new_relic/agent/audit_logger_test.rb +0 -208
  890. data/test/new_relic/agent/autostart_test.rb +0 -79
  891. data/test/new_relic/agent/aws_info_test.rb +0 -76
  892. data/test/new_relic/agent/busy_calculator_test.rb +0 -96
  893. data/test/new_relic/agent/commands/agent_command_router_test.rb +0 -256
  894. data/test/new_relic/agent/commands/agent_command_test.rb +0 -37
  895. data/test/new_relic/agent/commands/thread_profiler_session_test.rb +0 -216
  896. data/test/new_relic/agent/commands/xray_session_collection_test.rb +0 -332
  897. data/test/new_relic/agent/commands/xray_session_test.rb +0 -42
  898. data/test/new_relic/agent/configuration/default_source_test.rb +0 -229
  899. data/test/new_relic/agent/configuration/dotted_hash_test.rb +0 -53
  900. data/test/new_relic/agent/configuration/environment_source_test.rb +0 -201
  901. data/test/new_relic/agent/configuration/high_security_source_test.rb +0 -92
  902. data/test/new_relic/agent/configuration/manager_test.rb +0 -455
  903. data/test/new_relic/agent/configuration/manual_source_test.rb +0 -18
  904. data/test/new_relic/agent/configuration/orphan_configuration_test.rb +0 -91
  905. data/test/new_relic/agent/configuration/server_source_test.rb +0 -202
  906. data/test/new_relic/agent/configuration/yaml_source_test.rb +0 -117
  907. data/test/new_relic/agent/cross_app_monitor_test.rb +0 -248
  908. data/test/new_relic/agent/custom_event_aggregator_test.rb +0 -127
  909. data/test/new_relic/agent/database/postgres_explain_obfuscator_test.rb +0 -34
  910. data/test/new_relic/agent/database/sql_obfuscation_test.rb +0 -52
  911. data/test/new_relic/agent/database_test.rb +0 -482
  912. data/test/new_relic/agent/datastores/metric_helper_test.rb +0 -203
  913. data/test/new_relic/agent/datastores/mongo/event_formatter_test.rb +0 -175
  914. data/test/new_relic/agent/datastores/mongo/metric_translator_test.rb +0 -270
  915. data/test/new_relic/agent/datastores/mongo/obfuscator_test.rb +0 -99
  916. data/test/new_relic/agent/datastores/mongo/statement_formatter_test.rb +0 -72
  917. data/test/new_relic/agent/datastores/redis_test.rb +0 -126
  918. data/test/new_relic/agent/datastores_test.rb +0 -202
  919. data/test/new_relic/agent/deprecator_test.rb +0 -52
  920. data/test/new_relic/agent/encoding_normalizer_test.rb +0 -69
  921. data/test/new_relic/agent/error_collector_test.rb +0 -407
  922. data/test/new_relic/agent/error_event_aggregator_test.rb +0 -237
  923. data/test/new_relic/agent/error_trace_aggregator_test.rb +0 -298
  924. data/test/new_relic/agent/event_aggregator_test.rb +0 -178
  925. data/test/new_relic/agent/event_buffer_test_cases.rb +0 -168
  926. data/test/new_relic/agent/event_listener_test.rb +0 -70
  927. data/test/new_relic/agent/event_loop_test.rb +0 -202
  928. data/test/new_relic/agent/harvester_test.rb +0 -79
  929. data/test/new_relic/agent/hostname_test.rb +0 -121
  930. data/test/new_relic/agent/http_clients/uri_util_test.rb +0 -64
  931. data/test/new_relic/agent/inbound_request_monitor_test.rb +0 -49
  932. data/test/new_relic/agent/instrumentation/action_cable_subscriber_test.rb +0 -124
  933. data/test/new_relic/agent/instrumentation/action_controller_subscriber_test.rb +0 -299
  934. data/test/new_relic/agent/instrumentation/action_view_subscriber_test.rb +0 -249
  935. data/test/new_relic/agent/instrumentation/active_job_test.rb +0 -20
  936. data/test/new_relic/agent/instrumentation/active_record_helper_test.rb +0 -66
  937. data/test/new_relic/agent/instrumentation/active_record_subscriber_test.rb +0 -210
  938. data/test/new_relic/agent/instrumentation/controller_instrumentation_test.rb +0 -328
  939. data/test/new_relic/agent/instrumentation/delayed_job_instrumentation_test.rb +0 -23
  940. data/test/new_relic/agent/instrumentation/instance_identification_test.rb +0 -169
  941. data/test/new_relic/agent/instrumentation/instrumentation_test.rb +0 -14
  942. data/test/new_relic/agent/instrumentation/middleware_proxy_test.rb +0 -256
  943. data/test/new_relic/agent/instrumentation/middleware_tracing_test.rb +0 -49
  944. data/test/new_relic/agent/instrumentation/mongodb_command_subscriber_test.rb +0 -112
  945. data/test/new_relic/agent/instrumentation/net_instrumentation_test.rb +0 -41
  946. data/test/new_relic/agent/instrumentation/queue_time_test.rb +0 -103
  947. data/test/new_relic/agent/instrumentation/rack_test.rb +0 -44
  948. data/test/new_relic/agent/instrumentation/sequel_helper_test.rb +0 -36
  949. data/test/new_relic/agent/instrumentation/sinatra/transaction_namer_test.rb +0 -62
  950. data/test/new_relic/agent/instrumentation/sinatra_test.rb +0 -80
  951. data/test/new_relic/agent/instrumentation/task_instrumentation_test.rb +0 -186
  952. data/test/new_relic/agent/javascript_instrumentor_test.rb +0 -340
  953. data/test/new_relic/agent/memory_logger_test.rb +0 -85
  954. data/test/new_relic/agent/method_interrobang_test.rb +0 -31
  955. data/test/new_relic/agent/method_tracer/class_methods/add_method_tracer_test.rb +0 -112
  956. data/test/new_relic/agent/method_tracer/instance_methods/trace_execution_scoped_test.rb +0 -215
  957. data/test/new_relic/agent/method_tracer_test.rb +0 -480
  958. data/test/new_relic/agent/method_visibility_test.rb +0 -90
  959. data/test/new_relic/agent/mock_scope_listener.rb +0 -30
  960. data/test/new_relic/agent/new_relic_service/json_marshaller_test.rb +0 -27
  961. data/test/new_relic/agent/new_relic_service_test.rb +0 -972
  962. data/test/new_relic/agent/obfuscator_test.rb +0 -77
  963. data/test/new_relic/agent/parameter_filtering_test.rb +0 -39
  964. data/test/new_relic/agent/payload_metric_mapping_test.rb +0 -74
  965. data/test/new_relic/agent/pipe_channel_manager_test.rb +0 -316
  966. data/test/new_relic/agent/pipe_service_test.rb +0 -151
  967. data/test/new_relic/agent/rpm_agent_test.rb +0 -91
  968. data/test/new_relic/agent/rules_engine_test.rb +0 -136
  969. data/test/new_relic/agent/sampled_buffer_test.rb +0 -142
  970. data/test/new_relic/agent/sampler_collection_test.rb +0 -90
  971. data/test/new_relic/agent/sampler_test.rb +0 -66
  972. data/test/new_relic/agent/samplers/cpu_sampler_test.rb +0 -79
  973. data/test/new_relic/agent/samplers/memory_sampler_test.rb +0 -66
  974. data/test/new_relic/agent/samplers/vm_sampler_test.rb +0 -349
  975. data/test/new_relic/agent/sized_buffer_test.rb +0 -29
  976. data/test/new_relic/agent/sql_sampler_test.rb +0 -463
  977. data/test/new_relic/agent/stats_engine/gc_profiler_test.rb +0 -176
  978. data/test/new_relic/agent/stats_engine/metric_stats_test.rb +0 -328
  979. data/test/new_relic/agent/stats_engine/stats_hash_test.rb +0 -195
  980. data/test/new_relic/agent/stats_engine_test.rb +0 -32
  981. data/test/new_relic/agent/stats_test.rb +0 -187
  982. data/test/new_relic/agent/synthetics_event_aggregator_test.rb +0 -180
  983. data/test/new_relic/agent/synthetics_event_buffer_test.rb +0 -54
  984. data/test/new_relic/agent/synthetics_monitor_test.rb +0 -93
  985. data/test/new_relic/agent/system_info_test.rb +0 -133
  986. data/test/new_relic/agent/threading/agent_thread_test.rb +0 -149
  987. data/test/new_relic/agent/threading/backtrace_node_test.rb +0 -184
  988. data/test/new_relic/agent/threading/backtrace_service_test.rb +0 -603
  989. data/test/new_relic/agent/threading/fake_thread.rb +0 -43
  990. data/test/new_relic/agent/threading/thread_profile_test.rb +0 -271
  991. data/test/new_relic/agent/threading/threaded_test_case.rb +0 -18
  992. data/test/new_relic/agent/traced_method_stack_test.rb +0 -187
  993. data/test/new_relic/agent/transaction/abstract_segment_test.rb +0 -103
  994. data/test/new_relic/agent/transaction/attributes_test.rb +0 -268
  995. data/test/new_relic/agent/transaction/datastore_segment_test.rb +0 -336
  996. data/test/new_relic/agent/transaction/developer_mode_sample_buffer_test.rb +0 -75
  997. data/test/new_relic/agent/transaction/external_request_segment_test.rb +0 -330
  998. data/test/new_relic/agent/transaction/request_attributes_test.rb +0 -84
  999. data/test/new_relic/agent/transaction/segment_test.rb +0 -77
  1000. data/test/new_relic/agent/transaction/slowest_sample_buffer_test.rb +0 -67
  1001. data/test/new_relic/agent/transaction/synthetics_sample_buffer_test.rb +0 -38
  1002. data/test/new_relic/agent/transaction/trace_node_test.rb +0 -361
  1003. data/test/new_relic/agent/transaction/trace_test.rb +0 -394
  1004. data/test/new_relic/agent/transaction/tracing_test.rb +0 -176
  1005. data/test/new_relic/agent/transaction/xray_sample_buffer_test.rb +0 -71
  1006. data/test/new_relic/agent/transaction_error_primitive_test.rb +0 -117
  1007. data/test/new_relic/agent/transaction_event_aggregator_test.rb +0 -211
  1008. data/test/new_relic/agent/transaction_event_primitive_test.rb +0 -195
  1009. data/test/new_relic/agent/transaction_event_recorder_test.rb +0 -80
  1010. data/test/new_relic/agent/transaction_interrobang_test.rb +0 -33
  1011. data/test/new_relic/agent/transaction_metrics_test.rb +0 -113
  1012. data/test/new_relic/agent/transaction_sample_builder_test.rb +0 -215
  1013. data/test/new_relic/agent/transaction_sampler_test.rb +0 -860
  1014. data/test/new_relic/agent/transaction_state_test.rb +0 -122
  1015. data/test/new_relic/agent/transaction_test.rb +0 -1476
  1016. data/test/new_relic/agent/transaction_timings_test.rb +0 -91
  1017. data/test/new_relic/agent/utilization_data_test.rb +0 -258
  1018. data/test/new_relic/agent/vm/monotonic_gc_profiler_test.rb +0 -42
  1019. data/test/new_relic/agent/vm/mri_vm_test.rb +0 -40
  1020. data/test/new_relic/agent/vm/snapshot_test.rb +0 -13
  1021. data/test/new_relic/agent/vm_test.rb +0 -48
  1022. data/test/new_relic/agent/worker_loop_test.rb +0 -98
  1023. data/test/new_relic/agent_test.rb +0 -461
  1024. data/test/new_relic/cli/commands/deployments_test.rb +0 -136
  1025. data/test/new_relic/cli/commands/install_test.rb +0 -27
  1026. data/test/new_relic/coerce_test.rb +0 -93
  1027. data/test/new_relic/collection_helper_test.rb +0 -152
  1028. data/test/new_relic/control/class_methods_test.rb +0 -52
  1029. data/test/new_relic/control/frameworks/rails_test.rb +0 -29
  1030. data/test/new_relic/control/instance_methods_test.rb +0 -50
  1031. data/test/new_relic/control/instrumentation_test.rb +0 -41
  1032. data/test/new_relic/control_test.rb +0 -169
  1033. data/test/new_relic/data_container_tests.rb +0 -87
  1034. data/test/new_relic/dependency_detection_test.rb +0 -155
  1035. data/test/new_relic/dispatcher_test.rb +0 -60
  1036. data/test/new_relic/environment_report_test.rb +0 -107
  1037. data/test/new_relic/evil_server.rb +0 -55
  1038. data/test/new_relic/fake_collector.rb +0 -390
  1039. data/test/new_relic/fake_external_server.rb +0 -65
  1040. data/test/new_relic/fake_instance_metadata_service.rb +0 -45
  1041. data/test/new_relic/fake_rpm_site.rb +0 -35
  1042. data/test/new_relic/fake_server.rb +0 -104
  1043. data/test/new_relic/filtering_test_app.rb +0 -19
  1044. data/test/new_relic/framework_test.rb +0 -58
  1045. data/test/new_relic/http_client_test_cases.rb +0 -639
  1046. data/test/new_relic/language_support_test.rb +0 -98
  1047. data/test/new_relic/latest_changes_test.rb +0 -34
  1048. data/test/new_relic/license_test.rb +0 -125
  1049. data/test/new_relic/load_test.rb +0 -15
  1050. data/test/new_relic/local_environment_test.rb +0 -103
  1051. data/test/new_relic/marshalling_test_cases.rb +0 -183
  1052. data/test/new_relic/metric_data_test.rb +0 -144
  1053. data/test/new_relic/metric_parser/metric_parser_test.rb +0 -17
  1054. data/test/new_relic/metric_spec_test.rb +0 -144
  1055. data/test/new_relic/multiverse_helpers.rb +0 -289
  1056. data/test/new_relic/noticed_error_test.rb +0 -267
  1057. data/test/new_relic/rack/agent_hooks_test.rb +0 -44
  1058. data/test/new_relic/rack/agent_middleware_test.rb +0 -32
  1059. data/test/new_relic/rack/browser_monitoring_test.rb +0 -195
  1060. data/test/new_relic/rack/developer_mode/segment_summary_test.rb +0 -96
  1061. data/test/new_relic/rack/developer_mode_helper_test.rb +0 -136
  1062. data/test/new_relic/rack/developer_mode_test.rb +0 -96
  1063. data/test/new_relic/transaction_ignoring_test_cases.rb +0 -102
  1064. data/test/nullverse/default_source_require_test.rb +0 -21
  1065. data/test/nullverse/nullverse_helper.rb +0 -10
  1066. data/test/performance/README.md +0 -175
  1067. data/test/performance/lib/performance.rb +0 -38
  1068. data/test/performance/lib/performance/baseline.rb +0 -36
  1069. data/test/performance/lib/performance/baseline_compare_reporter.rb +0 -103
  1070. data/test/performance/lib/performance/baseline_save_reporter.rb +0 -24
  1071. data/test/performance/lib/performance/console_reporter.rb +0 -66
  1072. data/test/performance/lib/performance/formatting_helpers.rb +0 -22
  1073. data/test/performance/lib/performance/hako_client.rb +0 -31
  1074. data/test/performance/lib/performance/hako_reporter.rb +0 -26
  1075. data/test/performance/lib/performance/instrumentation/cpu_usage.rb +0 -26
  1076. data/test/performance/lib/performance/instrumentation/gc_stats.rb +0 -56
  1077. data/test/performance/lib/performance/instrumentation/perf_tools.rb +0 -30
  1078. data/test/performance/lib/performance/instrumentation/stackprof.rb +0 -46
  1079. data/test/performance/lib/performance/instrumentor.rb +0 -96
  1080. data/test/performance/lib/performance/json_reporter.rb +0 -15
  1081. data/test/performance/lib/performance/platform.rb +0 -31
  1082. data/test/performance/lib/performance/reporting.rb +0 -36
  1083. data/test/performance/lib/performance/result.rb +0 -104
  1084. data/test/performance/lib/performance/runner.rb +0 -221
  1085. data/test/performance/lib/performance/table.rb +0 -105
  1086. data/test/performance/lib/performance/test_case.rb +0 -152
  1087. data/test/performance/lib/performance/timer.rb +0 -40
  1088. data/test/performance/script/baselines +0 -102
  1089. data/test/performance/script/mega-runner +0 -37
  1090. data/test/performance/script/runner +0 -131
  1091. data/test/performance/suites/active_record.rb +0 -26
  1092. data/test/performance/suites/active_record_subscriber.rb +0 -100
  1093. data/test/performance/suites/agent_attributes.rb +0 -62
  1094. data/test/performance/suites/config.rb +0 -35
  1095. data/test/performance/suites/datastores.rb +0 -59
  1096. data/test/performance/suites/error_collector.rb +0 -28
  1097. data/test/performance/suites/external_segment.rb +0 -82
  1098. data/test/performance/suites/marshalling.rb +0 -148
  1099. data/test/performance/suites/queue_time.rb +0 -21
  1100. data/test/performance/suites/rack_middleware.rb +0 -136
  1101. data/test/performance/suites/redis.rb +0 -45
  1102. data/test/performance/suites/rules_engine.rb +0 -35
  1103. data/test/performance/suites/rum_autoinsertion.rb +0 -75
  1104. data/test/performance/suites/segment_terms_rule.rb +0 -27
  1105. data/test/performance/suites/sql_obfuscation.rb +0 -50
  1106. data/test/performance/suites/startup.rb +0 -12
  1107. data/test/performance/suites/stats_hash.rb +0 -31
  1108. data/test/performance/suites/thread_profiling.rb +0 -116
  1109. data/test/performance/suites/trace_execution_scoped.rb +0 -31
  1110. data/test/performance/suites/transaction_tracing.rb +0 -106
  1111. data/test/script/before_install/gemstash_mirror.sh +0 -10
  1112. data/test/script/before_script/install_mongodb.sh +0 -12
  1113. data/test/script/ci.sh +0 -15
  1114. data/test/script/external_server.rb +0 -31
  1115. data/test/script/path_hash.rb +0 -49
  1116. data/test/test_helper.rb +0 -59
  1117. data/ui/helpers/developer_mode_helper.rb +0 -325
  1118. data/ui/helpers/google_pie_chart.rb +0 -54
  1119. data/ui/views/layouts/newrelic_default.rhtml +0 -48
  1120. data/ui/views/newrelic/_explain_plans.rhtml +0 -27
  1121. data/ui/views/newrelic/_sample.rhtml +0 -20
  1122. data/ui/views/newrelic/_segment.rhtml +0 -28
  1123. data/ui/views/newrelic/_segment_limit_message.rhtml +0 -1
  1124. data/ui/views/newrelic/_segment_row.rhtml +0 -12
  1125. data/ui/views/newrelic/_show_sample_detail.rhtml +0 -24
  1126. data/ui/views/newrelic/_show_sample_sql.rhtml +0 -24
  1127. data/ui/views/newrelic/_show_sample_summary.rhtml +0 -3
  1128. data/ui/views/newrelic/_sql_row.rhtml +0 -16
  1129. data/ui/views/newrelic/_stack_trace.rhtml +0 -15
  1130. data/ui/views/newrelic/_table.rhtml +0 -12
  1131. data/ui/views/newrelic/explain_sql.rhtml +0 -43
  1132. data/ui/views/newrelic/file/images/arrow-close.png +0 -0
  1133. data/ui/views/newrelic/file/images/arrow-open.png +0 -0
  1134. data/ui/views/newrelic/file/images/blue_bar.gif +0 -0
  1135. data/ui/views/newrelic/file/images/file_icon.png +0 -0
  1136. data/ui/views/newrelic/file/images/gray_bar.gif +0 -0
  1137. data/ui/views/newrelic/file/images/new-relic-rpm-desktop.gif +0 -0
  1138. data/ui/views/newrelic/file/images/new_relic_rpm_desktop.gif +0 -0
  1139. data/ui/views/newrelic/file/images/textmate.png +0 -0
  1140. data/ui/views/newrelic/file/javascript/jquery-1.4.2.js +0 -6243
  1141. data/ui/views/newrelic/file/javascript/transaction_sample.js +0 -123
  1142. data/ui/views/newrelic/file/stylesheets/style.css +0 -490
  1143. data/ui/views/newrelic/index.rhtml +0 -70
  1144. data/ui/views/newrelic/sample_not_found.rhtml +0 -2
  1145. data/ui/views/newrelic/show_sample.rhtml +0 -81
  1146. data/ui/views/newrelic/threads.rhtml +0 -45
  1147. data/vendor/gems/metric_parser-0.1.0.pre1/.specification +0 -116
  1148. data/vendor/gems/metric_parser-0.1.0.pre1/lib/metric_parser.rb +0 -5
  1149. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser.rb +0 -70
  1150. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/action_mailer.rb +0 -18
  1151. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/active_merchant.rb +0 -35
  1152. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/active_record.rb +0 -37
  1153. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/apdex.rb +0 -93
  1154. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/background_transaction.rb +0 -11
  1155. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/client.rb +0 -50
  1156. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/controller.rb +0 -71
  1157. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/controller_cpu.rb +0 -47
  1158. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/controller_ext.rb +0 -21
  1159. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/database.rb +0 -52
  1160. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/database_pool.rb +0 -28
  1161. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/dot_net.rb +0 -32
  1162. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/dot_net_parser.rb +0 -21
  1163. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/errors.rb +0 -15
  1164. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/external.rb +0 -59
  1165. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/frontend.rb +0 -44
  1166. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/gc.rb +0 -24
  1167. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/hibernate_session.rb +0 -11
  1168. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/java.rb +0 -35
  1169. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/java_parser.rb +0 -21
  1170. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/jsp.rb +0 -38
  1171. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/jsp_tag.rb +0 -11
  1172. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/mem_cache.rb +0 -56
  1173. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/metric_parser.rb +0 -138
  1174. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/middleware.rb +0 -33
  1175. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/nested.rb +0 -23
  1176. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/orm.rb +0 -31
  1177. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/other_transaction.rb +0 -44
  1178. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/servlet.rb +0 -11
  1179. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/servlet_context_listener.rb +0 -11
  1180. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/servlet_filter.rb +0 -11
  1181. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/servlet_init.rb +0 -11
  1182. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/solr.rb +0 -31
  1183. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/solr_request_handler.rb +0 -19
  1184. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/spring.rb +0 -58
  1185. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/spring_controller.rb +0 -10
  1186. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/spring_view.rb +0 -10
  1187. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/struts_action.rb +0 -24
  1188. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/struts_result.rb +0 -24
  1189. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/version.rb +0 -9
  1190. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/view.rb +0 -74
  1191. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/web_frontend.rb +0 -22
  1192. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/web_service.rb +0 -18
  1193. data/vendor/gems/metric_parser-0.1.0.pre1/lib/new_relic/metric_parser/web_transaction.rb +0 -137
@@ -0,0 +1,21 @@
1
+ name: "Close stale issues"
2
+ on:
3
+ schedule:
4
+ - cron: "0 0 * * *"
5
+
6
+ jobs:
7
+ stale:
8
+ runs-on: ubuntu-latest
9
+ steps:
10
+ - uses: actions/stale@v3
11
+ with:
12
+ repo-token: ${{ secrets.GITHUB_TOKEN }}
13
+ stale-issue-message: 'This has been marked stale after 30 days with no activity. It will be closed in 5 days if there is no activity.'
14
+ stale-pr-message: 'Stale pull request message'
15
+ days-before-stale: 30
16
+ days-before-close: 5
17
+ stale-issue-label: 'stale'
18
+ exempt-issue-labels: 'good first issue,help wanted,in progress,on hold,in review,roadmap'
19
+ stale-pr-label: 'stale'
20
+ exempt-pr-labels: 'on hold,in review'
21
+
data/.gitignore CHANGED
@@ -1,4 +1,5 @@
1
1
  Gemfile.lock
2
+ Guard*
2
3
  .DS\_Store
3
4
  .svn/
4
5
  *~
@@ -14,6 +15,7 @@ tags
14
15
  *.swp
15
16
  *.swo
16
17
 
18
+ /doc/
17
19
  /log/
18
20
  /lerg/
19
21
  gems/newrelic_rpm.gemspec
@@ -24,4 +26,11 @@ lib/new_relic/build.rb
24
26
  .bundle
25
27
  .yardoc
26
28
  artifacts/
29
+ test/performance/log/
27
30
  test/performance/script/log/
31
+ infinite_tracing/log/
32
+ infinite_tracing/test/new_relic/infinite_tracing/log
33
+ test/fixtures/cross_agent_tests/*/README.md
34
+ node_modules/
35
+ yarn.lock
36
+ errors.txt
data/.yardopts CHANGED
@@ -2,20 +2,25 @@
2
2
  --api public
3
3
  lib/new_relic/agent.rb
4
4
  lib/new_relic/agent/method_tracer.rb
5
+ lib/new_relic/agent/distributed_tracing.rb
6
+ lib/new_relic/agent/distributed_trace_payload.rb
7
+ lib/new_relic/agent/external.rb
5
8
  lib/new_relic/agent/instrumentation/controller_instrumentation.rb
6
9
  lib/new_relic/agent/instrumentation/rack.rb
7
10
  lib/new_relic/agent/instrumentation/metric_frame.rb
8
11
  lib/new_relic/agent/stats_engine/metric_stats.rb
9
12
  lib/new_relic/agent/datastores.rb
13
+ lib/new_relic/agent/messaging.rb
10
14
  lib/new_relic/agent/sql_sampler.rb
15
+ lib/new_relic/agent/tracer.rb
11
16
  lib/new_relic/agent/transaction.rb
12
17
  lib/new_relic/agent/transaction_sampler.rb
13
- lib/new_relic/rack/developer_mode.rb
14
18
  lib/new_relic/rack/agent_hooks.rb
15
19
  lib/new_relic/rack/browser_monitoring.rb
16
20
  lib/new_relic/rack/error_collector.rb
17
21
  lib/new_relic/rack.rb
22
+ lib/new_relic/agent/transaction/external_request_segment.rb
18
23
  -
19
24
  LICENSE
20
- CHANGELOG
25
+ CHANGELOG.md
21
26
  CONTRIBUTING.md
@@ -1,5 +1,1135 @@
1
1
  # New Relic Ruby Agent Release Notes #
2
2
 
3
+ ## v6.13.1
4
+
5
+ * **Bugfix: obfuscating URLs to external services no longer modifying original URI**
6
+
7
+ A recent change to the Ruby agent to obfuscate URIs sent to external services had the unintended side-effect of removing query parameters
8
+ from the original URI. This is fixed to obfuscate while also preserving the original URI.
9
+
10
+ Thanks to @VictorJimenezKwast for pinpointing and helpful unit test to demonstrate.
11
+
12
+ ## v6.13.0
13
+
14
+ * **Bugfix: never use redirect host when accessing preconnect endpoint**
15
+
16
+ When connecting to New Relic, the Ruby Agent uses the value in `Agent.config[:host]` to post a request to the New Relic preconnect endpoint. This endpoint returns a "redirect host" which is the URL to which agents send data from that point on.
17
+
18
+ Previously, if the agent needed to reconnect to the collector, it would incorrectly use this redirect host to call the preconnect
19
+ endpoint, when it should have used the original configured value in `Agent.config[:host]`. The agent now uses the correct host
20
+ for all calls to preconnect.
21
+
22
+ * **Bugfix: calling `add_custom_attributes` no longer modifies the params of the caller**
23
+
24
+ The previous agent's improvements to recording attributes at the span level had an unexpected
25
+ side-effect of modifying the params passed to the API call as duplicated attributes were deleted
26
+ in the process. This is now fixed and params passed in are no longer modified.
27
+
28
+ Thanks to Pete Johns (@johnsyweb) for the PR that resolves this bug.
29
+
30
+ * **Bugfix: `http.url` query parameters spans are now obfuscated**
31
+
32
+ Previously, the agent was recording the full URL of the external requests, including
33
+ the query and fragment parts of the URL as part of the attributes on the external request
34
+ span. This has been fixed so that the URL is obfuscated to filter out potentially sensitive data.
35
+
36
+ * **Use system SSL certificates by default**
37
+
38
+ The Ruby agent previously used a root SSL/TLS certificate bundle by default. Now the agent will attempt to use
39
+ the default system certificates, but will fall back to the bundled certs if there is an issue (and log that this occurred).
40
+
41
+ * **Bugfix: reduce allocations for segment attributes**
42
+
43
+ Previously, every segment received an `Attributes` object on initialization. The agent now lazily creates attributes
44
+ on segments, resulting in a significant reduction in object allocations for a typical transaction.
45
+
46
+ * **Bugfix: eliminate errors around Rake::VERSION with Rails**
47
+
48
+ When running a Rails application with rake tasks, customers could see the following error:
49
+
50
+ * **Prevent connecting agent thread from hanging on shutdown**
51
+
52
+ A bug in `Net::HTTP`'s Gzip decoder can cause the (un-catchable)
53
+ thread-kill exception to be replaced with a (catchable) `Zlib` exception,
54
+ which prevents a connecting agent thread from exiting during shutdown,
55
+ causing the Ruby process to hang indefinitely.
56
+ This workaround checks for an `aborting` thread in the `#connect` exception handler
57
+ and re-raises the exception, allowing a killed thread to continue exiting.
58
+
59
+ Thanks to Will Jordan (@wjordan) for chasing this one down and patching with tests.
60
+
61
+ * **Fix error messages about Rake instrumentation**
62
+
63
+ When running a Rails application with rake tasks, customers could see the following error in logs resulting from
64
+ a small part of rake functionality being loaded with the Rails test runner:
65
+
66
+ ```
67
+ ERROR : Error while detecting rake_instrumentation:
68
+ ERROR : NameError: uninitialized constant Rake::VERSION
69
+ ```
70
+
71
+ Such error messages should no longer appear in this context.
72
+
73
+ Thanks to @CamilleDrapier for pointing out this issue.
74
+
75
+ * **Remove NewRelic::Metrics**
76
+
77
+ The `NewRelic::Metrics` module has been removed from the agent since it is no longer used.
78
+
79
+ Thanks to @csaura for the contribution!
80
+
81
+ ## v6.12.0
82
+
83
+ * The New Relic Ruby Agent is now open source under the [Apache 2 license](LICENSE)
84
+ and you can now observe the project roadmap. See our [Contributing guide](https://github.com/newrelic/newrelic-ruby-agent/blob/main/CONTRIBUTING.md)
85
+ and [Code of Conduct](https://github.com/newrelic/.github/blob/master/CODE_OF_CONDUCT.md) for details on contributing!
86
+
87
+ * **Security: Updated all uses of Rake to >= 12.3.3**
88
+
89
+ All versions of Rake testing prior to 12.3.3 were removed to address
90
+ [CVE-2020-8130](https://nvd.nist.gov/vuln/detail/CVE-2020-8130).
91
+ No functionality in the agent was removed nor deprecated with this change, and older versions
92
+ of rake are expected to continue to work as they have in the past. However, versions of
93
+ rake < 12.3.3 are no longer tested nor supported.
94
+
95
+ * **Bugfix: fixes an error capturing content length in middleware on multi-part responses**
96
+
97
+ In the middleware tracing, the `Content-Length` header is sometimes returned as an array of
98
+ values when content is a multi-part response. Previously, the agent would fail with
99
+ "NoMethodError: undefined method `to_i` for Array" Error. This bug is now fixed and
100
+ multi-part content lengths are summed for a total when an `Array` is present.
101
+
102
+ * **Added support for auto-instrumenting Mongo gem versions 2.6 to 2.12**
103
+
104
+ * **Bugfix: MongoDB instrumentation did not handle CommandFailed events when noticing errors**
105
+
106
+ The mongo gem sometimes returns a CommandFailed object instead of a CommandSucceeded object with
107
+ error attributes populated. The instrumentation did not handle noticing errors on CommandFailed
108
+ objects and resulted in logging an error and backtrace to the log file.
109
+
110
+ Additionally, a bug in recording the metric for "findAndModify" as all lowercased "findandmodify"
111
+ for versions 2.1 through 2.5 was fixed.
112
+
113
+ * **Bugfix: Priority Sampler causes crash in high throughput environents in rare cases**
114
+
115
+ Previously, the priority sampling buffer would, in rare cases, generate an error in high-throughput
116
+ environments once capacity is reached and the sampling algorthym engages. This issue is fixed.
117
+
118
+ * **Additional Transaction Information applied to Span Events**
119
+
120
+ When Distributed Tracing and/or Infinite Tracing are enabled, the Agent will now incorporate additional information from the Transaction Event on to the root Span Event of the transaction.
121
+
122
+ The following items are affected:
123
+ * Custom attribute values applied to the Transaction via our [add_custom_attributes](http://www.rubydoc.info/github/newrelic/newrelic-ruby-agent/NewRelic/Agent#add_custom_attributes-instance_method) API method.
124
+ * Request parameters: `request.parameters.*`
125
+ * Request headers: `request.headers.*`
126
+ * Response headers: `response.headers.*`
127
+ * Resque job arguments: `job.resque.args.*`
128
+ * Sidekiq job arguments: `job.sidekiq.args.*`
129
+ * Messaging arguments: `message.*`
130
+ * `httpResponseCode` (deprecated in this version; see note below)/`http.statusCode`
131
+ * `response.status`
132
+ * `request.uri`
133
+ * `request.method`
134
+ * `host.displayName`
135
+
136
+ * **Security Recommendation**
137
+
138
+ Review your Transaction attributes [include](https://docs.newrelic.com/docs/agents/ruby-agent/attributes/enable-disable-attributes-ruby#transaction_events-attributes-include) and [exclude](https://docs.newrelic.com/docs/agents/ruby-agent/attributes/enable-disable-attributes-ruby#transaction_events-attributes-exclude) configurations. Any attribute include or exclude settings specific to Transaction Events should be applied
139
+ to your Span attributes [include](https://docs.newrelic.com/docs/agents/ruby-agent/attributes/enable-disable-attributes-ruby#span-events-attributes-include) and [exclude](https://docs.newrelic.com/docs/agents/ruby-agent/attributes/enable-disable-attributes-ruby#span-events-attributes-exclude) configuration or your global attributes [include](https://docs.newrelic.com/docs/agents/ruby-agent/attributes/enable-disable-attributes-ruby#attributes-include) and [exclude](https://docs.newrelic.com/docs/agents/ruby-agent/attributes/enable-disable-attributes-ruby#attributes-exclude) configuration.
140
+
141
+ * **Agent attribute deprecation: httpResponseCode**
142
+
143
+ Starting in this agent version, the [agent attribute](https://docs.newrelic.com/docs/agents/ruby-agent/attributes/ruby-agent-attributes#attributes) `httpResponseCode` (string value) has been deprecated. Customers can begin using `http.statusCode`
144
+ (integer value) immediately, and `httpResponseCode` will be removed in the agent's next major version update.
145
+
146
+ * **Bugfix: Eliminate warnings for distributed tracing when using sidekiq**
147
+
148
+ Previously, using sidekiq with distributed tracing disabled resulted in warning messages\
149
+ `WARN : Not configured to accept distributed trace headers`\
150
+ ` WARN : Not configured to insert distributed trace headers`\
151
+ These messages no longer appear.
152
+
153
+ ## v6.11.0
154
+
155
+ * **Infinite Tracing**
156
+
157
+ This release adds support for [Infinite Tracing](https://docs.newrelic.com/docs/understand-dependencies/distributed-tracing/enable-configure/enable-distributed-tracing). Infinite Tracing observes 100% of your distributed traces and provides visualizations for the most actionable data. With Infinite Tracing, you get examples of errors and long-running traces so you can better diagnose and troubleshoot your systems.
158
+
159
+ Configure your agent to send traces to a trace observer in New Relic Edge. View distributed traces through New Relic’s UI. There is no need to install a collector on your network.
160
+
161
+ Infinite Tracing is currently available on a sign-up basis. If you would like to participate, please contact your sales representative.
162
+
163
+ * **Bugfix: Cross Application Tracing (CAT) adds a missing field to response**
164
+
165
+ Previously, the Ruby agent's Cross Application Tracing header was missing a reserved field that would lead to an error
166
+ in the Go agent's processing of incoming headers from the Ruby agent. This fix adds that missing field to the headers, eliminating
167
+ the issue with traces involving the Ruby agent and the Go agent.
168
+
169
+ * **Bugfix: Environment Report now supports Rails >= 6.1**
170
+
171
+ Previously, users of Rails 6.1 would see the following deprecation warning appear when the Ruby agent attempted to
172
+ collect enviroment data: `DEPRECATION WARNING: [] is deprecated and will be removed from Rails 6.2`. These deprecation methods
173
+ no longer appear.
174
+
175
+ Thanks to Sébastien Dubois (sedubois) for reporting this issue and for the contribution!
176
+
177
+ * **Added distributed tracing to Sidekiq jobs**
178
+
179
+ Previously, Sidekiq jobs were not included in portions of <a href="https://docs.newrelic.com/docs/understand-dependencies/distributed-tracing/get-started/introduction-distributed-tracing">distributed traces</a> captured by the Ruby agent. Now you can view distributed
180
+ traces that include Sidekiq jobs instrumented by the Ruby agent.
181
+
182
+ Thanks to andreaseger for the contribution!
183
+
184
+ * **Bugfix: Eliminate warnings appearing when using `add_method_tracer` with Ruby 2.7**
185
+
186
+ Previously, using `add_method_tracer` with Ruby 2.7 to trace a method that included keyword arguments resulted in warning messages:
187
+ `warning: Using the last argument as keyword parameters is deprecated; maybe ** should be added to the call`. These messages no
188
+ longer appear.
189
+
190
+ Thanks to Harm de Wit and Atsuo Fukaya for reporting the issue!
191
+
192
+ ## v6.10.0
193
+
194
+ * **Error attributes now added to each span that exits with an error or exception**
195
+
196
+ Error attributes `error.class` and `error.message` are now included on the span event in which an error
197
+ or exception was noticed, and, in the case of unhandled exceptions, on any ancestor spans that also exit with an error.
198
+ The public API method `notice_error` now attaches these error attributes to the currently executing span.
199
+
200
+ <a href="https://docs.newrelic.com/docs/apm/distributed-tracing/ui-data/understand-use-distributed-tracing-data#rules-limits">Spans with error details are now highlighted red in the Distributed Tracing UI</a>, and error details will expose the associated
201
+ `error.class` and `error.message`. It is also now possible to see when an exception leaves the boundary of the span,
202
+ and if it is caught in an ancestor span without reaching the entry span. NOTE: This “bubbling up” of exceptions will impact
203
+ the error count when compared to prior behavior for the same trace. It is possible to have a trace that now has span errors
204
+ without the trace level showing an error.
205
+
206
+ If multiple errors occur on the same span, only the most recent error information is added to the attributes. Prior errors on the same span are overwritten.
207
+
208
+ These span event attributes conform to <a href="https://docs.newrelic.com/docs/agents/manage-apm-agents/agent-data/manage-errors-apm-collect-ignore-or-mark-expected#ignore">ignored errors</a> and <a href="https://docs.newrelic.com/docs/agents/manage-apm-agents/agent-data/manage-errors-apm-collect-ignore-or-mark-expected#expected">expected errors</a>.
209
+
210
+ * **Added tests for latest Grape / Rack combination**
211
+
212
+ For a short period of time, the latest versions of Grape and Rack had compatibility issues.
213
+ Generally, Rack 2.1.0 should be avoided in all cases due to breaking changes in many gems
214
+ reliant on Rack. We recommend using either Rack <= 2.0.9, or using latest Rack when using Grape
215
+ (2.2.2 at the time of this writing).
216
+
217
+ * **Bugfix: Calculate Content-Length in bytes**
218
+
219
+ Previously, the Content-Length HTTP header would be incorrect after injecting the Browser Monitoring
220
+ JS when the response contained Unicode characters because the value was not calculated in bytes.
221
+ The Content-Length is now correctly updated.
222
+
223
+ Thanks to thaim for the contribution!
224
+
225
+ * **Bugfix: Fix Content-Length calculation when response is nil**
226
+
227
+ Previously, calculating the Content-Length HTTP header would result in a `NoMethodError` in the case of
228
+ a nil response. These errors will no longer occur in such a case.
229
+
230
+ Thanks to Johan Van Ryseghem for the contribution!
231
+
232
+ * **Bugfix: DecoratingFormatter now logs timestamps as millisecond Integers**
233
+
234
+ Previously the agent sent timestamps as a Float with milliseconds as part of the
235
+ fractional value. Logs in Context was changed to only accept Integer values and this
236
+ release changes DecoratingFormatter to match.
237
+
238
+ * **Added --force option to `newrelic install` cli command to allow overwriting newrelic.yml**
239
+
240
+ * **Bugfix: The fully qualified hostname now works correctly for BSD and Solaris**
241
+
242
+ Previously, when running on systems such as BSD and Solaris, the agent was unable to determine the fully
243
+ qualified domain name, which is used to help link Ruby agent data with data from New Relic Infrastructure.
244
+ This information is now successfully collected on various BSD distros and Solaris.
245
+
246
+
247
+ ## v6.9.0
248
+
249
+ * **Added support for W3C Trace Context, with easy upgrade from New Relic trace context**
250
+
251
+ * [Distributed Tracing now supports W3C Trace Context headers](https://docs.newrelic.com/docs/understand-dependencies/distributed-tracing/get-started/introduction-distributed-tracing#w3c-support) for HTTP protocols when distributed tracing is enabled. Our implementation can accept and emit both
252
+ the W3C trace header format and the New Relic trace header format. This simplifies
253
+ agent upgrades, allowing trace context to be propagated between services with older
254
+ and newer releases of New Relic agents. W3C trace header format will always be
255
+ accepted and emitted. New Relic trace header format will be accepted, and you can
256
+ optionally disable emission of the New Relic trace header format.
257
+
258
+ * When distributed tracing is enabled by setting `distributed_tracing.enabled` to `true`,
259
+ the Ruby agent will now accept W3C's `traceparent` and `tracestate` headers when
260
+ calling `DistributedTracing.accept_distributed_trace_headers` or automatically via
261
+ `http` instrumentation. When calling `DistributedTracing.insert_distributed_trace_headers`,
262
+ or automatically via `http` instrumentation, the Ruby agent will include the W3C
263
+ headers along with the New Relic distributed tracing header, unless the New Relic
264
+ trace header format is disabled by setting `exclude_newrelic_header` setting to `true`.
265
+
266
+ * Added `DistributedTracing.accept_distributed_trace_headers` API for accepting both
267
+ New Relic and W3C TraceContext distributed traces.
268
+
269
+ * Deprecated `DistributedTracing.accept_distributed_trace_payload` which will be removed
270
+ in a future major release.
271
+
272
+ * Added `DistributedTracing.insert_distributed_trace_headers` API for adding outbound
273
+ distributed trace headers. Both W3C TraceContext and New Relic formats will be
274
+ included unless `distributed_tracing.exclude_newrelic_header: true`.
275
+
276
+ * Deprecated `DistributedTracing.create_distributed_trace_payload` which will be removed
277
+ in a future major release.
278
+
279
+ Known Issues and Workarounds
280
+
281
+ * If a .NET agent is initiating traces as the root service, do not upgrade your
282
+ downstream Ruby New Relic agents to this agent release.
283
+
284
+ * **Official Ruby 2.7 support**
285
+
286
+ The Ruby agent has been verified to run with Ruby 2.7.0.
287
+
288
+ * **Reduced allocations when tracing transactions using API calls**
289
+
290
+ Default empty hashes for `options` parameter were not frozen, leading to
291
+ excessive and unnecessary allocations when calling APIs for tracing transactions.
292
+
293
+ Thanks to Joel Turkel (jturkel) for the contribution!
294
+
295
+ * **Bugfix for Resque worker thread race conditions**
296
+
297
+ Recent changes in Rack surfaced issues marshalling data for resque, surfaced a potential race-condition with closing out the worker-threads before flushing the data pipe. This
298
+ is now fixed.
299
+
300
+ Thanks to Bertrand Paquet (bpaquet) for the contribution!
301
+
302
+ * **Bugfix for Content-Length when injecting Browser Monitoring JS**
303
+
304
+ The Content-Length HTTP header would be incorrect after injecting the Browser Monitoring
305
+ JS into the HEAD tag of the HTML source with Content-Length and lead to the HTML BODY content
306
+ being truncated in some cases. The Content-Length is now correctly updated after injecting the
307
+ Browser Monitoring JS script.
308
+
309
+ Thanks to Slava Kardakov (ojab) for the contribution!
310
+
311
+ ## v6.8.0
312
+
313
+ * **Initial Ruby 2.7 support**
314
+
315
+ The Ruby agent has been verified to run with Ruby 2.7.0-preview1.
316
+
317
+ * **New API method to add custom attributes to Spans**
318
+
319
+ New API method for adding custom attributes to spans. Previously, custom
320
+ attributes were only available at the Transaction level. Now, with Span
321
+ level custom attributes, more granular tagging of events is possible for
322
+ easier isolation and review of trace events. For more information:
323
+
324
+ * [`Agent#add_custom_span_attributes`](https://www.rubydoc.info/github/newrelic/newrelic-ruby-agent/NewRelic/Agent#add_custom_span_attributes)
325
+
326
+ * **Enables ability to migrate to Configurable Security Policies (CSP) on a per agent
327
+ basis for accounts already using High Security Mode (HSM).**
328
+
329
+ When both [HSM](https://docs.newrelic.com/docs/agents/manage-apm-agents/configuration/high-security-mode) and [CSP](https://docs.newrelic.com/docs/agents/manage-apm-agents/configuration/enable-configurable-security-policies) are enabled for an account, an agent (this version or later)
330
+ can successfully connect with either `high_security: true` or the appropriate
331
+ `security_policies_token` configured. `high_security` has been added as part of
332
+ the preconnect payload.
333
+
334
+ * **Bugfix for Logs in Context combined with act-fluent-logger-rails**
335
+
336
+ Previously, when using the Ruby agent's Logs in Context logger
337
+ to link logging data with trace and entity metadata for an
338
+ improved experience in the UI, customers who were also using
339
+ the `act-fluent-logger-rails` gem would see a `NoMethodError`
340
+ for `clear_tags!` that would interfere with the use of this
341
+ feature. This error no longer appears, allowing customers to
342
+ combine the use of Logs in Context with the use of this gem.
343
+
344
+ Please note that the Logs in Context logger does not support
345
+ tagged logging; if you are initializing your logger with a
346
+ `log_tags` argument, your custom tags may not appear on the
347
+ final version of your logs.
348
+
349
+ * **Bugfix for parsing invalid newrelic.yml**
350
+
351
+ Previously, if the newrelic.yml configuration file was invalid, and the agent
352
+ could not start as a result, the agent would not log any indication of
353
+ the problem.
354
+
355
+ This version of the agent will emit a FATAL message to STDOUT when this scenario
356
+ occurs so that customers can address issues with newrelic.yml that prevent startup.
357
+
358
+ * **Configuration options containing the terms "whitelist" and "blacklist" deprecated**
359
+
360
+ The following local configuration settings have been deprecated:
361
+
362
+ * `autostart.blacklisted_constants`: use `autostart.denylisted_constants` instead.
363
+ * `autostart.blacklisted_executables`: use `autostart.denylisted_executables` instead.
364
+ * `autostart.blacklisted_rake_tasks`: use `autostart.denylisted_rake_tasks` instead.
365
+ * `strip_exception_messages.whitelist`: use `strip_exception_messages.allowed_classes` instead.
366
+
367
+ * **Bugfix for module loading and constant resolution in Rails**
368
+
369
+ Starting in version 6.3, the Ruby agent has caused module loading and constant
370
+ resolution to sometimes fail, which caused errors in some Rails applications.
371
+ These errors were generally `NoMethodError` exceptions or I18n errors
372
+ `translation missing` or `invalid locale`. These errors would not appear if the agent
373
+ was removed from the application's Gemfile.
374
+ This version of the agent fixes these issues with module loading and constant
375
+ resolution, so these errors no longer occur.
376
+
377
+ * **Bugfix: failed to get urandom**
378
+
379
+ Previous versions of the agent would fail unexpectedly when the Ruby process used
380
+ every available file descriptor. The failures would include this message:
381
+ ```
382
+ ERROR : RuntimeError: failed to get urandom
383
+ ```
384
+ This version of the agent uses a different strategy for generating random IDs, and
385
+ will not fail in the same way when no file descriptors are available.
386
+
387
+ ## v6.7.0
388
+
389
+ * **Trace and Entity Metadata API**
390
+
391
+ Several new API methods have been added to the agent:
392
+ * [`Agent#linking_metadata`](https://www.rubydoc.info/github/newrelic/newrelic-ruby-agent/NewRelic/Agent#linking_metadata-instance_method)
393
+ * [`Tracer#trace_id`](https://www.rubydoc.info/github/newrelic/newrelic-ruby-agent/NewRelic/Agent/Tracer#trace_id-class_method)
394
+ * [`Tracer#span_id`](https://www.rubydoc.info/github/newrelic/newrelic-ruby-agent/NewRelic/Agent/Tracer#span_id-class_method)
395
+ * [`Tracer#sampled?`](https://www.rubydoc.info/github/newrelic/newrelic-ruby-agent/NewRelic/Agent/Tracer#sampled?-class_method)
396
+
397
+ These API methods allow you to access information that can be used to link data of your choosing to a trace or entity.
398
+
399
+ * **Logs in Context**
400
+
401
+ This version of the agent includes a logger, which can be used in place of `::Logger`
402
+ from the standard library, or `ActiveSupport::Logger` from Rails. This logger
403
+ leverages the new trace and entity metadata API to decorate log statements with entity
404
+ and trace metadata, so they can be correlated together in the New Relic UI.
405
+
406
+ For more information on how to use logs in context, see https://docs.newrelic.com/docs/enable-logs-context-ruby
407
+
408
+ * **Project metadata in Gemspec**
409
+
410
+ Project metadata has been added to the gemspec file. This means our Rubygems page will allow users to more easily
411
+ access the agent's source code, raise issues, and read the changelog.
412
+
413
+ Thanks to Orien Madgwick for the contribution!
414
+
415
+ ## v6.6.0
416
+
417
+ * **Bugfix for ActionCable Instrumentation**
418
+
419
+ Previous versions of the agent sometimes caused application crashes with some versions
420
+ of ActionCable. The application would exit quickly after startup with the error:
421
+ `uninitialized constant ActionCable::Engine`.
422
+
423
+ Version 6.6.0 of the agent no longer crashes in this way.
424
+
425
+
426
+ * **Handling of disabling Error Collection**
427
+
428
+ When the agent first starts, it begins collecting Error Events and Traces before
429
+ fetching configuration from New Relic. In previous versions of the agent, those
430
+ events or traces would be sent to New Relic, even if _Error Collection_ is disabled in
431
+ the application's server-side configuration.
432
+
433
+ Version 6.6.0 of the agent drops all collected Error Events and Traces if the
434
+ configuration from the server disables _Error Collection_.
435
+
436
+ ## v6.5.0
437
+
438
+ * **Change to default setting for ActiveRecord connection resolution**
439
+
440
+ Due to incompatibilities between the faster ActiveRecord connection resolution
441
+ released in v6.3.0 of the agent and other gems which patch ActiveRecord,
442
+ `backport_fast_active_record_connection_lookup` will now be set to `false` by default.
443
+ Because it results in a significant performance improvement, we recommend customers
444
+ whose environments include ActiveRecord change this setting to `true`
445
+ _unless_ they are using other gems which measure ActiveRecord performance, which may
446
+ lose functionality when combined with this setting. If unsure whether to enable
447
+ `backport_fast_active_record_connection_lookup`, we recommend enabling it in a
448
+ development environment to make sure other gems which patch ActiveRecord are still
449
+ working as expected.
450
+
451
+ * **Bugfix for ActiveStorage instrumentation error**
452
+
453
+ Version 6.4.0 of the agent introduced a bug that interfered with ActiveStorage
454
+ callbacks, resulting in the agent being unable to instrument ActiveStorage operations.
455
+ ActiveStorage segments are now correctly recorded.
456
+
457
+ * **Bugfix for ActiveRecord 4.1 and 4.2 exception logging**
458
+
459
+ Version 6.3.0 of the agent introduced a bug that prevented ActiveRecord versions 4.1
460
+ and 4.2 from logging exceptions that occurred within a database transaction. This
461
+ version of the agent restores the exception logging functionality from previous agent
462
+ versions.
463
+ Thanks to Oleksiy Kovyrin for the contribution!
464
+
465
+ ## v6.4.0
466
+
467
+ * **Custom Metadata Collection**
468
+
469
+ The agent now collects environment variables prefixed by `NEW_RELIC_METADATA_`. These
470
+ may be added to transaction events to provide context between your Kubernetes cluster
471
+ and your services. For details on the behavior, see
472
+ [this blog post](https://blog.newrelic.com/engineering/monitoring-application-performance-in-kubernetes/).
473
+
474
+ * **Bugfix for faster ActiveRecord connection resolution**
475
+
476
+ Version 6.3.0 of the agent backported the faster ActiveRecord connection resolution
477
+ from Rails 6.0 to previous versions, but the implementation caused certain other gems
478
+ which measured ActiveRecord performance to stop working. This version of the agent
479
+ changes the implementation of this performance improvement so no such conflicts occur.
480
+
481
+ * **Bugfix for Grape instrumentation error**
482
+
483
+ Previous versions of the agent would fail to install Grape instrumentation in Grape
484
+ versions 1.2.0 and up if the API being instrumented subclassed `Grape::API::Instance`
485
+ rather than `Grape::API`. A warning would also print to the newrelic_agent log:
486
+ ```
487
+ WARN : Error in Grape instrumentation
488
+ WARN : NoMethodError: undefined method `name' for nil:NilClass
489
+ ```
490
+
491
+ This version of the agent successfully installs instrumentation for subclasses
492
+ of `Grape::API::Instance`, and these log messages should no longer appear.
493
+
494
+ * **Bugfix for streaming responses**
495
+
496
+ Previous versions of the agent would attempt to insert JavaScript instrumentation into
497
+ any streaming response that did not make use of `ActionController::Live`. This resulted
498
+ in an empty, non-streamed response being sent to the client.
499
+
500
+ This version of the agent will not attempt to insert JavaScript instrumentation into
501
+ a response which includes the header `Transfer-Encoding=chunked`, which indicates a
502
+ streaming response.
503
+
504
+ This should exclude JavaScript instrumentation for all streamed responses. To include
505
+ this instrumentation manually, see
506
+ [Manually instrument via agent API](https://docs.newrelic.com/docs/agents/ruby-agent/features/new-relic-browser-ruby-agent#manual_instrumentation)
507
+ in our documentation.
508
+
509
+ ## v6.3.0
510
+
511
+ * **Official Rails 6.0 support**
512
+
513
+ This version of the agent has been verified against the Rails 6.0.0 release.
514
+
515
+ As ActiveRecord 4, 5, and 6 use the same New Relic instrumentation, the
516
+ `disable_active_record_4` and `disable_active_record_5` settings in NewRelic.yml are being
517
+ deprecated in favor of the new `disable_active_record_notifications`. This new
518
+ setting will affect the instrumentation of ActiveRecord 4, 5, and 6. The deprecated settings
519
+ will be removed in a future release.
520
+
521
+ * **Bugfix for `newrelic deployments` script**
522
+
523
+ For applications housed in the EU, the `newrelic deployments` script included with previous
524
+ versions of the agent would fail with the following message: `Deployment not recorded:
525
+ Application does not exist.` This is because the script would attempt to send the deployment
526
+ notification to the US region. The deployment script now sends deployments to the correct region.
527
+
528
+ * **Faster ActiveRecord connection resolution**
529
+
530
+ This version of the agent uses the faster ActiveRecord connection resolution that Rails 6.0 uses, even on previous versions of Rails.
531
+ Thanks to Callum Jones for the contribution!
532
+
533
+ * **Support non-ascii characters in hostnames**
534
+
535
+ Previous versions of the agent would frequently log warnings like: `log writing failed. "\xE2" from ASCII-8BIT to UTF-8` if the hostname contained a non-ascii character. This version of the agent will no longer log these warnings.
536
+ Thanks to Rafael Petry for the contribution!
537
+
538
+ ## v6.2.0
539
+
540
+ * Bugfix for superfluous `Empty JSON response` error messages
541
+
542
+ Version 6.1.0 of the agent frequently logged error messages about an empty
543
+ JSON response, when no error had occurred. These logs no longer appear.
544
+
545
+ * Bugfix for `Unable to calculate elapsed transaction time` warning messages
546
+
547
+ Ruby Agent versions 5.4 through 6.1, when running in jruby without
548
+ ObjectSpace enabled, would occasionally log a warning indicating that the
549
+ agent was unable to calculate the elapsed transaction time. When this log
550
+ statement appeared, the affected transactions would not be included in the
551
+ data displayed on the capacity analysis page. These transactions are now
552
+ correctly recorded.
553
+
554
+ ## v6.1.0
555
+
556
+ * Performance monitoring on Kubernetes
557
+
558
+ This release adds Transaction event attributes that provide
559
+ context between your Kubernetes cluster and services. For details
560
+ on the benefits, see this [blog
561
+ post](https://blog.newrelic.com/engineering/monitoring-application-performance-in-kubernetes/).
562
+
563
+ * Bugfix for Bunny instrumentation when popping empty queues
564
+
565
+ When a customer calls `Bunny::Queue#pop` on an empty queue, Bunny
566
+ returns a `nil` value. Previous Ruby Agent versions raised a
567
+ `NoMethodError` when trying to process this result. Now, the
568
+ agent correctly skips processing for `nil` values. Thanks to
569
+ Matt Campbell for the contribution.
570
+
571
+ ## v6.0.0
572
+
573
+ * Tracer API for flexible custom instrumentation
574
+
575
+ With agent version 6.0, we are introducing the `Tracer` class, an
576
+ officially supported public API for more flexible custom
577
+ instrumentation. By calling its `in_transaction` method, you can
578
+ instrument an arbitrary section of Ruby code without needing to
579
+ juggle any explicit state. Behind the scenes, the agent will
580
+ make sure that the measured code results in an APM segment inside
581
+ a transaction.
582
+
583
+ The same API contains additional methods for creating
584
+ transactions and segments, and for interacting with the current
585
+ transaction. For more details, see the [custom instrumentation
586
+ documentation](https://docs.newrelic.com/docs/agents/ruby-agent/api-guides/ruby-custom-instrumentation).
587
+
588
+ If you were previously using any of the agent's private,
589
+ undocumented APIs, such as `Transaction.wrap` or
590
+ `Transaction.start/stop`, you will need to update your code to
591
+ use the Tracer API.
592
+
593
+ The full list of APIs that were removed or deprecated are:
594
+ * `External.start_segment`
595
+ * `Transaction.create_segment`
596
+ * `Transaction.start`
597
+ * `Transaction.stop`
598
+ * `Transaction.start_datastore_segment`
599
+ * `Transaction.start_segment`
600
+ * `Transaction.wrap`
601
+ * `TransactionState.current_transaction`
602
+
603
+ If are you using any of these APIs, please see the [upgrade guide](https://docs.newrelic.com/docs/agents/ruby-agent/troubleshooting/update-private-api-calls-public-tracer-api) for a list of replacements.
604
+
605
+ * Agent detects Rails 6.0
606
+
607
+ The agent properly detects Rails 6.0 and no longer logs an error when
608
+ started in a Rails 6.0 environment. This does not include full Rails 6.0
609
+ support, which will be coming in a future release. Thanks to Jacob Bednarz
610
+ for the contribution.
611
+
612
+ ## v5.7.0
613
+
614
+ * Ruby 2.6 support
615
+
616
+ We have tested the agent with the official release of Ruby 2.6.0
617
+ made on December 25, 2018, and it looks great! Feel free to use
618
+ agent v5.7 to measure the performance of your Ruby 2.6
619
+ applications.
620
+
621
+ * Support for loading Sequel core standalone
622
+
623
+ Earlier versions of the agent required users of the Sequel data
624
+ mapping library to load the _entire_ library. The agent will now
625
+ enable Sequel instrumentation when an application loads Sequel's
626
+ core standalone; i.e., without the `Sequel::Model` class. Thanks
627
+ to Vasily Kolesnikov for the contribution!
628
+
629
+ * Grape 1.2 support
630
+
631
+ With agent versions 5.6 and earlier, Grape 1.2 apps reported
632
+ their transactions under the name `Proc#call` instead of the name
633
+ of the API endpoint. Starting with agent version 5.7, all
634
+ existing versions of Grape will report the correct transaction
635
+ name. Thanks to Masato Ohba for the contribution!
636
+
637
+ ## v5.6.0
638
+
639
+ * Bugfix for transactions with `ActionController::Live`
640
+
641
+ Previously, transactions containing `ActionController::Live` resulted in
642
+ incorrect calculations of capacity analysis as well as error backtraces
643
+ appearing in agent logs in agent versions 5.4 and later. The agent now
644
+ correctly calculates capacity for transactions with `ActionController::Live`.
645
+
646
+ * Add ability to exclude attributes from span events and transaction
647
+ segments
648
+
649
+ Agent versions 5.5 and lower could selectively exclude attributes
650
+ from page views, error traces, transaction traces, and
651
+ transaction events. With agent version 5.6 and higher, you can
652
+ also exclude attributes from span events (via the
653
+ `span_events.include/exclude` options) and from transaction
654
+ segments (via the `transaction_segments.include/exclude` options).
655
+
656
+ As with other attribute destinations, these new options will
657
+ inherit values from the top-level `attributes.include/exclude`
658
+ settings. See the
659
+ [documentation](https://docs.newrelic.com/docs/agents/ruby-agent/attributes/enabling-disabling-attributes-ruby)
660
+ for more information.
661
+
662
+ * Increasing backoff sequence on failing to connect to New Relic
663
+
664
+ If the agent cannot reach New Relic, it will now wait for an
665
+ increasing amount of time after each failed attempt. We are also
666
+ starting with a shorter delay initially, which will help customer
667
+ apps bounce back more quickly from transient network errors.
668
+
669
+ * Truncation of long stack traces
670
+
671
+ Previous versions of the agent would truncate long stack traces to
672
+ 50 frames. To give customers more flexibility, we have added the
673
+ `error_collector.max_backtrace_frames` configuration option.
674
+ Thanks to Patrick Tulskie for the contribution!
675
+
676
+ * Update link in documentation
677
+
678
+ The community forum link in `README.md` now goes to the updated
679
+ location. Thanks to Sam Killgallon for the contribution!
680
+
681
+ * Active Storage instrumentation
682
+
683
+ The agent now provides instrumentation for Active Storage, introduced in
684
+ Rails 5.2. Customers will see Active Storage operations represented as
685
+ segments within transaction traces.
686
+
687
+ ## v5.5.0
688
+
689
+ * Bugfix for `perform` instrumentation with curb gem
690
+
691
+ Use of curb's `perform` method now no longer results in nil headers
692
+ getting returned.
693
+
694
+ * Bugfix for parsing Docker container IDs
695
+
696
+ The agent now parses Docker container IDs correctly regardless of the
697
+ cgroup parent.
698
+
699
+ * Use lazy load hooks for ActiveJob instrumentation
700
+
701
+ In some instances the ActiveJob instrumentation could trigger ActiveJob
702
+ to load before it was initialized by Rails. This could result in
703
+ configuration changes not being properly applied. The agent now uses lazy
704
+ load hooks which fixes this issue.
705
+
706
+ * Documentation improvement
707
+
708
+ The `config.dot` diagram of the agent's configuration settings no
709
+ longer includes the deleted `developer_mode` option. Thanks to
710
+ Yuichiro Kaneko for the contribution!
711
+
712
+ ## v5.4.0
713
+
714
+ * Capacity analysis for multi-threaded dispatchers
715
+
716
+ Metrics around capacity analysis did not previously account for multi-threaded
717
+ dispatchers, and consequently could result in capacities of over 100% being
718
+ recorded. This version now properly accounts for multi-threaded dispatchers.
719
+
720
+ * `NewRelic::Agent.disable_transaction_tracing` deprecated
721
+
722
+ `NewRelic::Agent.disable_transaction_tracing` has been deprecated. Users
723
+ are encouraged to use `NewRelic::Agent.disable_all_tracing` or
724
+ `NewRelic::Agent.ignore_transaction` instead.
725
+
726
+ * Bugfix for SQL over-obfuscation
727
+
728
+ A bug, introduced in v5.3.0, where SQL could be over-obfuscated for some
729
+ database adapters has been fixed.
730
+
731
+ * Bugfix for span event data in Resque processes
732
+
733
+ A bug where span events would not be sent from Resque processes due to a
734
+ missing endpoint has been fixed.
735
+
736
+ ## v5.3.0 ##
737
+
738
+ * Distributed Tracing
739
+
740
+ Distributed tracing lets you see the path that a request takes as
741
+ it travels through your distributed system. By showing the
742
+ distributed activity through a unified view, you can troubleshoot
743
+ and understand a complex system better than ever before.
744
+
745
+ Distributed tracing is available with an APM Pro or equivalent
746
+ subscription. To see a complete distributed trace, you need to
747
+ enable the feature on a set of neighboring services. Enabling
748
+ distributed tracing changes the behavior of some New Relic
749
+ features, so carefully consult the
750
+ [transition guide](https://docs.newrelic.com/docs/transition-guide-distributed-tracing)
751
+ before you enable this feature.
752
+
753
+ To enable distributed tracing, set the
754
+ `distributed_tracing.enabled` configuration option to `true`.
755
+
756
+ ## v5.2.0 ##
757
+
758
+ * Use priority sampling for errors and custom events
759
+
760
+ Priority sampling replaces the older reservoir event sampling method.
761
+ With this change, the agent will maintain randomness across a given
762
+ time period while improving coordination among transactions, errors,
763
+ and custom events.
764
+
765
+ * Bugfix for wrapping datastore operations
766
+
767
+ The agent will now complete the process of wrapping datastore
768
+ operations even if an error occurs during execution of a callback.
769
+
770
+ * Span Events
771
+
772
+ Finished segments whose `sampled` property is `true` will now post
773
+ Span events to Insights.
774
+
775
+ ## v5.1.0 ##
776
+
777
+ * Rails 5.2 support
778
+
779
+ The Ruby agent has been validated against the latest release of
780
+ Ruby on Rails!
781
+
782
+ * Support for newer libraries and frameworks
783
+
784
+ We have updated the multiverse suite to test the agent against
785
+ current versions of several frameworks.
786
+
787
+ * Add `custom_attributes.enabled` configuration option
788
+
789
+ This option is enabled by default. When it's disabled, custom
790
+ attributes will not be transmitted on transaction events or error
791
+ events.
792
+
793
+ * Fix Grape load order dependency
794
+
795
+ The agent will now choose the correct name for Grape transactions
796
+ even if the customer's app loads the agent before Grape. Thanks
797
+ to Daniel Doubrovkine for the contribution!
798
+
799
+ * Add `webpacker:compile` to blacklisted tasks
800
+
801
+ `webpacker:compile` is commonly used for compiling assets. It has
802
+ been added to `AUTOSTART_BLACKLISTED_RAKE_TASKS` in the default
803
+ configuration. Thanks to Claudio B. for the contribution!
804
+
805
+ * Make browser instrumentation W3C-compliant
806
+
807
+ `type="text/javascript"` is optional for the `<script>` tag under
808
+ W3C. The `type` attribute has now been removed from browser
809
+ instrumentation. Thanks to Spharian for the contribution!
810
+
811
+ * Deferred `add_method_tracer` calls
812
+
813
+ If a third-party library calls `add_method_tracer` before the
814
+ agent has finished starting, we now queue these calls and run them
815
+ when it's safe to do so (rather than skipping them and logging a
816
+ warning).
817
+
818
+ * Bugfix for Resque `around` / `before` hooks
819
+
820
+ In rare cases, the agent was not instrumenting Resque `around` and
821
+ `before` hooks. This version fixes the error.
822
+
823
+ * Truncation of long stack traces
824
+
825
+ Occasionally, long stack traces would cause complications sending
826
+ data to New Relic. This version truncates long traces to 50 frames
827
+ (split evenly between the top and bottom of the trace).
828
+
829
+ ## v5.0.0 ##
830
+
831
+ * SSL connections to New Relic are now mandatory
832
+
833
+ Prior to this version, using an SSL connection to New Relic was
834
+ the default behavior, but could be overridden. SSL connections are
835
+ now enforced (not overrideable).
836
+
837
+ * Additional security checking before trying to explain
838
+ multi-statement SQL queries
839
+
840
+ Customer applications might submit SQL queries containing multiple
841
+ statements (e.g., SELECT * FROM table; SELECT * FROM table). For
842
+ security reasons, we should not generate explain plans in this
843
+ situation.
844
+
845
+ Although the agent correctly skipped explain plans for these
846
+ queries during testing, we have added extra checks for this
847
+ scenario.
848
+
849
+ * Bugfix for RabbitMQ exchange names that are symbols
850
+
851
+ The agent no longer raises a TypeError when a RabbitMQ exchange
852
+ name is a Ruby symbol instead of a string.
853
+
854
+ * Bugfix for audit logging to stdout
855
+
856
+ Previous agents configured to log to stdout would correctly send
857
+ regular agent logs to stdout, but would incorrectly send audit
858
+ logs to a text file named "stdout". This release corrects the
859
+ error.
860
+
861
+ * Bugfix for Capistrano deployment notifications on v3.7 and beyond
862
+
863
+ Starting with version 3.7, Capistrano uses a different technique
864
+ to determine a project's version control system. The agent now
865
+ works correctly with this new behavior. Thanks to Jimmy Zhang for
866
+ the contribution.
867
+
868
+ ## v4.8.0 ##
869
+
870
+ * Initialize New Relic Agent before config initializers
871
+
872
+ When running in a Rails environment, the agent registers an initializer that
873
+ starts the agent. This initializer is now defined to run before config/initializers.
874
+ Previously, the ordering was not specified for the initializer. This change
875
+ guarantees the agent will started by the time your initializers run, so you can
876
+ safely reference the Agent in your custom initializers. Thanks to Tony Ta for
877
+ the contribution.
878
+
879
+ * Ruby 2.5 Support
880
+
881
+ The Ruby Agent has been verified to run under Ruby 2.5.
882
+
883
+ * `request.uri` Collected as an Agent Attribute
884
+
885
+ Users can now control the collection of `request.uri` on errors and transaction
886
+ traces. Previously it was always collected without the ability to turn it off.
887
+ It is now an agent attribute that can be controlled via the attributes config.
888
+ For more information on agent attributes [see here](https://docs.newrelic.com/docs/agents/manage-apm-agents/agent-data/agent-attributes).
889
+
890
+ ## 4.7.1 ##
891
+
892
+ * Bugfix for Manual Browser Instrumentation
893
+
894
+ There was a previous bug that required setting both `rum.enabled: false` and
895
+ `browser.auto_instrument: false` to completely disable browser monitoring. An
896
+ attempt to fix this in 4.7.0 resulted in breaking manual browser
897
+ instrumentation. Those changes have been reverted. We will revisit this issue
898
+ in an upcoming release.
899
+
900
+ ## v4.7.0 ##
901
+
902
+ * Expected Error API
903
+
904
+ The agent now sends up `error.expected` as an intrinsic attribute on error
905
+ events and error traces. When you pass `expected: true` to the `notice_error`
906
+ method, both Insights and APM will indicate that the error is expected.
907
+
908
+ * Typhoeus Hydra Instrumentation
909
+
910
+ The agent now has request level visibility for HTTP requests made using
911
+ Typhoeus Hydra.
912
+
913
+ * Total Time Metrics are Recorded
914
+
915
+ The agent now records Total Time metrics. In an application where segments
916
+ execute concurrently, the total time can exceed the wall-clock time for a
917
+ transaction. Users of the new Typhoeus Hydra instrumentation will notice
918
+ this as changes on the overview page. Immediately after upgrading there
919
+ will be an alert in the APM dashboard that states: "There are both old and
920
+ new time metrics for this time window". This indicates that during that time
921
+ window, some transactions report the total time metrics, while others do not.
922
+ The message will go away after waiting for enough time to elapse and / or
923
+ updating the time window.
924
+
925
+ * Add `:message` category to `set_transaction_name` public API method
926
+
927
+ The agent now permits the `:message` category to be passed into the public
928
+ API method `set_transaction_name`, which will enable the transaction to be
929
+ displayed as a messaging transaction.
930
+
931
+ * Create `prepend_active_record_instrumentation` config option
932
+
933
+ Users may now set the `prepend_active_record_instrumentation` option in
934
+ their agent config to install Active Record 3 or 4 instrumentation using
935
+ `Module.prepend` rather than `alias_method`.
936
+
937
+ * Use Lazy load hooks for `ActionController::Base` and `ActionController::API`
938
+
939
+ The agent now uses lazy load hooks to hook on `ActionController::Base` and
940
+ `ActionController::API`. Thanks Edouard Chin for the contribution!
941
+
942
+ * Use Lazy load hooks for `ActiveRecord::Base` and `ActiveRecord::Relation`
943
+
944
+ The agent uses lazy load hooks when recording supportability metrics
945
+ for `ActiveRecord::Base` and `ActiveRecord::Relation`. Thanks Joseph Haig
946
+ for the contribution!
947
+
948
+ * Check that `Rails::VERSION` is defined instead of just `Rails`
949
+
950
+ The agent now checks that `Rails::VERSION` is defined since there are cases
951
+ where `Rails` is defined but `Rails::VERSION` is not. Thanks to Alex Riedler
952
+ and nilsding for the contribution!
953
+
954
+ * Support fast RPC/direct reply-to in RabbitMQ
955
+
956
+ The agent can now handle the pseudo-queue 'amq.rabbitmq.reply-to' in its
957
+ Bunny instrumentation. Previously, using fast RPC led to a `NoMethodError`
958
+ because the reply-to queue was expected to be a `Queue` object instead of
959
+ a string.
960
+
961
+ ## v4.6.0 ##
962
+
963
+ * Public API for External Requests
964
+
965
+ The agent now has public API for instrumenting external requests and linking
966
+ up transactions via cross application tracing. See the [API Guide](https://docs.newrelic.com/docs/agents/ruby-agent/customization/ruby-agent-api-guide#externals)
967
+ for more details this new functionality.
968
+
969
+ ## v4.5.0 ##
970
+
971
+ * Send synthetics headers even when CAT disabled
972
+
973
+ The agent now sends synthetics headers whenever they are received from an
974
+ external request, even if cross-application tracing is disabled.
975
+
976
+ * Bugfix for DelayedJob Daemonization
977
+
978
+ Customers using the delayed_job script that ships with the gem may encounter
979
+ an IOError with a message indicating the stream was closed. This was due to
980
+ the agent attempting to write a byte into a Pipe that was closed during the
981
+ deamonization of the delayed_job script. This issue has been fixed.
982
+
983
+ * Collect supportability metrics for public API
984
+
985
+ The agent now collects Supportability/API/{method} metrics to track usage of
986
+ all methods in the agent's public API.
987
+
988
+ * Collect supportability metrics on `Module#prepend`
989
+
990
+ The agent now collects Supportability/PrependedModules/{Module} metrics
991
+ for ActiveRecord 4 and 5, ActionController 4 and 5, ActionView 4 and 5,
992
+ ActiveJob 5, and ActionCable 5. These help track the adoption of the
993
+ `Module#prepend` method so we can maintain compatibility with newer versions
994
+ of Ruby and Rails.
995
+
996
+ * Collect explain plans when using PostGIS ActiveRecord adapter
997
+
998
+ The agent will now collect slow SQL explain plans, if configured to, on
999
+ connections using the PostGIS adapter. Thanks Ari Pollak for the contribution!
1000
+
1001
+ * Lazily intialize New Relic Config
1002
+
1003
+ The agent will lazily initialize the New Relic config. This allows the agent
1004
+ to pickup configuration from environment variables set by dotenv and similar
1005
+ tools.
1006
+
1007
+ ## v4.4.0 ##
1008
+
1009
+ * Include test helper for 3rd party use
1010
+
1011
+ In 4.2.0, all test files were excluded from being packaged in the gem. An
1012
+ agent class method `NewRelic::Agent.require_test_helper` was used by 3rd
1013
+ party gem authors to test extensions to the agent. The required file is now
1014
+ included in the gem.
1015
+
1016
+ * Collect cloud metadata from Azure, GCP, PCF, and AWS cloud platform
1017
+
1018
+ The agent now collects additional metadata when running in AWS, GCP, Azure, and
1019
+ PCF. This information is used to provide an enhanced experience when the agent
1020
+ is deployed on those platforms.
1021
+
1022
+ * Install `at_exit` hook when running JRuby
1023
+
1024
+ The agent now installs an `at_exit` hook when running JRuby, which wasn't
1025
+ done before because of constraints related to older JRuby versions that
1026
+ are no longer supported.
1027
+
1028
+ * User/Utilization and System/Utilization metrics not recorded after Resque forks
1029
+
1030
+ The agent no longer records invalid User/Utilization and System/Utilization
1031
+ metrics, which can lead to negative values, in forks of Resque processes.
1032
+
1033
+ * Add `identifier` field to agent connect settings
1034
+
1035
+ The agent now includes a unique identifier in its connect settings, ensuring
1036
+ that when multiple agents connect to multiple different apps, data are reported
1037
+ for each of the apps.
1038
+
1039
+ * Clear transaction state after forking now opt-in
1040
+
1041
+ The agent waits to connect until the first web request when it detects it's
1042
+ running in a forking dispatcher. When clearing the transaction state in this
1043
+ situation we lose the first frame of the transaction and the subsequent
1044
+ trace becomes corrupted. We've made this feature opt-in and is turned off by
1045
+ default. This behavior only affects the first transaction after a dispatcher
1046
+ forks.
1047
+
1048
+ ## v4.3.0 ##
1049
+
1050
+ * Instrumentation for the Bunny AMQP Client
1051
+
1052
+ The Bunny AMQP Client is now automatically instrumented. The agent will
1053
+ report data for messages sent and received by an application. Data on messages
1054
+ is available in both APM and Insights. Applications connected through a
1055
+ RabbitMQ exchange will now also be visible on Service Maps as part of Cross
1056
+ Application Tracing. See the [message queues documentation page](https://docs.newrelic.com/docs/agents/ruby-agent/features/message-queues)
1057
+ for more details.
1058
+
1059
+ * Safely normalize external hostnames
1060
+
1061
+ The agent has been updated to check for nil host values before downcasing the
1062
+ hostname. Thanks Rafael Valério for the contribution!
1063
+
1064
+ * PageView events will not be generated for ignored transactions
1065
+
1066
+ The agent now checks if transaction is ignored before injecting the New Relic
1067
+ Browser Agent. This will prevent PageView events from being generated for
1068
+ ignored transactions.
1069
+
1070
+ * Datastores required explicitly in agent
1071
+
1072
+ The agent has been modified to explicity `require` the Datastores module
1073
+ whereas previously there were situations where the module could be
1074
+ implicitly defined. Thanks Kevin Griffin for the contribution!
1075
+
1076
+ * Clear transaction state after forking
1077
+
1078
+ Previously, if a transaction was started and the process forks, the transaction
1079
+ state survived the fork and `#after_fork` call in thread local storage. Now,
1080
+ this state is cleared by `#after_fork`.
1081
+
1082
+ * Postgis adapter reports as Postgres for datastores
1083
+
1084
+ The agent now maps the Postgis adapter to Postgres for datastore metrics.
1085
+ Thanks Vojtěch Vondra for the contribution!
1086
+
1087
+ * Deprecate `:trace_only` option
1088
+
1089
+ The `NewRelic::Agent.notice_error` API has been updated to deprecate the
1090
+ `:trace_only` option in favor of `:expected`.
1091
+
1092
+ ## v4.2.0 ##
1093
+
1094
+ * Sinatra 2.0 and Padrino 0.14.x Support
1095
+
1096
+ The agent has been verified against the latest versions of Sinatra and Padrino.
1097
+
1098
+ * Rails 5.1 Support
1099
+
1100
+ The Ruby agent has been validated against the latest release of Ruby on Rails!
1101
+
1102
+ * APP_ENV considered when determining environment
1103
+
1104
+ The agent will now consider the APP_ENV environment when starting up.
1105
+
1106
+ * Test files excluded from gem
1107
+
1108
+ The gemspec has been updated to exclude test files from being packaged into the
1109
+ gem. Thanks dimko for the contribution!
1110
+
1111
+ ## v4.1.0 ##
1112
+
1113
+ * Developer Mode removed
1114
+
1115
+ The Ruby Agent's Developer Mode, which provided a very limited view of your
1116
+ application performance data, has been removed. For more information, check
1117
+ out our [community forum](https://discuss.newrelic.com/t/feedback-on-the-ruby-agent-s-developer-mode/46957).
1118
+
1119
+ * Support NEW_RELIC_ENV for Rails apps
1120
+
1121
+ Previously, users could set the agent environment with NEW_RELIC_ENV only
1122
+ for non-Rails apps. For Rails app, the agent environment would use whatever
1123
+ the Rails environment was set to. Now, NEW_RELIC_ENV can also be used for
1124
+ Rails apps, so that it is possible to have an agent environment that is
1125
+ different from the Rails environment. Thanks Andrea Campolonghi for the
1126
+ contribution, as well as Steve Schwartz for also looking into this issue!
1127
+
1128
+ * Normalization of external hostnames
1129
+
1130
+ Hostnames from URIs used in external HTTP requests are now always downcased
1131
+ to prevent duplicate metrics when only case is different.
1132
+
3
1133
  ## v4.0.0 ##
4
1134
 
5
1135
  * Require Ruby 2.0.0+