newrelic_rpm 7.2.0 → 8.3.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (288) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +2 -0
  3. data/.rubocop.yml +1936 -0
  4. data/CHANGELOG.md +182 -9
  5. data/CONTRIBUTING.md +14 -2
  6. data/Guardfile +8 -8
  7. data/README.md +5 -1
  8. data/Rakefile +5 -7
  9. data/bin/mongrel_rpm +8 -9
  10. data/bin/newrelic +1 -1
  11. data/bin/nrdebug +14 -14
  12. data/init.rb +0 -2
  13. data/lefthook.yml +9 -0
  14. data/lib/new_relic/agent/adaptive_sampler.rb +9 -5
  15. data/lib/new_relic/agent/agent.rb +44 -46
  16. data/lib/new_relic/agent/agent_logger.rb +8 -9
  17. data/lib/new_relic/agent/attribute_filter.rb +31 -31
  18. data/lib/new_relic/agent/attributes.rb +2 -2
  19. data/lib/new_relic/agent/autostart.rb +6 -7
  20. data/lib/new_relic/agent/commands/agent_command.rb +2 -2
  21. data/lib/new_relic/agent/commands/agent_command_router.rb +6 -5
  22. data/lib/new_relic/agent/commands/thread_profiler_session.rb +7 -6
  23. data/lib/new_relic/agent/configuration/default_source.rb +352 -336
  24. data/lib/new_relic/agent/configuration/dotted_hash.rb +3 -3
  25. data/lib/new_relic/agent/configuration/environment_source.rb +3 -4
  26. data/lib/new_relic/agent/configuration/event_harvest_config.rb +30 -16
  27. data/lib/new_relic/agent/configuration/high_security_source.rb +7 -7
  28. data/lib/new_relic/agent/configuration/manager.rb +57 -58
  29. data/lib/new_relic/agent/configuration/mask_defaults.rb +1 -1
  30. data/lib/new_relic/agent/configuration/security_policy_source.rb +73 -73
  31. data/lib/new_relic/agent/configuration/server_source.rb +12 -11
  32. data/lib/new_relic/agent/configuration/yaml_source.rb +26 -5
  33. data/lib/new_relic/agent/connect/request_builder.rb +13 -16
  34. data/lib/new_relic/agent/connect/response_handler.rb +0 -3
  35. data/lib/new_relic/agent/custom_event_aggregator.rb +9 -9
  36. data/lib/new_relic/agent/database/explain_plan_helpers.rb +3 -4
  37. data/lib/new_relic/agent/database/obfuscation_helpers.rb +12 -12
  38. data/lib/new_relic/agent/database/postgres_explain_obfuscator.rb +2 -2
  39. data/lib/new_relic/agent/database.rb +25 -26
  40. data/lib/new_relic/agent/datastores/metric_helper.rb +10 -10
  41. data/lib/new_relic/agent/datastores/mongo/event_formatter.rb +2 -3
  42. data/lib/new_relic/agent/datastores/mongo/metric_translator.rb +3 -5
  43. data/lib/new_relic/agent/datastores/mongo/obfuscator.rb +1 -2
  44. data/lib/new_relic/agent/datastores/mongo.rb +5 -10
  45. data/lib/new_relic/agent/datastores/redis.rb +2 -4
  46. data/lib/new_relic/agent/datastores.rb +7 -9
  47. data/lib/new_relic/agent/distributed_tracing/cross_app_payload.rb +9 -9
  48. data/lib/new_relic/agent/distributed_tracing/cross_app_tracing.rb +21 -16
  49. data/lib/new_relic/agent/distributed_tracing/distributed_trace_attributes.rb +10 -12
  50. data/lib/new_relic/agent/distributed_tracing/distributed_trace_payload.rb +42 -43
  51. data/lib/new_relic/agent/distributed_tracing/distributed_trace_transport_type.rb +3 -3
  52. data/lib/new_relic/agent/distributed_tracing/trace_context.rb +41 -43
  53. data/lib/new_relic/agent/distributed_tracing/trace_context_payload.rb +25 -25
  54. data/lib/new_relic/agent/distributed_tracing.rb +17 -18
  55. data/lib/new_relic/agent/encoding_normalizer.rb +1 -1
  56. data/lib/new_relic/agent/error_collector.rb +17 -17
  57. data/lib/new_relic/agent/error_event_aggregator.rb +1 -1
  58. data/lib/new_relic/agent/error_filter.rb +16 -10
  59. data/lib/new_relic/agent/error_trace_aggregator.rb +1 -1
  60. data/lib/new_relic/agent/event_aggregator.rb +1 -1
  61. data/lib/new_relic/agent/event_buffer.rb +6 -7
  62. data/lib/new_relic/agent/event_listener.rb +0 -1
  63. data/lib/new_relic/agent/event_loop.rb +14 -14
  64. data/lib/new_relic/agent/external.rb +1 -34
  65. data/lib/new_relic/agent/guid_generator.rb +1 -3
  66. data/lib/new_relic/agent/harvester.rb +3 -4
  67. data/lib/new_relic/agent/heap.rb +1 -3
  68. data/lib/new_relic/agent/hostname.rb +3 -3
  69. data/lib/new_relic/agent/http_clients/abstract.rb +7 -9
  70. data/lib/new_relic/agent/http_clients/curb_wrappers.rb +1 -5
  71. data/lib/new_relic/agent/http_clients/excon_wrappers.rb +4 -4
  72. data/lib/new_relic/agent/http_clients/http_rb_wrappers.rb +3 -3
  73. data/lib/new_relic/agent/http_clients/httpclient_wrappers.rb +1 -2
  74. data/lib/new_relic/agent/http_clients/net_http_wrappers.rb +8 -3
  75. data/lib/new_relic/agent/http_clients/typhoeus_wrappers.rb +2 -3
  76. data/lib/new_relic/agent/http_clients/uri_util.rb +0 -1
  77. data/lib/new_relic/agent/instrumentation/action_cable_subscriber.rb +2 -3
  78. data/lib/new_relic/agent/instrumentation/action_controller_subscriber.rb +10 -11
  79. data/lib/new_relic/agent/instrumentation/action_view_subscriber.rb +5 -7
  80. data/lib/new_relic/agent/instrumentation/active_job.rb +4 -3
  81. data/lib/new_relic/agent/instrumentation/active_merchant.rb +3 -3
  82. data/lib/new_relic/agent/instrumentation/active_record.rb +20 -18
  83. data/lib/new_relic/agent/instrumentation/active_record_helper.rb +36 -42
  84. data/lib/new_relic/agent/instrumentation/active_record_notifications.rb +28 -25
  85. data/lib/new_relic/agent/instrumentation/active_record_prepend.rb +3 -3
  86. data/lib/new_relic/agent/instrumentation/active_record_subscriber.rb +5 -6
  87. data/lib/new_relic/agent/instrumentation/acts_as_solr.rb +8 -9
  88. data/lib/new_relic/agent/instrumentation/bunny/chain.rb +1 -1
  89. data/lib/new_relic/agent/instrumentation/bunny/instrumentation.rb +8 -9
  90. data/lib/new_relic/agent/instrumentation/controller_instrumentation.rb +42 -42
  91. data/lib/new_relic/agent/instrumentation/curb/chain.rb +19 -20
  92. data/lib/new_relic/agent/instrumentation/curb/instrumentation.rb +34 -38
  93. data/lib/new_relic/agent/instrumentation/curb/prepend.rb +9 -10
  94. data/lib/new_relic/agent/instrumentation/data_mapper.rb +10 -10
  95. data/lib/new_relic/agent/instrumentation/delayed_job/chain.rb +5 -7
  96. data/lib/new_relic/agent/instrumentation/delayed_job/instrumentation.rb +5 -9
  97. data/lib/new_relic/agent/instrumentation/delayed_job_instrumentation.rb +4 -4
  98. data/lib/new_relic/agent/instrumentation/excon/middleware.rb +2 -2
  99. data/lib/new_relic/agent/instrumentation/excon.rb +3 -23
  100. data/lib/new_relic/agent/instrumentation/grape/chain.rb +1 -2
  101. data/lib/new_relic/agent/instrumentation/grape/instrumentation.rb +6 -7
  102. data/lib/new_relic/agent/instrumentation/grape.rb +2 -3
  103. data/lib/new_relic/agent/instrumentation/httpclient/chain.rb +2 -3
  104. data/lib/new_relic/agent/instrumentation/httpclient/instrumentation.rb +0 -1
  105. data/lib/new_relic/agent/instrumentation/httpclient/prepend.rb +0 -2
  106. data/lib/new_relic/agent/instrumentation/httprb/chain.rb +2 -2
  107. data/lib/new_relic/agent/instrumentation/httprb/instrumentation.rb +6 -6
  108. data/lib/new_relic/agent/instrumentation/httprb/prepend.rb +1 -1
  109. data/lib/new_relic/agent/instrumentation/ignore_actions.rb +2 -3
  110. data/lib/new_relic/agent/instrumentation/logger/chain.rb +21 -0
  111. data/lib/new_relic/agent/instrumentation/logger/instrumentation.rb +58 -0
  112. data/lib/new_relic/agent/instrumentation/logger/prepend.rb +13 -0
  113. data/lib/new_relic/agent/instrumentation/logger.rb +25 -0
  114. data/lib/new_relic/agent/instrumentation/memcache/dalli.rb +7 -2
  115. data/lib/new_relic/agent/instrumentation/memcache/helper.rb +5 -1
  116. data/lib/new_relic/agent/instrumentation/memcache/prepend.rb +9 -2
  117. data/lib/new_relic/agent/instrumentation/middleware_proxy.rb +9 -10
  118. data/lib/new_relic/agent/instrumentation/middleware_tracing.rb +4 -5
  119. data/lib/new_relic/agent/instrumentation/mongo.rb +3 -141
  120. data/lib/new_relic/agent/instrumentation/mongodb_command_subscriber.rb +4 -4
  121. data/lib/new_relic/agent/instrumentation/net_http/chain.rb +3 -4
  122. data/lib/new_relic/agent/instrumentation/net_http/instrumentation.rb +5 -5
  123. data/lib/new_relic/agent/instrumentation/net_http/prepend.rb +4 -4
  124. data/lib/new_relic/agent/instrumentation/net_http.rb +1 -1
  125. data/lib/new_relic/agent/instrumentation/notifications_subscriber.rb +2 -3
  126. data/lib/new_relic/agent/instrumentation/padrino/chain.rb +23 -19
  127. data/lib/new_relic/agent/instrumentation/padrino/instrumentation.rb +3 -2
  128. data/lib/new_relic/agent/instrumentation/padrino/prepend.rb +2 -2
  129. data/lib/new_relic/agent/instrumentation/padrino.rb +2 -5
  130. data/lib/new_relic/agent/instrumentation/queue_time.rb +8 -8
  131. data/lib/new_relic/agent/instrumentation/rack/chain.rb +5 -5
  132. data/lib/new_relic/agent/instrumentation/rack/helpers.rb +0 -1
  133. data/lib/new_relic/agent/instrumentation/rack/instrumentation.rb +4 -5
  134. data/lib/new_relic/agent/instrumentation/rack/prepend.rb +0 -1
  135. data/lib/new_relic/agent/instrumentation/rack.rb +1 -1
  136. data/lib/new_relic/agent/instrumentation/rails3/action_controller.rb +11 -47
  137. data/lib/new_relic/agent/instrumentation/rails_notifications/action_cable.rb +2 -2
  138. data/lib/new_relic/agent/instrumentation/rails_notifications/action_controller.rb +0 -1
  139. data/lib/new_relic/agent/instrumentation/rake/chain.rb +0 -5
  140. data/lib/new_relic/agent/instrumentation/rake/instrumentation.rb +6 -6
  141. data/lib/new_relic/agent/instrumentation/rake.rb +1 -1
  142. data/lib/new_relic/agent/instrumentation/redis/chain.rb +6 -6
  143. data/lib/new_relic/agent/instrumentation/redis/instrumentation.rb +2 -2
  144. data/lib/new_relic/agent/instrumentation/redis/prepend.rb +1 -1
  145. data/lib/new_relic/agent/instrumentation/redis.rb +1 -1
  146. data/lib/new_relic/agent/instrumentation/resque/chain.rb +2 -3
  147. data/lib/new_relic/agent/instrumentation/resque/helper.rb +1 -1
  148. data/lib/new_relic/agent/instrumentation/resque/instrumentation.rb +4 -4
  149. data/lib/new_relic/agent/instrumentation/resque/prepend.rb +1 -2
  150. data/lib/new_relic/agent/instrumentation/resque.rb +7 -7
  151. data/lib/new_relic/agent/instrumentation/sequel.rb +7 -9
  152. data/lib/new_relic/agent/instrumentation/sequel_helper.rb +1 -1
  153. data/lib/new_relic/agent/instrumentation/sidekiq.rb +7 -1
  154. data/lib/new_relic/agent/instrumentation/sinatra/ignorer.rb +0 -1
  155. data/lib/new_relic/agent/instrumentation/sinatra/instrumentation.rb +4 -3
  156. data/lib/new_relic/agent/instrumentation/sunspot.rb +1 -1
  157. data/lib/new_relic/agent/instrumentation/tilt/chain.rb +24 -0
  158. data/lib/new_relic/agent/instrumentation/tilt/instrumentation.rb +40 -0
  159. data/lib/new_relic/agent/instrumentation/tilt/prepend.rb +13 -0
  160. data/lib/new_relic/agent/instrumentation/tilt.rb +25 -0
  161. data/lib/new_relic/agent/instrumentation/typhoeus/chain.rb +4 -4
  162. data/lib/new_relic/agent/instrumentation/typhoeus/instrumentation.rb +3 -5
  163. data/lib/new_relic/agent/instrumentation/typhoeus/prepend.rb +1 -1
  164. data/lib/new_relic/agent/internal_agent_error.rb +1 -1
  165. data/lib/new_relic/agent/javascript_instrumentor.rb +30 -30
  166. data/lib/new_relic/agent/logging.rb +11 -8
  167. data/lib/new_relic/agent/memory_logger.rb +1 -1
  168. data/lib/new_relic/agent/messaging.rb +46 -61
  169. data/lib/new_relic/agent/method_tracer.rb +139 -143
  170. data/lib/new_relic/agent/method_tracer_helpers.rb +2 -2
  171. data/lib/new_relic/agent/monitors/cross_app_monitor.rb +21 -13
  172. data/lib/new_relic/agent/monitors/distributed_tracing_monitor.rb +2 -2
  173. data/lib/new_relic/agent/monitors/inbound_request_monitor.rb +0 -1
  174. data/lib/new_relic/agent/monitors/synthetics_monitor.rb +4 -7
  175. data/lib/new_relic/agent/monitors.rb +1 -2
  176. data/lib/new_relic/agent/new_relic_service/encoders.rb +4 -4
  177. data/lib/new_relic/agent/new_relic_service/json_marshaller.rb +1 -1
  178. data/lib/new_relic/agent/new_relic_service/marshaller.rb +1 -1
  179. data/lib/new_relic/agent/new_relic_service/security_policy_settings.rb +4 -3
  180. data/lib/new_relic/agent/new_relic_service.rb +34 -41
  181. data/lib/new_relic/agent/noticible_error.rb +0 -2
  182. data/lib/new_relic/agent/null_logger.rb +6 -2
  183. data/lib/new_relic/agent/obfuscator.rb +6 -8
  184. data/lib/new_relic/agent/parameter_filtering.rb +3 -5
  185. data/lib/new_relic/agent/payload_metric_mapping.rb +8 -9
  186. data/lib/new_relic/agent/pipe_channel_manager.rb +15 -12
  187. data/lib/new_relic/agent/pipe_service.rb +2 -2
  188. data/lib/new_relic/agent/priority_sampled_buffer.rb +4 -7
  189. data/lib/new_relic/agent/rules_engine/replacement_rule.rb +9 -9
  190. data/lib/new_relic/agent/rules_engine/segment_terms_rule.rb +12 -12
  191. data/lib/new_relic/agent/rules_engine.rb +2 -2
  192. data/lib/new_relic/agent/sampler.rb +2 -3
  193. data/lib/new_relic/agent/sampler_collection.rb +2 -3
  194. data/lib/new_relic/agent/samplers/cpu_sampler.rb +1 -1
  195. data/lib/new_relic/agent/samplers/delayed_job_sampler.rb +10 -7
  196. data/lib/new_relic/agent/samplers/memory_sampler.rb +4 -3
  197. data/lib/new_relic/agent/samplers/vm_sampler.rb +18 -18
  198. data/lib/new_relic/agent/span_event_aggregator.rb +10 -10
  199. data/lib/new_relic/agent/span_event_primitive.rb +39 -39
  200. data/lib/new_relic/agent/sql_sampler.rb +9 -9
  201. data/lib/new_relic/agent/stats.rb +16 -16
  202. data/lib/new_relic/agent/stats_engine/gc_profiler.rb +7 -9
  203. data/lib/new_relic/agent/stats_engine/stats_hash.rb +8 -9
  204. data/lib/new_relic/agent/stats_engine.rb +7 -7
  205. data/lib/new_relic/agent/synthetics_event_aggregator.rb +0 -1
  206. data/lib/new_relic/agent/system_info.rb +22 -20
  207. data/lib/new_relic/agent/threading/agent_thread.rb +4 -5
  208. data/lib/new_relic/agent/threading/backtrace_node.rb +6 -9
  209. data/lib/new_relic/agent/threading/backtrace_service.rb +12 -13
  210. data/lib/new_relic/agent/threading/thread_profile.rb +16 -19
  211. data/lib/new_relic/agent/tracer.rb +43 -71
  212. data/lib/new_relic/agent/transaction/abstract_segment.rb +9 -9
  213. data/lib/new_relic/agent/transaction/datastore_segment.rb +7 -6
  214. data/lib/new_relic/agent/transaction/distributed_tracer.rb +8 -9
  215. data/lib/new_relic/agent/transaction/distributed_tracing.rb +21 -22
  216. data/lib/new_relic/agent/transaction/external_request_segment.rb +6 -5
  217. data/lib/new_relic/agent/transaction/message_broker_segment.rb +24 -30
  218. data/lib/new_relic/agent/transaction/request_attributes.rb +7 -7
  219. data/lib/new_relic/agent/transaction/segment.rb +6 -3
  220. data/lib/new_relic/agent/transaction/slowest_sample_buffer.rb +0 -2
  221. data/lib/new_relic/agent/transaction/trace.rb +8 -8
  222. data/lib/new_relic/agent/transaction/trace_context.rb +13 -15
  223. data/lib/new_relic/agent/transaction/trace_node.rb +16 -16
  224. data/lib/new_relic/agent/transaction/tracing.rb +1 -3
  225. data/lib/new_relic/agent/transaction/transaction_sample_buffer.rb +1 -2
  226. data/lib/new_relic/agent/transaction.rb +85 -108
  227. data/lib/new_relic/agent/transaction_error_primitive.rb +16 -16
  228. data/lib/new_relic/agent/transaction_event_aggregator.rb +5 -6
  229. data/lib/new_relic/agent/transaction_event_primitive.rb +29 -29
  230. data/lib/new_relic/agent/transaction_metrics.rb +3 -3
  231. data/lib/new_relic/agent/transaction_sampler.rb +0 -1
  232. data/lib/new_relic/agent/transaction_time_aggregator.rb +11 -11
  233. data/lib/new_relic/agent/utilization/azure.rb +1 -1
  234. data/lib/new_relic/agent/utilization_data.rb +3 -4
  235. data/lib/new_relic/agent/vm/monotonic_gc_profiler.rb +1 -1
  236. data/lib/new_relic/agent/vm/snapshot.rb +4 -4
  237. data/lib/new_relic/agent/worker_loop.rb +8 -10
  238. data/lib/new_relic/agent.rb +27 -27
  239. data/lib/new_relic/cli/command.rb +15 -17
  240. data/lib/new_relic/cli/commands/deployments.rb +21 -23
  241. data/lib/new_relic/cli/commands/install.rb +6 -10
  242. data/lib/new_relic/coerce.rb +5 -8
  243. data/lib/new_relic/collection_helper.rb +48 -47
  244. data/lib/new_relic/constants.rb +0 -4
  245. data/lib/new_relic/control/class_methods.rb +2 -2
  246. data/lib/new_relic/control/frameworks/external.rb +1 -1
  247. data/lib/new_relic/control/frameworks/rails.rb +5 -6
  248. data/lib/new_relic/control/frameworks/rails3.rb +2 -3
  249. data/lib/new_relic/control/frameworks/ruby.rb +2 -2
  250. data/lib/new_relic/control/instance_methods.rb +4 -5
  251. data/lib/new_relic/control/instrumentation.rb +4 -5
  252. data/lib/new_relic/control/server_methods.rb +2 -3
  253. data/lib/new_relic/control.rb +0 -1
  254. data/lib/new_relic/dependency_detection.rb +6 -8
  255. data/lib/new_relic/environment_report.rb +16 -18
  256. data/lib/new_relic/helper.rb +5 -5
  257. data/lib/new_relic/language_support.rb +1 -1
  258. data/lib/new_relic/latest_changes.rb +2 -2
  259. data/lib/new_relic/local_environment.rb +7 -7
  260. data/lib/new_relic/metric_data.rb +6 -7
  261. data/lib/new_relic/metric_spec.rb +3 -3
  262. data/lib/new_relic/noticed_error.rb +16 -17
  263. data/lib/new_relic/rack/agent_middleware.rb +2 -2
  264. data/lib/new_relic/rack/browser_monitoring.rb +9 -9
  265. data/lib/new_relic/recipes/capistrano3.rb +11 -13
  266. data/lib/new_relic/recipes/capistrano_legacy.rb +11 -14
  267. data/lib/new_relic/supportability_helper.rb +1 -2
  268. data/lib/new_relic/version.rb +4 -5
  269. data/lib/newrelic_rpm.rb +10 -34
  270. data/lib/sequel/extensions/newrelic_instrumentation.rb +4 -7
  271. data/lib/sequel/plugins/newrelic_instrumentation.rb +3 -9
  272. data/lib/tasks/all.rb +2 -2
  273. data/lib/tasks/config.rake +21 -21
  274. data/lib/tasks/multiverse.rb +4 -6
  275. data/lib/tasks/tests.rake +3 -7
  276. data/newrelic.yml +580 -3
  277. data/newrelic_rpm.gemspec +13 -12
  278. data/recipes/newrelic.rb +1 -1
  279. data/test/agent_helper.rb +80 -55
  280. metadata +42 -13
  281. data/lib/new_relic/agent/datastores/mongo/statement_formatter.rb +0 -53
  282. data/lib/new_relic/agent/instrumentation/excon/connection.rb +0 -49
  283. data/lib/new_relic/agent/instrumentation/merb/controller.rb +0 -44
  284. data/lib/new_relic/agent/instrumentation/merb/errors.rb +0 -33
  285. data/lib/new_relic/agent/instrumentation/rails/action_controller.rb +0 -125
  286. data/lib/new_relic/agent/instrumentation/rails/action_web_service.rb +0 -46
  287. data/lib/new_relic/agent/supported_versions.rb +0 -275
  288. data/lib/new_relic/control/frameworks/merb.rb +0 -29
@@ -5,7 +5,6 @@
5
5
  require 'capistrano/framework'
6
6
 
7
7
  namespace :newrelic do
8
-
9
8
  # notifies New Relic of a deployment
10
9
  desc "Record a deployment in New Relic (newrelic.com)"
11
10
  task :notice_deployment do
@@ -23,15 +22,15 @@ namespace :newrelic do
23
22
  def send_deployment_notification_to_newrelic
24
23
  environment = fetch(:newrelic_rails_env, fetch(:rack_env, fetch(:rails_env, fetch(:stage, "production"))))
25
24
 
26
- require 'new_relic/cli/command.rb'
25
+ require 'new_relic/cli/command'
27
26
 
28
27
  begin
29
28
  # allow overrides to be defined for revision, description, changelog, appname, and user
30
- rev = fetch(:newrelic_revision)
29
+ rev = fetch(:newrelic_revision)
31
30
  description = fetch(:newrelic_desc)
32
- changelog = fetch(:newrelic_changelog)
33
- appname = fetch(:newrelic_appname)
34
- user = fetch(:newrelic_user)
31
+ changelog = fetch(:newrelic_changelog)
32
+ appname = fetch(:newrelic_appname)
33
+ user = fetch(:newrelic_user)
35
34
  license_key = fetch(:newrelic_license_key)
36
35
 
37
36
  has_scm_from_plugin = respond_to?(:scm_plugin_installed?) && scm_plugin_installed?
@@ -39,17 +38,17 @@ namespace :newrelic do
39
38
 
40
39
  if has_scm_from_plugin || has_scm_from_config
41
40
  changelog ||= lookup_changelog
42
- rev ||= fetch(:current_revision)
41
+ rev ||= fetch(:current_revision)
43
42
  end
44
43
 
45
44
  new_revision = rev
46
45
  deploy_options = {
47
46
  :environment => environment,
48
- :revision => new_revision,
49
- :changelog => changelog,
47
+ :revision => new_revision,
48
+ :changelog => changelog,
50
49
  :description => description,
51
- :appname => appname,
52
- :user => user,
50
+ :appname => appname,
51
+ :user => user,
53
52
  :license_key => license_key
54
53
  }
55
54
 
@@ -57,7 +56,6 @@ namespace :newrelic do
57
56
  deployment = NewRelic::Cli::Deployments.new deploy_options
58
57
  deployment.run
59
58
  info "Uploaded deployment information to New Relic"
60
-
61
59
  rescue NewRelic::Cli::Command::CommandFailure => e
62
60
  info e.message
63
61
  rescue => e
@@ -74,7 +72,7 @@ namespace :newrelic do
74
72
 
75
73
  if Rake::Task.task_defined?("git:check")
76
74
  log_command = "git --no-pager log --no-color --pretty=format:' * %an: %s' " +
77
- "--abbrev-commit --no-merges #{previous_revision}..#{current_revision}"
75
+ "--abbrev-commit --no-merges #{previous_revision}..#{current_revision}"
78
76
  `#{log_command}`
79
77
  end
80
78
  end
@@ -3,38 +3,36 @@
3
3
  # See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
4
4
 
5
5
  make_notify_task = Proc.new do
6
-
7
6
  namespace :newrelic do
8
-
9
7
  # on all deployments, notify New Relic
10
8
  desc "Record a deployment in New Relic (newrelic.com)"
11
- task :notice_deployment, :roles => :app, :except => {:no_release => true } do
9
+ task :notice_deployment, :roles => :app, :except => {:no_release => true} do
12
10
  rails_env = fetch(:newrelic_rails_env, fetch(:rails_env, "production"))
13
11
 
14
12
  require 'new_relic/cli/command'
15
13
 
16
14
  begin
17
15
  # allow overrides to be defined for revision, description, changelog, appname, and user
18
- rev = fetch(:newrelic_revision) if exists?(:newrelic_revision)
19
- description = fetch(:newrelic_desc) if exists?(:newrelic_desc)
20
- changelog = fetch(:newrelic_changelog) if exists?(:newrelic_changelog)
21
- appname = fetch(:newrelic_appname) if exists?(:newrelic_appname)
22
- user = fetch(:newrelic_user) if exists?(:newrelic_user)
16
+ rev = fetch(:newrelic_revision) if exists?(:newrelic_revision)
17
+ description = fetch(:newrelic_desc) if exists?(:newrelic_desc)
18
+ changelog = fetch(:newrelic_changelog) if exists?(:newrelic_changelog)
19
+ appname = fetch(:newrelic_appname) if exists?(:newrelic_appname)
20
+ user = fetch(:newrelic_user) if exists?(:newrelic_user)
23
21
  license_key = fetch(:newrelic_license_key) if exists?(:newrelic_license_key)
24
22
 
25
23
  unless scm == :none
26
24
  changelog = lookup_changelog(changelog)
27
- rev = lookup_rev(rev)
25
+ rev = lookup_rev(rev)
28
26
  end
29
27
 
30
28
  new_revision = rev
31
29
  deploy_options = {
32
30
  :environment => rails_env,
33
- :revision => new_revision,
34
- :changelog => changelog,
31
+ :revision => new_revision,
32
+ :changelog => changelog,
35
33
  :description => description,
36
- :appname => appname,
37
- :user => user,
34
+ :appname => appname,
35
+ :user => user,
38
36
  :license_key => license_key
39
37
  }
40
38
 
@@ -42,7 +40,6 @@ make_notify_task = Proc.new do
42
40
  deployment = NewRelic::Cli::Deployments.new deploy_options
43
41
  deployment.run
44
42
  logger.info "Uploaded deployment information to New Relic"
45
-
46
43
  rescue NewRelic::Cli::Command::CommandFailure => e
47
44
  logger.info e.message
48
45
  rescue Capistrano::CommandError
@@ -4,7 +4,6 @@
4
4
 
5
5
  module NewRelic
6
6
  module SupportabilityHelper
7
-
8
7
  API_SUPPORTABILITY_PREFIX = 'Supportability/API/'.freeze
9
8
 
10
9
  # pre-instantiate these strings as they may be used multiple times per
@@ -54,7 +53,7 @@ module NewRelic
54
53
  :trace_execution_scoped,
55
54
  :trace_execution_unscoped,
56
55
  :wrap
57
- ].reduce({}) do |h,o|
56
+ ].reduce({}) do |h, o|
58
57
  h[o] = API_SUPPORTABILITY_PREFIX + o.to_s
59
58
  h
60
59
  end
@@ -3,16 +3,15 @@
3
3
  # This file is distributed under New Relic's license terms.
4
4
  # See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
5
5
 
6
-
7
6
  module NewRelic
8
- module VERSION #:nodoc:
7
+ module VERSION # :nodoc:
9
8
  def self.build_version_string(*parts)
10
9
  parts.compact.join('.')
11
10
  end
12
11
 
13
- MAJOR = 7
14
- MINOR = 2
15
- TINY = 0
12
+ MAJOR = 8
13
+ MINOR = 3
14
+ TINY = 0
16
15
 
17
16
  begin
18
17
  require File.join(File.dirname(__FILE__), 'build')
data/lib/newrelic_rpm.rb CHANGED
@@ -6,48 +6,24 @@
6
6
  #
7
7
  # When installed as a gem, you can activate the New Relic agent one of the following ways:
8
8
  #
9
- # For Rails, add:
10
- # config.gem 'newrelic_rpm'
11
- # to your initialization sequence.
9
+ # For applications using Bundler, add this to the Gemfile:
10
+ # gem 'newrelic_rpm'
12
11
  #
13
- # For merb, do
14
- # dependency 'newrelic_rpm'
15
- # in the Merb config/init.rb
12
+ # You will also need to install the newrelic.yml configuration file
16
13
  #
17
- # For Sinatra, do
18
- # require 'newrelic_rpm'
19
- # after requiring 'sinatra'.
20
- #
21
- # For other frameworks, or to manage the agent manually, invoke NewRelic::Agent#manual_start
22
- # directly.
14
+ # For applications not using Bundler, and for other installation information, visit:
15
+ # https://docs.newrelic.com/docs/agents/ruby-agent/installation/install-new-relic-ruby-agent/
23
16
  #
24
17
 
25
18
  require 'new_relic/control'
26
- if defined?(Merb) && defined?(Merb::BootLoader)
27
- module NewRelic
28
- class MerbBootLoader < Merb::BootLoader
29
- after Merb::BootLoader::ChooseAdapter
30
- def self.run
31
- NewRelic::Control.instance.init_plugin
32
- end
33
- end
34
- end
35
- elsif defined?(Rails::VERSION)
36
- if Rails::VERSION::MAJOR.to_i >= 3
37
- module NewRelic
38
- class Railtie < Rails::Railtie
39
19
 
40
- initializer "newrelic_rpm.start_plugin", before: :load_config_initializers do |app|
41
- NewRelic::Control.instance.init_plugin(:config => app.config)
42
- end
20
+ if defined?(Rails::VERSION)
21
+ module NewRelic
22
+ class Railtie < Rails::Railtie
23
+ initializer "newrelic_rpm.start_plugin", before: :load_config_initializers do |app|
24
+ NewRelic::Control.instance.init_plugin(config: app.config)
43
25
  end
44
26
  end
45
- else
46
- # After version 2.0 of Rails we can access the configuration directly.
47
- # We need it to add dev mode routes after initialization finished.
48
- config = nil
49
- config = Rails.configuration if Rails.respond_to?(:configuration)
50
- NewRelic::Control.instance.init_plugin :config => config
51
27
  end
52
28
  else
53
29
  NewRelic::Control.instance.init_plugin
@@ -3,13 +3,12 @@
3
3
  # This file is distributed under New Relic's license terms.
4
4
  # See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
5
5
 
6
- require 'sequel' unless defined?( Sequel )
7
- require 'newrelic_rpm' unless defined?( NewRelic )
6
+ require 'sequel' unless defined?(Sequel)
7
+ require 'newrelic_rpm' unless defined?(NewRelic)
8
8
  require 'new_relic/agent/instrumentation/sequel_helper'
9
9
  require 'new_relic/agent/datastores/metric_helper'
10
10
 
11
11
  module Sequel
12
-
13
12
  # New Relic's Sequel instrumentation is implemented via a plugin for
14
13
  # Sequel::Models, and an extension for Sequel::Databases. Every database
15
14
  # handle that Sequel knows about when New Relic is loaded will automatically
@@ -31,7 +30,6 @@ module Sequel
31
30
  # `disable_activerecord_instrumentation` setting.
32
31
  #
33
32
  module NewRelicInstrumentation
34
-
35
33
  module Naming
36
34
  def self.query_method_name
37
35
  if Sequel::VERSION >= "4.35.0"
@@ -42,7 +40,7 @@ module Sequel
42
40
  end
43
41
  end
44
42
 
45
- define_method Naming.query_method_name do |*args, &blk| #THREAD_LOCAL_ACCESS
43
+ define_method Naming.query_method_name do |*args, &blk| # THREAD_LOCAL_ACCESS
46
44
  sql = args.first
47
45
 
48
46
  product = NewRelic::Agent::Instrumentation::SequelHelper.product_name_from_adapter(self.class.adapter_scheme)
@@ -86,7 +84,7 @@ module Sequel
86
84
  def explainer_for sql
87
85
  Proc.new do |*|
88
86
  if THREAD_SAFE_CONNECTION_POOL_CLASSES.include?(self.pool.class)
89
- self[ sql ].explain
87
+ self[sql].explain
90
88
  else
91
89
  NewRelic::Agent.logger.log_once(:info, :sequel_explain_skipped, "Not running SQL explains because Sequel is not in recognized multi-threaded mode")
92
90
  nil
@@ -97,5 +95,4 @@ module Sequel
97
95
 
98
96
  NewRelic::Agent.logger.debug "Registering the :newrelic_instrumentation extension."
99
97
  Database.register_extension(:newrelic_instrumentation, NewRelicInstrumentation)
100
-
101
98
  end # module Sequel
@@ -3,23 +3,21 @@
3
3
  # This file is distributed under New Relic's license terms.
4
4
  # See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
5
5
 
6
- require 'sequel' unless defined?( Sequel )
7
- require 'newrelic_rpm' unless defined?( NewRelic )
6
+ require 'sequel' unless defined?(Sequel)
7
+ require 'newrelic_rpm' unless defined?(NewRelic)
8
8
  require 'new_relic/agent/instrumentation/sequel_helper'
9
9
  require 'new_relic/agent/datastores/metric_helper'
10
10
 
11
11
  module Sequel
12
12
  module Plugins
13
-
14
13
  # Sequel::Model instrumentation for the New Relic agent.
15
14
  module NewrelicInstrumentation
16
-
17
15
  # Meta-programming for creating method tracers for the Sequel::Model plugin.
18
16
  module MethodWrapping
19
17
  # Install a method named +method_name+ that will trace execution
20
18
  # with a metric name derived from +operation_name+ (or +method_name+ if +operation_name+
21
19
  # isn't specified).
22
- def wrap_sequel_method(method_name, operation_name=method_name)
20
+ def wrap_sequel_method(method_name, operation_name = method_name)
23
21
  define_method(method_name) do |*args, &block|
24
22
  klass = self.is_a?(Class) ? self : self.class
25
23
  product = NewRelic::Agent::Instrumentation::SequelHelper.product_name_from_adapter(db.adapter_scheme)
@@ -36,7 +34,6 @@ module Sequel
36
34
  end
37
35
  end
38
36
  end
39
-
40
37
  end # module MethodTracer
41
38
 
42
39
  # Methods to be added to Sequel::Model instances.
@@ -51,10 +48,8 @@ module Sequel
51
48
  wrap_sequel_method :update_fields
52
49
  wrap_sequel_method :update_only
53
50
  wrap_sequel_method :save
54
-
55
51
  end # module InstanceMethods
56
52
 
57
-
58
53
  # Methods to be added to Sequel::Model classes.
59
54
  module ClassMethods
60
55
  extend Sequel::Plugins::NewrelicInstrumentation::MethodWrapping
@@ -64,7 +59,6 @@ module Sequel
64
59
  wrap_sequel_method :first
65
60
  wrap_sequel_method :create
66
61
  end # module ClassMethods
67
-
68
62
  end # module NewRelicInstrumentation
69
63
  end # module Plugins
70
64
  end # module Sequel
data/lib/tasks/all.rb CHANGED
@@ -2,7 +2,7 @@
2
2
  # This file is distributed under New Relic's license terms.
3
3
  # See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
4
4
 
5
- # This is required to load in task definitions from merb
6
- Dir.glob(File.join(File.dirname(__FILE__),'*.rake')) do |file|
5
+ # This is required to load in task definitions
6
+ Dir.glob(File.join(File.dirname(__FILE__), '*.rake')) do |file|
7
7
  load file
8
8
  end
@@ -2,22 +2,22 @@ namespace :newrelic do
2
2
  namespace :config do
3
3
  desc "Describe available New Relic configuration settings."
4
4
 
5
- GENERAL = "general"
6
- DISABLING = "disabling"
5
+ GENERAL = "general"
6
+ DISABLING = "disabling"
7
7
  ATTRIBUTES = "attributes"
8
8
 
9
9
  SECTION_DESCRIPTIONS = {
10
- GENERAL => 'These settings are available for agent configuration. Some settings depend on your New Relic subscription level.',
11
- DISABLING => 'Use these settings to toggle instrumentation types during agent startup.',
12
- ATTRIBUTES => '[Attributes](/docs/features/agent-attributes) are key-value pairs containing information that determines the properties of an event or transaction. These key-value pairs can be viewed within transaction traces in APM, traced errors in APM, transaction events in dashboards, and page views in dashboards. You can customize exactly which attributes will be sent to each of these destinations',
10
+ GENERAL => 'These settings are available for agent configuration. Some settings depend on your New Relic subscription level.',
11
+ DISABLING => 'Use these settings to toggle instrumentation types during agent startup.',
12
+ ATTRIBUTES => '[Attributes](/docs/features/agent-attributes) are key-value pairs containing information that determines the properties of an event or transaction. These key-value pairs can be viewed within transaction traces in APM, traced errors in APM, transaction events in dashboards, and page views in dashboards. You can customize exactly which attributes will be sent to each of these destinations',
13
13
  "transaction_tracer" => 'The [transaction traces](/docs/apm/traces/transaction-traces/transaction-traces) feature collects detailed information from a selection of transactions, including a summary of the calling sequence, a breakdown of time spent, and a list of SQL queries and their query plans (on mysql and postgresql). Available features depend on your New Relic subscription level.',
14
- "error_collector" => 'The agent collects and reports all uncaught exceptions by default. These configuration options allow you to customize the error collection.',
14
+ "error_collector" => 'The agent collects and reports all uncaught exceptions by default. These configuration options allow you to customize the error collection.',
15
15
  "browser_monitoring" => 'The Browser monitoring [page load timing](/docs/browser/new-relic-browser/page-load-timing/page-load-timing-process) feature (sometimes referred to as real user monitoring or RUM) gives you insight into the performance real users are experiencing with your website. This is accomplished by measuring the time it takes for your users\' browsers to download and render your web pages by injecting a small amount of JavaScript code into the header and footer of each page.',
16
- "analytics_events" => '[New Relic dashboards](/docs/query-your-data/explore-query-data/dashboards/introduction-new-relic-one-dashboards) is a resource to gather and visualize data about your software and what it says about your business. With it you can quickly and easily create real-time dashboards to get immediate answers about end-user experiences, clickstreams, mobile activities, and server transactions.'
16
+ "analytics_events" => '[New Relic dashboards](/docs/query-your-data/explore-query-data/dashboards/introduction-new-relic-one-dashboards) is a resource to gather and visualize data about your software and what it says about your business. With it you can quickly and easily create real-time dashboards to get immediate answers about end-user experiences, clickstreams, mobile activities, and server transactions.'
17
17
  }
18
18
 
19
19
  NAME_OVERRIDES = {
20
- "slow_sql" => "Slow SQL"
20
+ "slow_sql" => "Slow SQL"
21
21
  }
22
22
 
23
23
  def output(format)
@@ -29,7 +29,7 @@ namespace :newrelic do
29
29
  end
30
30
 
31
31
  def build_config_hash
32
- sections = Hash.new {|hash, key| hash[key] = []}
32
+ sections = Hash.new { |hash, key| hash[key] = [] }
33
33
  NewRelic::Agent::Configuration::DEFAULTS.each do |key, value|
34
34
  next unless value[:public]
35
35
 
@@ -37,20 +37,20 @@ namespace :newrelic do
37
37
  key = key.to_s
38
38
  components = key.split(".")
39
39
 
40
- if key.match(/^disable_/) # "disable_httpclient"
40
+ if key.match(/^disable_/) # "disable_httpclient"
41
41
  section_key = DISABLING
42
- elsif components.length == 2 # "analytics_events.enabled"
42
+ elsif components.length == 2 # "analytics_events.enabled"
43
43
  section_key = components.first
44
44
  elsif components[1] == "attributes" # "transaction_tracer.attributes.enabled"
45
45
  section_key = ATTRIBUTES
46
46
  end
47
47
 
48
48
  sections[section_key] << {
49
- :key => key,
50
- :type => format_type(value[:type]),
49
+ :key => key,
50
+ :type => format_type(value[:type]),
51
51
  :description => format_description(value),
52
- :default => format_default_value(value),
53
- :env_var => format_env_var(key)
52
+ :default => format_default_value(value),
53
+ :env_var => format_env_var(key)
54
54
  }
55
55
  end
56
56
  sections
@@ -60,10 +60,10 @@ namespace :newrelic do
60
60
  sections = []
61
61
  sections << pluck(GENERAL, config_hash)
62
62
  sections << pluck("transaction_tracer", config_hash)
63
- sections << pluck("error_collector", config_hash)
63
+ sections << pluck("error_collector", config_hash)
64
64
  sections << pluck("browser_monitoring", config_hash)
65
- sections << pluck("analytics_events", config_hash)
66
- sections.concat(config_hash.to_a.sort_by { |a| a.first})
65
+ sections << pluck("analytics_events", config_hash)
66
+ sections.concat(config_hash.to_a.sort_by { |a| a.first })
67
67
 
68
68
  add_data_to_sections(sections)
69
69
 
@@ -82,9 +82,9 @@ namespace :newrelic do
82
82
  name = NAME_OVERRIDES[key]
83
83
  return name if name
84
84
 
85
- key.split("_").
86
- each { |fragment| fragment[0] = fragment[0].upcase }.
87
- join(" ")
85
+ key.split("_")
86
+ .each { |fragment| fragment[0] = fragment[0].upcase }
87
+ .join(" ")
88
88
  end
89
89
 
90
90
  def format_type(type)
@@ -42,10 +42,9 @@ namespace :test do
42
42
  end
43
43
 
44
44
  namespace :multiverse do
45
-
46
45
  def remove_local_multiverse_databases
47
- list_databases_command = %{echo "show databases" | mysql -u root}
48
- databases = `#{list_databases_command}`.chomp!.split("\n").select{|s| s =~ /multiverse/}
46
+ list_databases_command = %(echo "show databases" | mysql -u root)
47
+ databases = `#{list_databases_command}`.chomp!.split("\n").select { |s| s =~ /multiverse/ }
49
48
  databases.each do |database|
50
49
  puts "Dropping #{database}"
51
50
  `echo "drop database #{database}" | mysql -u root`
@@ -58,7 +57,7 @@ namespace :test do
58
57
  def remove_generated_gemfiles
59
58
  file_path = File.expand_path "test/multiverse/suites"
60
59
  Dir.glob(File.join file_path, "**", "Gemfile*").each do |fn|
61
- puts "Removing #{fn.gsub(file_path,'.../suites')}"
60
+ puts "Removing #{fn.gsub(file_path, '.../suites')}"
62
61
  FileUtils.rm fn
63
62
  end
64
63
  end
@@ -66,7 +65,7 @@ namespace :test do
66
65
  def remove_generated_gemfile_lockfiles
67
66
  file_path = File.expand_path "test/environments"
68
67
  Dir.glob(File.join file_path, "**", "Gemfile.lock").each do |fn|
69
- puts "Removing #{fn.gsub(file_path,'.../environments')}"
68
+ puts "Removing #{fn.gsub(file_path, '.../environments')}"
70
69
  FileUtils.rm fn
71
70
  end
72
71
  end
@@ -99,6 +98,5 @@ namespace :test do
99
98
  task :prime, [:suite] => [:env] do |_, args|
100
99
  Multiverse::Runner.prime(args.suite, Multiverse::Runner.parse_args(args))
101
100
  end
102
-
103
101
  end
104
102
  end
data/lib/tasks/tests.rake CHANGED
@@ -9,26 +9,23 @@ if defined? Rake::TestTask
9
9
  matches = tasks.map { |t| /(seed=.*?)[,\]]/.match(t) }.compact
10
10
  if matches.any?
11
11
  matches.first[1]
12
- else
13
- nil
14
12
  end
15
13
  end
16
14
 
17
15
  tasks = Rake.application.top_level_tasks
18
16
  ENV["TESTOPTS"] ||= ""
19
- if tasks.any? { |t| t.include?("verbose")}
17
+ if tasks.any? { |t| t.include?("verbose") }
20
18
  ENV["TESTOPTS"] += " -v"
21
19
  end
22
20
  if seed = look_for_seed(tasks)
23
21
  ENV["TESTOPTS"] += " --" + seed
24
22
  end
25
23
 
26
- agent_home = File.expand_path(File.join(File.dirname(__FILE__),'..','..'))
24
+ agent_home = File.expand_path(File.join(File.dirname(__FILE__), '..', '..'))
27
25
 
28
26
  Rake::TestTask.new(:newrelic) do |t|
29
-
30
27
  file_pattern = ENV["file"]
31
- file_pattern = file_pattern.split(",").map{|f| "#{agent_home}/#{f}".gsub("//", "/")} if file_pattern
28
+ file_pattern = file_pattern.split(",").map { |f| "#{agent_home}/#{f}".gsub("//", "/") } if file_pattern
32
29
  file_pattern ||= "#{agent_home}/test/new_relic/**/*_test.rb"
33
30
 
34
31
  t.libs << "#{agent_home}/test"
@@ -36,6 +33,5 @@ if defined? Rake::TestTask
36
33
  t.pattern = Array(file_pattern)
37
34
  t.verbose = true
38
35
  end
39
-
40
36
  end
41
37
  end