ddtrace 0.50.0 → 0.53.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1107) hide show
  1. checksums.yaml +4 -4
  2. data/.editorconfig +22 -0
  3. data/.gitignore +7 -0
  4. data/CHANGELOG.md +196 -1
  5. data/CONTRIBUTING.md +1 -5
  6. data/ddtrace.gemspec +10 -1
  7. data/docs/DevelopmentGuide.md +16 -6
  8. data/docs/GettingStarted.md +108 -20
  9. data/docs/ProfilingDevelopment.md +33 -14
  10. data/ext/ddtrace_profiling_native_extension/extconf.rb +28 -0
  11. data/ext/ddtrace_profiling_native_extension/profiling.c +17 -0
  12. data/lib/datadog/ci/configuration/components.rb +1 -0
  13. data/lib/datadog/ci/configuration/settings.rb +1 -0
  14. data/lib/datadog/ci/context_flush.rb +1 -0
  15. data/lib/datadog/ci/contrib/cucumber/configuration/settings.rb +2 -1
  16. data/lib/datadog/ci/contrib/cucumber/ext.rb +1 -0
  17. data/lib/datadog/ci/contrib/cucumber/formatter.rb +1 -0
  18. data/lib/datadog/ci/contrib/cucumber/instrumentation.rb +1 -0
  19. data/lib/datadog/ci/contrib/cucumber/integration.rb +1 -0
  20. data/lib/datadog/ci/contrib/cucumber/patcher.rb +1 -0
  21. data/lib/datadog/ci/contrib/rspec/configuration/settings.rb +2 -1
  22. data/lib/datadog/ci/contrib/rspec/example.rb +1 -0
  23. data/lib/datadog/ci/contrib/rspec/ext.rb +1 -0
  24. data/lib/datadog/ci/contrib/rspec/integration.rb +3 -2
  25. data/lib/datadog/ci/contrib/rspec/patcher.rb +1 -0
  26. data/lib/datadog/ci/ext/app_types.rb +1 -0
  27. data/lib/datadog/ci/ext/environment.rb +269 -92
  28. data/lib/datadog/ci/ext/settings.rb +1 -0
  29. data/lib/datadog/ci/ext/test.rb +8 -1
  30. data/lib/datadog/ci/extensions.rb +1 -0
  31. data/lib/datadog/ci/test.rb +14 -0
  32. data/lib/datadog/ci.rb +1 -0
  33. data/lib/datadog/contrib.rb +71 -0
  34. data/lib/datadog/core/environment/cgroup.rb +52 -0
  35. data/lib/datadog/core/environment/class_count.rb +20 -0
  36. data/lib/datadog/core/environment/container.rb +91 -0
  37. data/lib/datadog/core/environment/ext.rb +27 -0
  38. data/lib/datadog/core/environment/gc.rb +19 -0
  39. data/lib/datadog/core/environment/identity.rb +51 -0
  40. data/lib/datadog/core/environment/socket.rb +17 -0
  41. data/lib/datadog/core/environment/thread_count.rb +19 -0
  42. data/lib/datadog/core/environment/variable_helpers.rb +42 -0
  43. data/lib/datadog/core/environment/vm_cache.rb +46 -0
  44. data/lib/ddtrace/analytics.rb +1 -0
  45. data/lib/ddtrace/auto_instrument.rb +2 -0
  46. data/lib/ddtrace/auto_instrument_base.rb +1 -0
  47. data/lib/ddtrace/buffer.rb +7 -5
  48. data/lib/ddtrace/chunker.rb +1 -0
  49. data/lib/ddtrace/configuration/agent_settings_resolver.rb +108 -40
  50. data/lib/ddtrace/configuration/base.rb +4 -3
  51. data/lib/ddtrace/configuration/components.rb +54 -11
  52. data/lib/ddtrace/configuration/dependency_resolver.rb +1 -0
  53. data/lib/ddtrace/configuration/option.rb +1 -0
  54. data/lib/ddtrace/configuration/option_definition.rb +1 -0
  55. data/lib/ddtrace/configuration/option_definition_set.rb +1 -0
  56. data/lib/ddtrace/configuration/option_set.rb +1 -0
  57. data/lib/ddtrace/configuration/options.rb +1 -0
  58. data/lib/ddtrace/configuration/pin_setup.rb +1 -0
  59. data/lib/ddtrace/configuration/settings.rb +34 -9
  60. data/lib/ddtrace/configuration.rb +21 -2
  61. data/lib/ddtrace/context.rb +1 -0
  62. data/lib/ddtrace/context_flush.rb +1 -0
  63. data/lib/ddtrace/context_provider.rb +1 -0
  64. data/lib/ddtrace/contrib/action_cable/configuration/settings.rb +1 -0
  65. data/lib/ddtrace/contrib/action_cable/event.rb +1 -0
  66. data/lib/ddtrace/contrib/action_cable/events/broadcast.rb +1 -0
  67. data/lib/ddtrace/contrib/action_cable/events/perform_action.rb +1 -0
  68. data/lib/ddtrace/contrib/action_cable/events/transmit.rb +1 -0
  69. data/lib/ddtrace/contrib/action_cable/events.rb +1 -0
  70. data/lib/ddtrace/contrib/action_cable/ext.rb +1 -0
  71. data/lib/ddtrace/contrib/action_cable/instrumentation.rb +47 -0
  72. data/lib/ddtrace/contrib/action_cable/integration.rb +1 -0
  73. data/lib/ddtrace/contrib/action_cable/patcher.rb +2 -0
  74. data/lib/ddtrace/contrib/action_mailer/configuration/settings.rb +32 -0
  75. data/lib/ddtrace/contrib/action_mailer/event.rb +50 -0
  76. data/lib/ddtrace/contrib/action_mailer/events/deliver.rb +54 -0
  77. data/lib/ddtrace/contrib/action_mailer/events/process.rb +41 -0
  78. data/lib/ddtrace/contrib/action_mailer/events.rb +31 -0
  79. data/lib/ddtrace/contrib/action_mailer/ext.rb +32 -0
  80. data/lib/ddtrace/contrib/action_mailer/integration.rb +45 -0
  81. data/lib/ddtrace/contrib/action_mailer/patcher.rb +27 -0
  82. data/lib/ddtrace/contrib/action_pack/action_controller/instrumentation.rb +21 -10
  83. data/lib/ddtrace/contrib/action_pack/action_controller/patcher.rb +1 -0
  84. data/lib/ddtrace/contrib/action_pack/configuration/settings.rb +1 -0
  85. data/lib/ddtrace/contrib/action_pack/ext.rb +1 -0
  86. data/lib/ddtrace/contrib/action_pack/integration.rb +1 -0
  87. data/lib/ddtrace/contrib/action_pack/patcher.rb +1 -0
  88. data/lib/ddtrace/contrib/action_pack/utils.rb +1 -0
  89. data/lib/ddtrace/contrib/action_view/configuration/settings.rb +1 -0
  90. data/lib/ddtrace/contrib/action_view/event.rb +1 -0
  91. data/lib/ddtrace/contrib/action_view/events/render_partial.rb +1 -0
  92. data/lib/ddtrace/contrib/action_view/events/render_template.rb +1 -0
  93. data/lib/ddtrace/contrib/action_view/events.rb +1 -0
  94. data/lib/ddtrace/contrib/action_view/ext.rb +1 -0
  95. data/lib/ddtrace/contrib/action_view/instrumentation/partial_renderer.rb +1 -0
  96. data/lib/ddtrace/contrib/action_view/instrumentation/template_renderer.rb +1 -0
  97. data/lib/ddtrace/contrib/action_view/integration.rb +1 -0
  98. data/lib/ddtrace/contrib/action_view/patcher.rb +1 -0
  99. data/lib/ddtrace/contrib/action_view/utils.rb +1 -0
  100. data/lib/ddtrace/contrib/active_job/configuration/settings.rb +33 -0
  101. data/lib/ddtrace/contrib/active_job/event.rb +54 -0
  102. data/lib/ddtrace/contrib/active_job/events/discard.rb +46 -0
  103. data/lib/ddtrace/contrib/active_job/events/enqueue.rb +45 -0
  104. data/lib/ddtrace/contrib/active_job/events/enqueue_at.rb +45 -0
  105. data/lib/ddtrace/contrib/active_job/events/enqueue_retry.rb +47 -0
  106. data/lib/ddtrace/contrib/active_job/events/perform.rb +45 -0
  107. data/lib/ddtrace/contrib/active_job/events/retry_stopped.rb +46 -0
  108. data/lib/ddtrace/contrib/active_job/events.rb +39 -0
  109. data/lib/ddtrace/contrib/active_job/ext.rb +32 -0
  110. data/lib/ddtrace/contrib/active_job/integration.rb +46 -0
  111. data/lib/ddtrace/contrib/active_job/log_injection.rb +21 -0
  112. data/lib/ddtrace/contrib/active_job/patcher.rb +33 -0
  113. data/lib/ddtrace/contrib/active_model_serializers/configuration/settings.rb +1 -0
  114. data/lib/ddtrace/contrib/active_model_serializers/event.rb +1 -0
  115. data/lib/ddtrace/contrib/active_model_serializers/events/render.rb +1 -0
  116. data/lib/ddtrace/contrib/active_model_serializers/events/serialize.rb +1 -0
  117. data/lib/ddtrace/contrib/active_model_serializers/events.rb +1 -0
  118. data/lib/ddtrace/contrib/active_model_serializers/ext.rb +1 -0
  119. data/lib/ddtrace/contrib/active_model_serializers/integration.rb +1 -0
  120. data/lib/ddtrace/contrib/active_model_serializers/patcher.rb +1 -0
  121. data/lib/ddtrace/contrib/active_record/configuration/makara_resolver.rb +1 -0
  122. data/lib/ddtrace/contrib/active_record/configuration/resolver.rb +3 -2
  123. data/lib/ddtrace/contrib/active_record/configuration/settings.rb +1 -0
  124. data/lib/ddtrace/contrib/active_record/event.rb +1 -0
  125. data/lib/ddtrace/contrib/active_record/events/instantiation.rb +1 -0
  126. data/lib/ddtrace/contrib/active_record/events/sql.rb +1 -0
  127. data/lib/ddtrace/contrib/active_record/events.rb +1 -0
  128. data/lib/ddtrace/contrib/active_record/ext.rb +1 -0
  129. data/lib/ddtrace/contrib/active_record/integration.rb +1 -0
  130. data/lib/ddtrace/contrib/active_record/patcher.rb +1 -0
  131. data/lib/ddtrace/contrib/active_record/utils.rb +4 -3
  132. data/lib/ddtrace/contrib/active_support/cache/instrumentation.rb +1 -0
  133. data/lib/ddtrace/contrib/active_support/cache/patcher.rb +1 -0
  134. data/lib/ddtrace/contrib/active_support/cache/redis.rb +1 -0
  135. data/lib/ddtrace/contrib/active_support/configuration/settings.rb +1 -0
  136. data/lib/ddtrace/contrib/active_support/ext.rb +1 -0
  137. data/lib/ddtrace/contrib/active_support/integration.rb +1 -0
  138. data/lib/ddtrace/contrib/active_support/notifications/event.rb +1 -0
  139. data/lib/ddtrace/contrib/active_support/notifications/subscriber.rb +1 -0
  140. data/lib/ddtrace/contrib/active_support/notifications/subscription.rb +1 -0
  141. data/lib/ddtrace/contrib/active_support/patcher.rb +1 -0
  142. data/lib/ddtrace/contrib/analytics.rb +1 -0
  143. data/lib/ddtrace/contrib/auto_instrument.rb +2 -2
  144. data/lib/ddtrace/contrib/aws/configuration/settings.rb +1 -0
  145. data/lib/ddtrace/contrib/aws/ext.rb +1 -0
  146. data/lib/ddtrace/contrib/aws/instrumentation.rb +1 -0
  147. data/lib/ddtrace/contrib/aws/integration.rb +1 -0
  148. data/lib/ddtrace/contrib/aws/parsed_context.rb +1 -0
  149. data/lib/ddtrace/contrib/aws/patcher.rb +2 -1
  150. data/lib/ddtrace/contrib/aws/services.rb +1 -0
  151. data/lib/ddtrace/contrib/concurrent_ruby/configuration/settings.rb +1 -0
  152. data/lib/ddtrace/contrib/concurrent_ruby/context_composite_executor_service.rb +1 -0
  153. data/lib/ddtrace/contrib/concurrent_ruby/ext.rb +1 -0
  154. data/lib/ddtrace/contrib/concurrent_ruby/future_patch.rb +1 -0
  155. data/lib/ddtrace/contrib/concurrent_ruby/integration.rb +1 -0
  156. data/lib/ddtrace/contrib/concurrent_ruby/patcher.rb +2 -0
  157. data/lib/ddtrace/contrib/configurable.rb +1 -0
  158. data/lib/ddtrace/contrib/configuration/resolver.rb +1 -0
  159. data/lib/ddtrace/contrib/configuration/resolvers/pattern_resolver.rb +1 -0
  160. data/lib/ddtrace/contrib/configuration/settings.rb +1 -0
  161. data/lib/ddtrace/contrib/dalli/configuration/settings.rb +1 -0
  162. data/lib/ddtrace/contrib/dalli/ext.rb +1 -0
  163. data/lib/ddtrace/contrib/dalli/instrumentation.rb +1 -0
  164. data/lib/ddtrace/contrib/dalli/integration.rb +1 -0
  165. data/lib/ddtrace/contrib/dalli/patcher.rb +1 -0
  166. data/lib/ddtrace/contrib/dalli/quantize.rb +1 -0
  167. data/lib/ddtrace/contrib/delayed_job/configuration/settings.rb +1 -0
  168. data/lib/ddtrace/contrib/delayed_job/ext.rb +1 -0
  169. data/lib/ddtrace/contrib/delayed_job/integration.rb +1 -0
  170. data/lib/ddtrace/contrib/delayed_job/patcher.rb +1 -0
  171. data/lib/ddtrace/contrib/delayed_job/plugin.rb +1 -0
  172. data/lib/ddtrace/contrib/elasticsearch/configuration/settings.rb +1 -0
  173. data/lib/ddtrace/contrib/elasticsearch/ext.rb +1 -0
  174. data/lib/ddtrace/contrib/elasticsearch/integration.rb +1 -0
  175. data/lib/ddtrace/contrib/elasticsearch/patcher.rb +1 -0
  176. data/lib/ddtrace/contrib/elasticsearch/quantize.rb +3 -0
  177. data/lib/ddtrace/contrib/ethon/configuration/settings.rb +1 -0
  178. data/lib/ddtrace/contrib/ethon/easy_patch.rb +1 -0
  179. data/lib/ddtrace/contrib/ethon/ext.rb +1 -0
  180. data/lib/ddtrace/contrib/ethon/integration.rb +1 -0
  181. data/lib/ddtrace/contrib/ethon/multi_patch.rb +1 -0
  182. data/lib/ddtrace/contrib/ethon/patcher.rb +2 -0
  183. data/lib/ddtrace/contrib/excon/configuration/settings.rb +1 -0
  184. data/lib/ddtrace/contrib/excon/ext.rb +1 -0
  185. data/lib/ddtrace/contrib/excon/integration.rb +1 -0
  186. data/lib/ddtrace/contrib/excon/middleware.rb +1 -0
  187. data/lib/ddtrace/contrib/excon/patcher.rb +1 -0
  188. data/lib/ddtrace/contrib/extensions.rb +37 -11
  189. data/lib/ddtrace/contrib/faraday/configuration/settings.rb +1 -0
  190. data/lib/ddtrace/contrib/faraday/connection.rb +1 -0
  191. data/lib/ddtrace/contrib/faraday/ext.rb +1 -0
  192. data/lib/ddtrace/contrib/faraday/integration.rb +1 -0
  193. data/lib/ddtrace/contrib/faraday/middleware.rb +1 -0
  194. data/lib/ddtrace/contrib/faraday/patcher.rb +1 -0
  195. data/lib/ddtrace/contrib/faraday/rack_builder.rb +1 -0
  196. data/lib/ddtrace/contrib/grape/configuration/settings.rb +1 -0
  197. data/lib/ddtrace/contrib/grape/endpoint.rb +26 -16
  198. data/lib/ddtrace/contrib/grape/ext.rb +1 -0
  199. data/lib/ddtrace/contrib/grape/instrumentation.rb +2 -1
  200. data/lib/ddtrace/contrib/grape/integration.rb +1 -0
  201. data/lib/ddtrace/contrib/grape/patcher.rb +1 -0
  202. data/lib/ddtrace/contrib/graphql/configuration/settings.rb +1 -0
  203. data/lib/ddtrace/contrib/graphql/ext.rb +1 -0
  204. data/lib/ddtrace/contrib/graphql/integration.rb +1 -0
  205. data/lib/ddtrace/contrib/graphql/patcher.rb +1 -0
  206. data/lib/ddtrace/contrib/grpc/configuration/settings.rb +2 -0
  207. data/lib/ddtrace/contrib/grpc/datadog_interceptor/client.rb +1 -0
  208. data/lib/ddtrace/contrib/grpc/datadog_interceptor/server.rb +3 -4
  209. data/lib/ddtrace/contrib/grpc/datadog_interceptor.rb +5 -0
  210. data/lib/ddtrace/contrib/grpc/ext.rb +1 -0
  211. data/lib/ddtrace/contrib/grpc/integration.rb +1 -0
  212. data/lib/ddtrace/contrib/grpc/intercept_with_datadog.rb +1 -0
  213. data/lib/ddtrace/contrib/grpc/patcher.rb +2 -0
  214. data/lib/ddtrace/contrib/http/circuit_breaker.rb +1 -0
  215. data/lib/ddtrace/contrib/http/configuration/settings.rb +1 -0
  216. data/lib/ddtrace/contrib/http/ext.rb +1 -0
  217. data/lib/ddtrace/contrib/http/instrumentation.rb +1 -0
  218. data/lib/ddtrace/contrib/http/integration.rb +1 -0
  219. data/lib/ddtrace/contrib/http/patcher.rb +1 -0
  220. data/lib/ddtrace/contrib/http_annotation_helper.rb +1 -0
  221. data/lib/ddtrace/contrib/httpclient/configuration/settings.rb +1 -0
  222. data/lib/ddtrace/contrib/httpclient/ext.rb +1 -0
  223. data/lib/ddtrace/contrib/httpclient/instrumentation.rb +1 -0
  224. data/lib/ddtrace/contrib/httpclient/integration.rb +1 -0
  225. data/lib/ddtrace/contrib/httpclient/patcher.rb +2 -1
  226. data/lib/ddtrace/contrib/httprb/configuration/settings.rb +1 -0
  227. data/lib/ddtrace/contrib/httprb/ext.rb +1 -0
  228. data/lib/ddtrace/contrib/httprb/instrumentation.rb +1 -0
  229. data/lib/ddtrace/contrib/httprb/integration.rb +1 -0
  230. data/lib/ddtrace/contrib/httprb/patcher.rb +2 -1
  231. data/lib/ddtrace/contrib/integration.rb +1 -0
  232. data/lib/ddtrace/contrib/kafka/configuration/settings.rb +1 -0
  233. data/lib/ddtrace/contrib/kafka/consumer_event.rb +1 -0
  234. data/lib/ddtrace/contrib/kafka/consumer_group_event.rb +1 -0
  235. data/lib/ddtrace/contrib/kafka/event.rb +1 -0
  236. data/lib/ddtrace/contrib/kafka/events/connection/request.rb +1 -0
  237. data/lib/ddtrace/contrib/kafka/events/consumer/process_batch.rb +1 -0
  238. data/lib/ddtrace/contrib/kafka/events/consumer/process_message.rb +1 -0
  239. data/lib/ddtrace/contrib/kafka/events/consumer_group/heartbeat.rb +1 -0
  240. data/lib/ddtrace/contrib/kafka/events/consumer_group/join_group.rb +1 -0
  241. data/lib/ddtrace/contrib/kafka/events/consumer_group/leave_group.rb +1 -0
  242. data/lib/ddtrace/contrib/kafka/events/consumer_group/sync_group.rb +1 -0
  243. data/lib/ddtrace/contrib/kafka/events/produce_operation/send_messages.rb +1 -0
  244. data/lib/ddtrace/contrib/kafka/events/producer/deliver_messages.rb +1 -0
  245. data/lib/ddtrace/contrib/kafka/events.rb +1 -0
  246. data/lib/ddtrace/contrib/kafka/ext.rb +1 -0
  247. data/lib/ddtrace/contrib/kafka/integration.rb +1 -0
  248. data/lib/ddtrace/contrib/kafka/patcher.rb +1 -0
  249. data/lib/ddtrace/contrib/lograge/configuration/settings.rb +19 -0
  250. data/lib/ddtrace/contrib/lograge/ext.rb +11 -0
  251. data/lib/ddtrace/contrib/lograge/instrumentation.rb +39 -0
  252. data/lib/ddtrace/contrib/lograge/integration.rb +46 -0
  253. data/lib/ddtrace/contrib/lograge/patcher.rb +26 -0
  254. data/lib/ddtrace/contrib/mongodb/configuration/settings.rb +1 -0
  255. data/lib/ddtrace/contrib/mongodb/ext.rb +1 -0
  256. data/lib/ddtrace/contrib/mongodb/instrumentation.rb +1 -0
  257. data/lib/ddtrace/contrib/mongodb/integration.rb +1 -0
  258. data/lib/ddtrace/contrib/mongodb/parsers.rb +1 -0
  259. data/lib/ddtrace/contrib/mongodb/patcher.rb +1 -0
  260. data/lib/ddtrace/contrib/mongodb/subscribers.rb +1 -0
  261. data/lib/ddtrace/contrib/mysql2/configuration/settings.rb +1 -0
  262. data/lib/ddtrace/contrib/mysql2/ext.rb +1 -0
  263. data/lib/ddtrace/contrib/mysql2/instrumentation.rb +1 -0
  264. data/lib/ddtrace/contrib/mysql2/integration.rb +1 -0
  265. data/lib/ddtrace/contrib/mysql2/patcher.rb +1 -0
  266. data/lib/ddtrace/contrib/patchable.rb +1 -0
  267. data/lib/ddtrace/contrib/patcher.rb +2 -1
  268. data/lib/ddtrace/contrib/presto/configuration/settings.rb +1 -0
  269. data/lib/ddtrace/contrib/presto/ext.rb +1 -0
  270. data/lib/ddtrace/contrib/presto/instrumentation.rb +1 -0
  271. data/lib/ddtrace/contrib/presto/integration.rb +1 -0
  272. data/lib/ddtrace/contrib/presto/patcher.rb +1 -0
  273. data/lib/ddtrace/contrib/qless/configuration/settings.rb +1 -0
  274. data/lib/ddtrace/contrib/qless/ext.rb +1 -0
  275. data/lib/ddtrace/contrib/qless/integration.rb +1 -0
  276. data/lib/ddtrace/contrib/qless/patcher.rb +2 -0
  277. data/lib/ddtrace/contrib/qless/qless_job.rb +1 -0
  278. data/lib/ddtrace/contrib/qless/tracer_cleaner.rb +1 -0
  279. data/lib/ddtrace/contrib/que/configuration/settings.rb +1 -0
  280. data/lib/ddtrace/contrib/que/ext.rb +1 -0
  281. data/lib/ddtrace/contrib/que/integration.rb +1 -0
  282. data/lib/ddtrace/contrib/que/patcher.rb +1 -0
  283. data/lib/ddtrace/contrib/que/tracer.rb +1 -0
  284. data/lib/ddtrace/contrib/racecar/configuration/settings.rb +1 -0
  285. data/lib/ddtrace/contrib/racecar/event.rb +1 -0
  286. data/lib/ddtrace/contrib/racecar/events/batch.rb +1 -0
  287. data/lib/ddtrace/contrib/racecar/events/consume.rb +1 -0
  288. data/lib/ddtrace/contrib/racecar/events/message.rb +1 -0
  289. data/lib/ddtrace/contrib/racecar/events.rb +1 -0
  290. data/lib/ddtrace/contrib/racecar/ext.rb +1 -0
  291. data/lib/ddtrace/contrib/racecar/integration.rb +1 -0
  292. data/lib/ddtrace/contrib/racecar/patcher.rb +1 -0
  293. data/lib/ddtrace/contrib/rack/configuration/settings.rb +1 -0
  294. data/lib/ddtrace/contrib/rack/ext.rb +1 -0
  295. data/lib/ddtrace/contrib/rack/integration.rb +1 -0
  296. data/lib/ddtrace/contrib/rack/middlewares.rb +2 -1
  297. data/lib/ddtrace/contrib/rack/patcher.rb +1 -0
  298. data/lib/ddtrace/contrib/rack/request_queue.rb +1 -0
  299. data/lib/ddtrace/contrib/rails/auto_instrument_railtie.rb +1 -1
  300. data/lib/ddtrace/contrib/rails/configuration/settings.rb +1 -0
  301. data/lib/ddtrace/contrib/rails/ext.rb +1 -0
  302. data/lib/ddtrace/contrib/rails/framework.rb +48 -1
  303. data/lib/ddtrace/contrib/rails/integration.rb +1 -0
  304. data/lib/ddtrace/contrib/rails/log_injection.rb +1 -40
  305. data/lib/ddtrace/contrib/rails/middlewares.rb +1 -0
  306. data/lib/ddtrace/contrib/rails/patcher.rb +30 -18
  307. data/lib/ddtrace/contrib/rails/railtie.rb +1 -0
  308. data/lib/ddtrace/contrib/rails/utils.rb +1 -0
  309. data/lib/ddtrace/contrib/rake/configuration/settings.rb +1 -0
  310. data/lib/ddtrace/contrib/rake/ext.rb +1 -0
  311. data/lib/ddtrace/contrib/rake/instrumentation.rb +1 -0
  312. data/lib/ddtrace/contrib/rake/integration.rb +1 -0
  313. data/lib/ddtrace/contrib/rake/patcher.rb +1 -0
  314. data/lib/ddtrace/contrib/redis/configuration/resolver.rb +1 -0
  315. data/lib/ddtrace/contrib/redis/configuration/settings.rb +1 -0
  316. data/lib/ddtrace/contrib/redis/ext.rb +1 -0
  317. data/lib/ddtrace/contrib/redis/integration.rb +1 -0
  318. data/lib/ddtrace/contrib/redis/patcher.rb +1 -0
  319. data/lib/ddtrace/contrib/redis/quantize.rb +1 -0
  320. data/lib/ddtrace/contrib/redis/tags.rb +1 -0
  321. data/lib/ddtrace/contrib/redis/vendor/resolver.rb +1 -0
  322. data/lib/ddtrace/contrib/registerable.rb +2 -2
  323. data/lib/ddtrace/contrib/registry.rb +1 -0
  324. data/lib/ddtrace/contrib/resque/configuration/settings.rb +1 -0
  325. data/lib/ddtrace/contrib/resque/ext.rb +1 -0
  326. data/lib/ddtrace/contrib/resque/integration.rb +1 -0
  327. data/lib/ddtrace/contrib/resque/patcher.rb +1 -0
  328. data/lib/ddtrace/contrib/resque/resque_job.rb +1 -0
  329. data/lib/ddtrace/contrib/rest_client/configuration/settings.rb +1 -0
  330. data/lib/ddtrace/contrib/rest_client/ext.rb +1 -0
  331. data/lib/ddtrace/contrib/rest_client/integration.rb +1 -0
  332. data/lib/ddtrace/contrib/rest_client/patcher.rb +2 -0
  333. data/lib/ddtrace/contrib/rest_client/request_patch.rb +1 -0
  334. data/lib/ddtrace/contrib/semantic_logger/configuration/settings.rb +19 -0
  335. data/lib/ddtrace/contrib/semantic_logger/ext.rb +11 -0
  336. data/lib/ddtrace/contrib/semantic_logger/instrumentation.rb +43 -0
  337. data/lib/ddtrace/contrib/semantic_logger/integration.rb +48 -0
  338. data/lib/ddtrace/contrib/semantic_logger/patcher.rb +26 -0
  339. data/lib/ddtrace/contrib/sequel/configuration/settings.rb +1 -0
  340. data/lib/ddtrace/contrib/sequel/database.rb +1 -0
  341. data/lib/ddtrace/contrib/sequel/dataset.rb +1 -0
  342. data/lib/ddtrace/contrib/sequel/ext.rb +1 -0
  343. data/lib/ddtrace/contrib/sequel/integration.rb +1 -0
  344. data/lib/ddtrace/contrib/sequel/patcher.rb +1 -0
  345. data/lib/ddtrace/contrib/sequel/utils.rb +1 -0
  346. data/lib/ddtrace/contrib/shoryuken/configuration/settings.rb +1 -0
  347. data/lib/ddtrace/contrib/shoryuken/ext.rb +1 -0
  348. data/lib/ddtrace/contrib/shoryuken/integration.rb +1 -0
  349. data/lib/ddtrace/contrib/shoryuken/patcher.rb +1 -0
  350. data/lib/ddtrace/contrib/shoryuken/tracer.rb +1 -0
  351. data/lib/ddtrace/contrib/sidekiq/client_tracer.rb +1 -0
  352. data/lib/ddtrace/contrib/sidekiq/configuration/settings.rb +1 -0
  353. data/lib/ddtrace/contrib/sidekiq/ext.rb +4 -0
  354. data/lib/ddtrace/contrib/sidekiq/integration.rb +11 -0
  355. data/lib/ddtrace/contrib/sidekiq/patcher.rb +27 -0
  356. data/lib/ddtrace/contrib/sidekiq/server_internal_tracer/heartbeat.rb +30 -0
  357. data/lib/ddtrace/contrib/sidekiq/server_internal_tracer/job_fetch.rb +30 -0
  358. data/lib/ddtrace/contrib/sidekiq/server_internal_tracer/scheduled_push.rb +29 -0
  359. data/lib/ddtrace/contrib/sidekiq/server_tracer.rb +1 -0
  360. data/lib/ddtrace/contrib/sidekiq/tracing.rb +1 -0
  361. data/lib/ddtrace/contrib/sinatra/configuration/settings.rb +1 -0
  362. data/lib/ddtrace/contrib/sinatra/env.rb +3 -1
  363. data/lib/ddtrace/contrib/sinatra/ext.rb +1 -0
  364. data/lib/ddtrace/contrib/sinatra/headers.rb +1 -0
  365. data/lib/ddtrace/contrib/sinatra/integration.rb +1 -0
  366. data/lib/ddtrace/contrib/sinatra/patcher.rb +2 -0
  367. data/lib/ddtrace/contrib/sinatra/tracer.rb +27 -4
  368. data/lib/ddtrace/contrib/sinatra/tracer_middleware.rb +8 -1
  369. data/lib/ddtrace/contrib/sneakers/configuration/settings.rb +1 -0
  370. data/lib/ddtrace/contrib/sneakers/ext.rb +1 -0
  371. data/lib/ddtrace/contrib/sneakers/integration.rb +1 -0
  372. data/lib/ddtrace/contrib/sneakers/patcher.rb +1 -0
  373. data/lib/ddtrace/contrib/sneakers/tracer.rb +1 -0
  374. data/lib/ddtrace/contrib/status_code_matcher.rb +1 -0
  375. data/lib/ddtrace/contrib/sucker_punch/configuration/settings.rb +1 -0
  376. data/lib/ddtrace/contrib/sucker_punch/exception_handler.rb +1 -0
  377. data/lib/ddtrace/contrib/sucker_punch/ext.rb +1 -0
  378. data/lib/ddtrace/contrib/sucker_punch/instrumentation.rb +1 -0
  379. data/lib/ddtrace/contrib/sucker_punch/integration.rb +1 -0
  380. data/lib/ddtrace/contrib/sucker_punch/patcher.rb +2 -0
  381. data/lib/ddtrace/correlation.rb +2 -1
  382. data/lib/ddtrace/diagnostics/environment_logger.rb +4 -3
  383. data/lib/ddtrace/diagnostics/health.rb +1 -0
  384. data/lib/ddtrace/distributed_tracing/headers/b3.rb +1 -0
  385. data/lib/ddtrace/distributed_tracing/headers/b3_single.rb +1 -0
  386. data/lib/ddtrace/distributed_tracing/headers/datadog.rb +1 -0
  387. data/lib/ddtrace/distributed_tracing/headers/headers.rb +1 -0
  388. data/lib/ddtrace/distributed_tracing/headers/helpers.rb +1 -0
  389. data/lib/ddtrace/encoding.rb +3 -0
  390. data/lib/ddtrace/error.rb +1 -0
  391. data/lib/ddtrace/event.rb +1 -0
  392. data/lib/ddtrace/ext/analytics.rb +1 -0
  393. data/lib/ddtrace/ext/app_types.rb +1 -0
  394. data/lib/ddtrace/ext/correlation.rb +1 -0
  395. data/lib/ddtrace/ext/diagnostics.rb +1 -0
  396. data/lib/ddtrace/ext/distributed.rb +1 -0
  397. data/lib/ddtrace/ext/environment.rb +8 -0
  398. data/lib/ddtrace/ext/errors.rb +1 -0
  399. data/lib/ddtrace/ext/forced_tracing.rb +1 -0
  400. data/lib/ddtrace/ext/git.rb +22 -1
  401. data/lib/ddtrace/ext/http.rb +1 -0
  402. data/lib/ddtrace/ext/integration.rb +1 -0
  403. data/lib/ddtrace/ext/manual_tracing.rb +1 -0
  404. data/lib/ddtrace/ext/metrics.rb +1 -0
  405. data/lib/ddtrace/ext/net.rb +1 -0
  406. data/lib/ddtrace/ext/priority.rb +1 -0
  407. data/lib/ddtrace/ext/profiling.rb +4 -0
  408. data/lib/ddtrace/ext/runtime.rb +4 -9
  409. data/lib/ddtrace/ext/sampling.rb +1 -0
  410. data/lib/ddtrace/ext/sql.rb +1 -0
  411. data/lib/ddtrace/ext/test.rb +1 -0
  412. data/lib/ddtrace/ext/transport.rb +12 -0
  413. data/lib/ddtrace/forced_tracing.rb +1 -0
  414. data/lib/ddtrace/logger.rb +1 -0
  415. data/lib/ddtrace/metrics.rb +60 -33
  416. data/lib/ddtrace/opentelemetry/extensions.rb +1 -0
  417. data/lib/ddtrace/opentelemetry/span.rb +1 -0
  418. data/lib/ddtrace/opentracer/binary_propagator.rb +1 -0
  419. data/lib/ddtrace/opentracer/carrier.rb +1 -0
  420. data/lib/ddtrace/opentracer/distributed_headers.rb +1 -0
  421. data/lib/ddtrace/opentracer/global_tracer.rb +1 -0
  422. data/lib/ddtrace/opentracer/propagator.rb +1 -0
  423. data/lib/ddtrace/opentracer/rack_propagator.rb +1 -0
  424. data/lib/ddtrace/opentracer/scope.rb +1 -0
  425. data/lib/ddtrace/opentracer/scope_manager.rb +1 -0
  426. data/lib/ddtrace/opentracer/span.rb +1 -0
  427. data/lib/ddtrace/opentracer/span_context.rb +1 -0
  428. data/lib/ddtrace/opentracer/span_context_factory.rb +1 -0
  429. data/lib/ddtrace/opentracer/text_map_propagator.rb +1 -0
  430. data/lib/ddtrace/opentracer/thread_local_scope.rb +1 -0
  431. data/lib/ddtrace/opentracer/thread_local_scope_manager.rb +1 -0
  432. data/lib/ddtrace/opentracer/tracer.rb +1 -0
  433. data/lib/ddtrace/opentracer.rb +1 -0
  434. data/lib/ddtrace/patcher.rb +1 -0
  435. data/lib/ddtrace/pin.rb +1 -0
  436. data/lib/ddtrace/pipeline/span_filter.rb +1 -0
  437. data/lib/ddtrace/pipeline/span_processor.rb +1 -0
  438. data/lib/ddtrace/pipeline.rb +1 -0
  439. data/lib/ddtrace/profiling/backtrace_location.rb +1 -0
  440. data/lib/ddtrace/profiling/buffer.rb +1 -0
  441. data/lib/ddtrace/profiling/collectors/stack.rb +77 -38
  442. data/lib/ddtrace/profiling/encoding/profile.rb +10 -1
  443. data/lib/ddtrace/profiling/event.rb +1 -0
  444. data/lib/ddtrace/profiling/events/stack.rb +16 -37
  445. data/lib/ddtrace/profiling/exporter.rb +1 -0
  446. data/lib/ddtrace/profiling/ext/cpu.rb +16 -1
  447. data/lib/ddtrace/profiling/ext/cthread.rb +1 -0
  448. data/lib/ddtrace/profiling/ext/forking.rb +1 -0
  449. data/lib/ddtrace/profiling/flush.rb +10 -9
  450. data/lib/ddtrace/profiling/native_extension.rb +18 -0
  451. data/lib/ddtrace/profiling/pprof/builder.rb +1 -0
  452. data/lib/ddtrace/profiling/pprof/converter.rb +23 -9
  453. data/lib/ddtrace/profiling/pprof/message_set.rb +4 -1
  454. data/lib/ddtrace/profiling/pprof/payload.rb +2 -1
  455. data/lib/ddtrace/profiling/pprof/pprof_pb.rb +1 -0
  456. data/lib/ddtrace/profiling/pprof/stack_sample.rb +43 -6
  457. data/lib/ddtrace/profiling/pprof/string_table.rb +1 -0
  458. data/lib/ddtrace/profiling/pprof/template.rb +1 -0
  459. data/lib/ddtrace/profiling/preload.rb +1 -0
  460. data/lib/ddtrace/profiling/profiler.rb +1 -0
  461. data/lib/ddtrace/profiling/recorder.rb +3 -2
  462. data/lib/ddtrace/profiling/scheduler.rb +21 -3
  463. data/lib/ddtrace/profiling/tasks/setup.rb +9 -5
  464. data/lib/ddtrace/profiling/trace_identifiers/ddtrace.rb +41 -0
  465. data/lib/ddtrace/profiling/trace_identifiers/helper.rb +46 -0
  466. data/lib/ddtrace/profiling/transport/client.rb +3 -0
  467. data/lib/ddtrace/profiling/transport/http/api/endpoint.rb +1 -0
  468. data/lib/ddtrace/profiling/transport/http/api/instance.rb +1 -0
  469. data/lib/ddtrace/profiling/transport/http/api/spec.rb +1 -0
  470. data/lib/ddtrace/profiling/transport/http/api.rb +1 -0
  471. data/lib/ddtrace/profiling/transport/http/builder.rb +1 -0
  472. data/lib/ddtrace/profiling/transport/http/client.rb +1 -0
  473. data/lib/ddtrace/profiling/transport/http/response.rb +1 -0
  474. data/lib/ddtrace/profiling/transport/http.rb +33 -40
  475. data/lib/ddtrace/profiling/transport/io/client.rb +1 -0
  476. data/lib/ddtrace/profiling/transport/io/response.rb +1 -0
  477. data/lib/ddtrace/profiling/transport/io.rb +1 -0
  478. data/lib/ddtrace/profiling/transport/parcel.rb +1 -0
  479. data/lib/ddtrace/profiling/transport/request.rb +1 -0
  480. data/lib/ddtrace/profiling/transport/response.rb +1 -0
  481. data/lib/ddtrace/profiling.rb +64 -20
  482. data/lib/ddtrace/propagation/grpc_propagator.rb +1 -0
  483. data/lib/ddtrace/propagation/http_propagator.rb +3 -2
  484. data/lib/ddtrace/quantization/hash.rb +1 -0
  485. data/lib/ddtrace/quantization/http.rb +3 -0
  486. data/lib/ddtrace/runtime/metrics.rb +33 -10
  487. data/lib/ddtrace/sampler.rb +1 -0
  488. data/lib/ddtrace/sampling/matcher.rb +1 -0
  489. data/lib/ddtrace/sampling/rate_limiter.rb +1 -0
  490. data/lib/ddtrace/sampling/rule.rb +2 -1
  491. data/lib/ddtrace/sampling/rule_sampler.rb +2 -1
  492. data/lib/ddtrace/sampling.rb +1 -0
  493. data/lib/ddtrace/span.rb +21 -8
  494. data/lib/ddtrace/sync_writer.rb +3 -2
  495. data/lib/ddtrace/tasks/exec.rb +4 -5
  496. data/lib/ddtrace/tasks/help.rb +1 -0
  497. data/lib/ddtrace/tracer.rb +7 -15
  498. data/lib/ddtrace/transport/http/adapters/net.rb +14 -3
  499. data/lib/ddtrace/transport/http/adapters/registry.rb +1 -0
  500. data/lib/ddtrace/transport/http/adapters/test.rb +5 -2
  501. data/lib/ddtrace/transport/http/adapters/unix_socket.rb +24 -12
  502. data/lib/ddtrace/transport/http/api/endpoint.rb +1 -0
  503. data/lib/ddtrace/transport/http/api/fallbacks.rb +1 -0
  504. data/lib/ddtrace/transport/http/api/instance.rb +1 -0
  505. data/lib/ddtrace/transport/http/api/map.rb +1 -0
  506. data/lib/ddtrace/transport/http/api/spec.rb +1 -0
  507. data/lib/ddtrace/transport/http/api.rb +1 -0
  508. data/lib/ddtrace/transport/http/builder.rb +14 -6
  509. data/lib/ddtrace/transport/http/client.rb +3 -1
  510. data/lib/ddtrace/transport/http/env.rb +1 -0
  511. data/lib/ddtrace/transport/http/response.rb +1 -0
  512. data/lib/ddtrace/transport/http/statistics.rb +1 -0
  513. data/lib/ddtrace/transport/http/traces.rb +1 -0
  514. data/lib/ddtrace/transport/http.rb +15 -18
  515. data/lib/ddtrace/transport/io/client.rb +2 -1
  516. data/lib/ddtrace/transport/io/response.rb +1 -0
  517. data/lib/ddtrace/transport/io/traces.rb +3 -0
  518. data/lib/ddtrace/transport/io.rb +1 -0
  519. data/lib/ddtrace/transport/parcel.rb +3 -0
  520. data/lib/ddtrace/transport/request.rb +1 -0
  521. data/lib/ddtrace/transport/response.rb +1 -0
  522. data/lib/ddtrace/transport/statistics.rb +1 -0
  523. data/lib/ddtrace/transport/traces.rb +3 -2
  524. data/lib/ddtrace/utils/compression.rb +1 -0
  525. data/lib/ddtrace/utils/database.rb +1 -0
  526. data/lib/ddtrace/utils/forking.rb +1 -0
  527. data/lib/ddtrace/utils/object_set.rb +1 -0
  528. data/lib/ddtrace/utils/only_once.rb +1 -0
  529. data/lib/ddtrace/utils/sequence.rb +1 -0
  530. data/lib/ddtrace/utils/string_table.rb +1 -0
  531. data/lib/ddtrace/utils/time.rb +8 -6
  532. data/lib/ddtrace/utils.rb +14 -2
  533. data/lib/ddtrace/vendor/active_record/connection_specification.rb +1 -0
  534. data/lib/ddtrace/vendor/multipart-post/multipart/post/composite_read_io.rb +1 -0
  535. data/lib/ddtrace/vendor/multipart-post/multipart/post/multipartable.rb +1 -0
  536. data/lib/ddtrace/vendor/multipart-post/multipart/post/parts.rb +1 -0
  537. data/lib/ddtrace/vendor/multipart-post/multipart/post/version.rb +1 -0
  538. data/lib/ddtrace/vendor/multipart-post/multipart/post.rb +1 -0
  539. data/lib/ddtrace/vendor/multipart-post/multipart.rb +1 -0
  540. data/lib/ddtrace/vendor/multipart-post/net/http/post/multipart.rb +1 -0
  541. data/lib/ddtrace/version.rb +2 -1
  542. data/lib/ddtrace/worker.rb +1 -0
  543. data/lib/ddtrace/workers/async.rb +2 -1
  544. data/lib/ddtrace/workers/loop.rb +1 -0
  545. data/lib/ddtrace/workers/polling.rb +1 -0
  546. data/lib/ddtrace/workers/queue.rb +1 -0
  547. data/lib/ddtrace/workers/runtime_metrics.rb +1 -0
  548. data/lib/ddtrace/workers/trace_writer.rb +3 -2
  549. data/lib/ddtrace/workers.rb +2 -1
  550. data/lib/ddtrace/writer.rb +3 -2
  551. data/lib/ddtrace.rb +19 -49
  552. metadata +59 -562
  553. data/.circleci/config.yml +0 -870
  554. data/.circleci/images/primary/Dockerfile-2.1.10 +0 -83
  555. data/.circleci/images/primary/Dockerfile-2.2.10 +0 -83
  556. data/.circleci/images/primary/Dockerfile-2.3.8 +0 -85
  557. data/.circleci/images/primary/Dockerfile-2.4.6 +0 -83
  558. data/.circleci/images/primary/Dockerfile-2.5.6 +0 -83
  559. data/.circleci/images/primary/Dockerfile-2.6.4 +0 -83
  560. data/.circleci/images/primary/Dockerfile-2.7.0 +0 -83
  561. data/.circleci/images/primary/Dockerfile-3.0.0 +0 -73
  562. data/.circleci/images/primary/Dockerfile-jruby-9.2-latest +0 -88
  563. data/.circleci/images/primary/Dockerfile-jruby-9.2.0.0 +0 -73
  564. data/.circleci/images/primary/Dockerfile-truffleruby-21.1.0 +0 -73
  565. data/.dockerignore +0 -0
  566. data/.env +0 -26
  567. data/.github/CODEOWNERS +0 -1
  568. data/.github/workflows/add-milestone-to-pull-requests.yml +0 -42
  569. data/.github/workflows/create-next-milestone.yml +0 -20
  570. data/.gitlab-ci.yml +0 -27
  571. data/.rspec +0 -1
  572. data/.rubocop.yml +0 -351
  573. data/.rubocop_todo.yml +0 -438
  574. data/.simplecov +0 -47
  575. data/Appraisals +0 -1323
  576. data/Gemfile +0 -69
  577. data/Rakefile +0 -939
  578. data/benchmarks/data/profiler-submission-marshal.gz +0 -0
  579. data/benchmarks/postgres_database.yml +0 -9
  580. data/benchmarks/profiler_sample_loop.rb +0 -69
  581. data/benchmarks/profiler_submission.rb +0 -93
  582. data/benchmarks/sidekiq_test.rb +0 -154
  583. data/docker-compose.yml +0 -414
  584. data/gemfiles/jruby_9.2.0.0_contrib.gemfile +0 -79
  585. data/gemfiles/jruby_9.2.0.0_contrib.gemfile.lock +0 -1518
  586. data/gemfiles/jruby_9.2.0.0_contrib_old.gemfile +0 -35
  587. data/gemfiles/jruby_9.2.0.0_contrib_old.gemfile.lock +0 -157
  588. data/gemfiles/jruby_9.2.0.0_core_old.gemfile +0 -34
  589. data/gemfiles/jruby_9.2.0.0_core_old.gemfile.lock +0 -153
  590. data/gemfiles/jruby_9.2.0.0_cucumber3.gemfile +0 -35
  591. data/gemfiles/jruby_9.2.0.0_cucumber3.gemfile.lock +0 -174
  592. data/gemfiles/jruby_9.2.0.0_cucumber4.gemfile +0 -35
  593. data/gemfiles/jruby_9.2.0.0_cucumber4.gemfile.lock +0 -206
  594. data/gemfiles/jruby_9.2.0.0_cucumber5.gemfile +0 -35
  595. data/gemfiles/jruby_9.2.0.0_cucumber5.gemfile.lock +0 -206
  596. data/gemfiles/jruby_9.2.0.0_rails5_mysql2.gemfile +0 -40
  597. data/gemfiles/jruby_9.2.0.0_rails5_mysql2.gemfile.lock +0 -271
  598. data/gemfiles/jruby_9.2.0.0_rails5_postgres.gemfile +0 -40
  599. data/gemfiles/jruby_9.2.0.0_rails5_postgres.gemfile.lock +0 -271
  600. data/gemfiles/jruby_9.2.0.0_rails5_postgres_redis.gemfile +0 -41
  601. data/gemfiles/jruby_9.2.0.0_rails5_postgres_redis.gemfile.lock +0 -273
  602. data/gemfiles/jruby_9.2.0.0_rails5_postgres_redis_activesupport.gemfile +0 -41
  603. data/gemfiles/jruby_9.2.0.0_rails5_postgres_redis_activesupport.gemfile.lock +0 -273
  604. data/gemfiles/jruby_9.2.0.0_rails5_postgres_sidekiq.gemfile +0 -42
  605. data/gemfiles/jruby_9.2.0.0_rails5_postgres_sidekiq.gemfile.lock +0 -279
  606. data/gemfiles/jruby_9.2.0.0_rails61_mysql2.gemfile +0 -40
  607. data/gemfiles/jruby_9.2.0.0_rails61_mysql2.gemfile.lock +0 -290
  608. data/gemfiles/jruby_9.2.0.0_rails61_postgres.gemfile +0 -40
  609. data/gemfiles/jruby_9.2.0.0_rails61_postgres.gemfile.lock +0 -290
  610. data/gemfiles/jruby_9.2.0.0_rails61_postgres_redis.gemfile +0 -41
  611. data/gemfiles/jruby_9.2.0.0_rails61_postgres_redis.gemfile.lock +0 -292
  612. data/gemfiles/jruby_9.2.0.0_rails61_postgres_sidekiq.gemfile +0 -41
  613. data/gemfiles/jruby_9.2.0.0_rails61_postgres_sidekiq.gemfile.lock +0 -297
  614. data/gemfiles/jruby_9.2.0.0_rails6_mysql2.gemfile +0 -40
  615. data/gemfiles/jruby_9.2.0.0_rails6_mysql2.gemfile.lock +0 -287
  616. data/gemfiles/jruby_9.2.0.0_rails6_postgres.gemfile +0 -40
  617. data/gemfiles/jruby_9.2.0.0_rails6_postgres.gemfile.lock +0 -287
  618. data/gemfiles/jruby_9.2.0.0_rails6_postgres_redis.gemfile +0 -41
  619. data/gemfiles/jruby_9.2.0.0_rails6_postgres_redis.gemfile.lock +0 -289
  620. data/gemfiles/jruby_9.2.0.0_rails6_postgres_redis_activesupport.gemfile +0 -41
  621. data/gemfiles/jruby_9.2.0.0_rails6_postgres_redis_activesupport.gemfile.lock +0 -289
  622. data/gemfiles/jruby_9.2.0.0_rails6_postgres_sidekiq.gemfile +0 -42
  623. data/gemfiles/jruby_9.2.0.0_rails6_postgres_sidekiq.gemfile.lock +0 -295
  624. data/gemfiles/jruby_9.2.0.0_resque2_redis3.gemfile +0 -36
  625. data/gemfiles/jruby_9.2.0.0_resque2_redis3.gemfile.lock +0 -180
  626. data/gemfiles/jruby_9.2.0.0_resque2_redis4.gemfile +0 -36
  627. data/gemfiles/jruby_9.2.0.0_resque2_redis4.gemfile.lock +0 -180
  628. data/gemfiles/jruby_9.2.11.1_contrib.gemfile +0 -79
  629. data/gemfiles/jruby_9.2.11.1_contrib.gemfile.lock +0 -1518
  630. data/gemfiles/jruby_9.2.11.1_contrib_old.gemfile +0 -35
  631. data/gemfiles/jruby_9.2.11.1_contrib_old.gemfile.lock +0 -157
  632. data/gemfiles/jruby_9.2.11.1_core_old.gemfile +0 -34
  633. data/gemfiles/jruby_9.2.11.1_core_old.gemfile.lock +0 -153
  634. data/gemfiles/jruby_9.2.11.1_cucumber3.gemfile +0 -35
  635. data/gemfiles/jruby_9.2.11.1_cucumber3.gemfile.lock +0 -174
  636. data/gemfiles/jruby_9.2.11.1_cucumber4.gemfile +0 -35
  637. data/gemfiles/jruby_9.2.11.1_cucumber4.gemfile.lock +0 -206
  638. data/gemfiles/jruby_9.2.11.1_cucumber5.gemfile +0 -35
  639. data/gemfiles/jruby_9.2.11.1_cucumber5.gemfile.lock +0 -206
  640. data/gemfiles/jruby_9.2.11.1_rails5_mysql2.gemfile +0 -40
  641. data/gemfiles/jruby_9.2.11.1_rails5_mysql2.gemfile.lock +0 -271
  642. data/gemfiles/jruby_9.2.11.1_rails5_postgres.gemfile +0 -40
  643. data/gemfiles/jruby_9.2.11.1_rails5_postgres.gemfile.lock +0 -271
  644. data/gemfiles/jruby_9.2.11.1_rails5_postgres_redis.gemfile +0 -41
  645. data/gemfiles/jruby_9.2.11.1_rails5_postgres_redis.gemfile.lock +0 -273
  646. data/gemfiles/jruby_9.2.11.1_rails5_postgres_redis_activesupport.gemfile +0 -41
  647. data/gemfiles/jruby_9.2.11.1_rails5_postgres_redis_activesupport.gemfile.lock +0 -273
  648. data/gemfiles/jruby_9.2.11.1_rails5_postgres_sidekiq.gemfile +0 -42
  649. data/gemfiles/jruby_9.2.11.1_rails5_postgres_sidekiq.gemfile.lock +0 -279
  650. data/gemfiles/jruby_9.2.11.1_rails61_mysql2.gemfile +0 -40
  651. data/gemfiles/jruby_9.2.11.1_rails61_mysql2.gemfile.lock +0 -290
  652. data/gemfiles/jruby_9.2.11.1_rails61_postgres.gemfile +0 -40
  653. data/gemfiles/jruby_9.2.11.1_rails61_postgres.gemfile.lock +0 -290
  654. data/gemfiles/jruby_9.2.11.1_rails61_postgres_redis.gemfile +0 -41
  655. data/gemfiles/jruby_9.2.11.1_rails61_postgres_redis.gemfile.lock +0 -292
  656. data/gemfiles/jruby_9.2.11.1_rails61_postgres_sidekiq.gemfile +0 -41
  657. data/gemfiles/jruby_9.2.11.1_rails61_postgres_sidekiq.gemfile.lock +0 -297
  658. data/gemfiles/jruby_9.2.11.1_rails6_mysql2.gemfile +0 -40
  659. data/gemfiles/jruby_9.2.11.1_rails6_mysql2.gemfile.lock +0 -287
  660. data/gemfiles/jruby_9.2.11.1_rails6_postgres.gemfile +0 -40
  661. data/gemfiles/jruby_9.2.11.1_rails6_postgres.gemfile.lock +0 -287
  662. data/gemfiles/jruby_9.2.11.1_rails6_postgres_redis.gemfile +0 -41
  663. data/gemfiles/jruby_9.2.11.1_rails6_postgres_redis.gemfile.lock +0 -289
  664. data/gemfiles/jruby_9.2.11.1_rails6_postgres_redis_activesupport.gemfile +0 -41
  665. data/gemfiles/jruby_9.2.11.1_rails6_postgres_redis_activesupport.gemfile.lock +0 -289
  666. data/gemfiles/jruby_9.2.11.1_rails6_postgres_sidekiq.gemfile +0 -42
  667. data/gemfiles/jruby_9.2.11.1_rails6_postgres_sidekiq.gemfile.lock +0 -295
  668. data/gemfiles/jruby_9.2.11.1_resque2_redis3.gemfile +0 -36
  669. data/gemfiles/jruby_9.2.11.1_resque2_redis3.gemfile.lock +0 -180
  670. data/gemfiles/jruby_9.2.11.1_resque2_redis4.gemfile +0 -36
  671. data/gemfiles/jruby_9.2.11.1_resque2_redis4.gemfile.lock +0 -180
  672. data/gemfiles/ruby_2.1.10_contrib_old.gemfile +0 -66
  673. data/gemfiles/ruby_2.1.10_contrib_old.gemfile.lock +0 -305
  674. data/gemfiles/ruby_2.1.10_core_old.gemfile +0 -33
  675. data/gemfiles/ruby_2.1.10_core_old.gemfile.lock +0 -118
  676. data/gemfiles/ruby_2.1.10_rails30_postgres.gemfile +0 -39
  677. data/gemfiles/ruby_2.1.10_rails30_postgres.gemfile.lock +0 -196
  678. data/gemfiles/ruby_2.1.10_rails30_postgres_sidekiq.gemfile +0 -40
  679. data/gemfiles/ruby_2.1.10_rails30_postgres_sidekiq.gemfile.lock +0 -205
  680. data/gemfiles/ruby_2.1.10_rails32_mysql2.gemfile +0 -42
  681. data/gemfiles/ruby_2.1.10_rails32_mysql2.gemfile.lock +0 -215
  682. data/gemfiles/ruby_2.1.10_rails32_postgres.gemfile +0 -39
  683. data/gemfiles/ruby_2.1.10_rails32_postgres.gemfile.lock +0 -204
  684. data/gemfiles/ruby_2.1.10_rails32_postgres_redis.gemfile +0 -41
  685. data/gemfiles/ruby_2.1.10_rails32_postgres_redis.gemfile.lock +0 -223
  686. data/gemfiles/ruby_2.1.10_rails32_postgres_sidekiq.gemfile +0 -40
  687. data/gemfiles/ruby_2.1.10_rails32_postgres_sidekiq.gemfile.lock +0 -213
  688. data/gemfiles/ruby_2.1.10_rails4_mysql2.gemfile +0 -38
  689. data/gemfiles/ruby_2.1.10_rails4_mysql2.gemfile.lock +0 -218
  690. data/gemfiles/ruby_2.1.10_rails4_postgres.gemfile +0 -38
  691. data/gemfiles/ruby_2.1.10_rails4_postgres.gemfile.lock +0 -218
  692. data/gemfiles/ruby_2.1.10_rails4_postgres_redis.gemfile +0 -40
  693. data/gemfiles/ruby_2.1.10_rails4_postgres_redis.gemfile.lock +0 -237
  694. data/gemfiles/ruby_2.2.10_contrib.gemfile +0 -73
  695. data/gemfiles/ruby_2.2.10_contrib.gemfile.lock +0 -1450
  696. data/gemfiles/ruby_2.2.10_core_old.gemfile +0 -33
  697. data/gemfiles/ruby_2.2.10_core_old.gemfile.lock +0 -118
  698. data/gemfiles/ruby_2.2.10_rails30_postgres.gemfile +0 -39
  699. data/gemfiles/ruby_2.2.10_rails30_postgres.gemfile.lock +0 -196
  700. data/gemfiles/ruby_2.2.10_rails30_postgres_sidekiq.gemfile +0 -40
  701. data/gemfiles/ruby_2.2.10_rails30_postgres_sidekiq.gemfile.lock +0 -205
  702. data/gemfiles/ruby_2.2.10_rails32_mysql2.gemfile +0 -41
  703. data/gemfiles/ruby_2.2.10_rails32_mysql2.gemfile.lock +0 -212
  704. data/gemfiles/ruby_2.2.10_rails32_postgres.gemfile +0 -39
  705. data/gemfiles/ruby_2.2.10_rails32_postgres.gemfile.lock +0 -204
  706. data/gemfiles/ruby_2.2.10_rails32_postgres_redis.gemfile +0 -41
  707. data/gemfiles/ruby_2.2.10_rails32_postgres_redis.gemfile.lock +0 -223
  708. data/gemfiles/ruby_2.2.10_rails32_postgres_sidekiq.gemfile +0 -40
  709. data/gemfiles/ruby_2.2.10_rails32_postgres_sidekiq.gemfile.lock +0 -213
  710. data/gemfiles/ruby_2.2.10_rails4_mysql2.gemfile +0 -38
  711. data/gemfiles/ruby_2.2.10_rails4_mysql2.gemfile.lock +0 -218
  712. data/gemfiles/ruby_2.2.10_rails4_postgres.gemfile +0 -38
  713. data/gemfiles/ruby_2.2.10_rails4_postgres.gemfile.lock +0 -218
  714. data/gemfiles/ruby_2.2.10_rails4_postgres_redis.gemfile +0 -40
  715. data/gemfiles/ruby_2.2.10_rails4_postgres_redis.gemfile.lock +0 -237
  716. data/gemfiles/ruby_2.2.10_rails4_postgres_sidekiq.gemfile +0 -40
  717. data/gemfiles/ruby_2.2.10_rails4_postgres_sidekiq.gemfile.lock +0 -229
  718. data/gemfiles/ruby_2.2.10_rails5_mysql2.gemfile +0 -38
  719. data/gemfiles/ruby_2.2.10_rails5_mysql2.gemfile.lock +0 -234
  720. data/gemfiles/ruby_2.2.10_rails5_postgres.gemfile +0 -38
  721. data/gemfiles/ruby_2.2.10_rails5_postgres.gemfile.lock +0 -234
  722. data/gemfiles/ruby_2.2.10_rails5_postgres_redis.gemfile +0 -39
  723. data/gemfiles/ruby_2.2.10_rails5_postgres_redis.gemfile.lock +0 -236
  724. data/gemfiles/ruby_2.2.10_rails5_postgres_redis_activesupport.gemfile +0 -39
  725. data/gemfiles/ruby_2.2.10_rails5_postgres_redis_activesupport.gemfile.lock +0 -236
  726. data/gemfiles/ruby_2.2.10_rails5_postgres_sidekiq.gemfile +0 -40
  727. data/gemfiles/ruby_2.2.10_rails5_postgres_sidekiq.gemfile.lock +0 -245
  728. data/gemfiles/ruby_2.3.8_contrib.gemfile +0 -73
  729. data/gemfiles/ruby_2.3.8_contrib.gemfile.lock +0 -1459
  730. data/gemfiles/ruby_2.3.8_contrib_old.gemfile +0 -34
  731. data/gemfiles/ruby_2.3.8_contrib_old.gemfile.lock +0 -127
  732. data/gemfiles/ruby_2.3.8_core_old.gemfile +0 -33
  733. data/gemfiles/ruby_2.3.8_core_old.gemfile.lock +0 -123
  734. data/gemfiles/ruby_2.3.8_cucumber3.gemfile +0 -34
  735. data/gemfiles/ruby_2.3.8_cucumber3.gemfile.lock +0 -144
  736. data/gemfiles/ruby_2.3.8_cucumber4.gemfile +0 -34
  737. data/gemfiles/ruby_2.3.8_cucumber4.gemfile.lock +0 -174
  738. data/gemfiles/ruby_2.3.8_rails30_postgres.gemfile +0 -39
  739. data/gemfiles/ruby_2.3.8_rails30_postgres.gemfile.lock +0 -201
  740. data/gemfiles/ruby_2.3.8_rails30_postgres_sidekiq.gemfile +0 -40
  741. data/gemfiles/ruby_2.3.8_rails30_postgres_sidekiq.gemfile.lock +0 -210
  742. data/gemfiles/ruby_2.3.8_rails32_mysql2.gemfile +0 -41
  743. data/gemfiles/ruby_2.3.8_rails32_mysql2.gemfile.lock +0 -217
  744. data/gemfiles/ruby_2.3.8_rails32_postgres.gemfile +0 -39
  745. data/gemfiles/ruby_2.3.8_rails32_postgres.gemfile.lock +0 -209
  746. data/gemfiles/ruby_2.3.8_rails32_postgres_redis.gemfile +0 -41
  747. data/gemfiles/ruby_2.3.8_rails32_postgres_redis.gemfile.lock +0 -228
  748. data/gemfiles/ruby_2.3.8_rails32_postgres_sidekiq.gemfile +0 -40
  749. data/gemfiles/ruby_2.3.8_rails32_postgres_sidekiq.gemfile.lock +0 -218
  750. data/gemfiles/ruby_2.3.8_rails4_mysql2.gemfile +0 -38
  751. data/gemfiles/ruby_2.3.8_rails4_mysql2.gemfile.lock +0 -223
  752. data/gemfiles/ruby_2.3.8_rails4_postgres.gemfile +0 -38
  753. data/gemfiles/ruby_2.3.8_rails4_postgres.gemfile.lock +0 -223
  754. data/gemfiles/ruby_2.3.8_rails4_postgres_redis.gemfile +0 -40
  755. data/gemfiles/ruby_2.3.8_rails4_postgres_redis.gemfile.lock +0 -242
  756. data/gemfiles/ruby_2.3.8_rails4_postgres_sidekiq.gemfile +0 -40
  757. data/gemfiles/ruby_2.3.8_rails4_postgres_sidekiq.gemfile.lock +0 -234
  758. data/gemfiles/ruby_2.3.8_rails5_mysql2.gemfile +0 -37
  759. data/gemfiles/ruby_2.3.8_rails5_mysql2.gemfile.lock +0 -234
  760. data/gemfiles/ruby_2.3.8_rails5_postgres.gemfile +0 -37
  761. data/gemfiles/ruby_2.3.8_rails5_postgres.gemfile.lock +0 -234
  762. data/gemfiles/ruby_2.3.8_rails5_postgres_redis.gemfile +0 -38
  763. data/gemfiles/ruby_2.3.8_rails5_postgres_redis.gemfile.lock +0 -236
  764. data/gemfiles/ruby_2.3.8_rails5_postgres_redis_activesupport.gemfile +0 -38
  765. data/gemfiles/ruby_2.3.8_rails5_postgres_redis_activesupport.gemfile.lock +0 -236
  766. data/gemfiles/ruby_2.3.8_rails5_postgres_sidekiq.gemfile +0 -39
  767. data/gemfiles/ruby_2.3.8_rails5_postgres_sidekiq.gemfile.lock +0 -245
  768. data/gemfiles/ruby_2.3.8_resque2_redis3.gemfile +0 -35
  769. data/gemfiles/ruby_2.3.8_resque2_redis3.gemfile.lock +0 -150
  770. data/gemfiles/ruby_2.3.8_resque2_redis4.gemfile +0 -35
  771. data/gemfiles/ruby_2.3.8_resque2_redis4.gemfile.lock +0 -150
  772. data/gemfiles/ruby_2.4.6_contrib.gemfile +0 -78
  773. data/gemfiles/ruby_2.4.6_contrib.gemfile.lock +0 -1513
  774. data/gemfiles/ruby_2.4.6_contrib_old.gemfile +0 -38
  775. data/gemfiles/ruby_2.4.6_contrib_old.gemfile.lock +0 -155
  776. data/gemfiles/ruby_2.4.6_core_old.gemfile +0 -37
  777. data/gemfiles/ruby_2.4.6_core_old.gemfile.lock +0 -151
  778. data/gemfiles/ruby_2.4.6_cucumber3.gemfile +0 -38
  779. data/gemfiles/ruby_2.4.6_cucumber3.gemfile.lock +0 -172
  780. data/gemfiles/ruby_2.4.6_cucumber4.gemfile +0 -38
  781. data/gemfiles/ruby_2.4.6_cucumber4.gemfile.lock +0 -202
  782. data/gemfiles/ruby_2.4.6_rails5_mysql2.gemfile +0 -41
  783. data/gemfiles/ruby_2.4.6_rails5_mysql2.gemfile.lock +0 -262
  784. data/gemfiles/ruby_2.4.6_rails5_postgres.gemfile +0 -41
  785. data/gemfiles/ruby_2.4.6_rails5_postgres.gemfile.lock +0 -262
  786. data/gemfiles/ruby_2.4.6_rails5_postgres_redis.gemfile +0 -42
  787. data/gemfiles/ruby_2.4.6_rails5_postgres_redis.gemfile.lock +0 -264
  788. data/gemfiles/ruby_2.4.6_rails5_postgres_redis_activesupport.gemfile +0 -42
  789. data/gemfiles/ruby_2.4.6_rails5_postgres_redis_activesupport.gemfile.lock +0 -264
  790. data/gemfiles/ruby_2.4.6_rails5_postgres_sidekiq.gemfile +0 -43
  791. data/gemfiles/ruby_2.4.6_rails5_postgres_sidekiq.gemfile.lock +0 -273
  792. data/gemfiles/ruby_2.4.6_resque2_redis3.gemfile +0 -39
  793. data/gemfiles/ruby_2.4.6_resque2_redis3.gemfile.lock +0 -178
  794. data/gemfiles/ruby_2.4.6_resque2_redis4.gemfile +0 -39
  795. data/gemfiles/ruby_2.4.6_resque2_redis4.gemfile.lock +0 -178
  796. data/gemfiles/ruby_2.5.6_contrib.gemfile +0 -83
  797. data/gemfiles/ruby_2.5.6_contrib.gemfile.lock +0 -1526
  798. data/gemfiles/ruby_2.5.6_contrib_old.gemfile +0 -39
  799. data/gemfiles/ruby_2.5.6_contrib_old.gemfile.lock +0 -165
  800. data/gemfiles/ruby_2.5.6_core_old.gemfile +0 -38
  801. data/gemfiles/ruby_2.5.6_core_old.gemfile.lock +0 -161
  802. data/gemfiles/ruby_2.5.6_cucumber3.gemfile +0 -39
  803. data/gemfiles/ruby_2.5.6_cucumber3.gemfile.lock +0 -182
  804. data/gemfiles/ruby_2.5.6_cucumber4.gemfile +0 -39
  805. data/gemfiles/ruby_2.5.6_cucumber4.gemfile.lock +0 -214
  806. data/gemfiles/ruby_2.5.6_cucumber5.gemfile +0 -39
  807. data/gemfiles/ruby_2.5.6_cucumber5.gemfile.lock +0 -214
  808. data/gemfiles/ruby_2.5.6_rails5_mysql2.gemfile +0 -44
  809. data/gemfiles/ruby_2.5.6_rails5_mysql2.gemfile.lock +0 -276
  810. data/gemfiles/ruby_2.5.6_rails5_postgres.gemfile +0 -44
  811. data/gemfiles/ruby_2.5.6_rails5_postgres.gemfile.lock +0 -276
  812. data/gemfiles/ruby_2.5.6_rails5_postgres_redis.gemfile +0 -45
  813. data/gemfiles/ruby_2.5.6_rails5_postgres_redis.gemfile.lock +0 -278
  814. data/gemfiles/ruby_2.5.6_rails5_postgres_redis_activesupport.gemfile +0 -45
  815. data/gemfiles/ruby_2.5.6_rails5_postgres_redis_activesupport.gemfile.lock +0 -278
  816. data/gemfiles/ruby_2.5.6_rails5_postgres_sidekiq.gemfile +0 -46
  817. data/gemfiles/ruby_2.5.6_rails5_postgres_sidekiq.gemfile.lock +0 -284
  818. data/gemfiles/ruby_2.5.6_rails61_mysql2.gemfile +0 -44
  819. data/gemfiles/ruby_2.5.6_rails61_mysql2.gemfile.lock +0 -295
  820. data/gemfiles/ruby_2.5.6_rails61_postgres.gemfile +0 -44
  821. data/gemfiles/ruby_2.5.6_rails61_postgres.gemfile.lock +0 -295
  822. data/gemfiles/ruby_2.5.6_rails61_postgres_redis.gemfile +0 -45
  823. data/gemfiles/ruby_2.5.6_rails61_postgres_redis.gemfile.lock +0 -297
  824. data/gemfiles/ruby_2.5.6_rails61_postgres_sidekiq.gemfile +0 -45
  825. data/gemfiles/ruby_2.5.6_rails61_postgres_sidekiq.gemfile.lock +0 -302
  826. data/gemfiles/ruby_2.5.6_rails6_mysql2.gemfile +0 -44
  827. data/gemfiles/ruby_2.5.6_rails6_mysql2.gemfile.lock +0 -292
  828. data/gemfiles/ruby_2.5.6_rails6_postgres.gemfile +0 -44
  829. data/gemfiles/ruby_2.5.6_rails6_postgres.gemfile.lock +0 -292
  830. data/gemfiles/ruby_2.5.6_rails6_postgres_redis.gemfile +0 -45
  831. data/gemfiles/ruby_2.5.6_rails6_postgres_redis.gemfile.lock +0 -294
  832. data/gemfiles/ruby_2.5.6_rails6_postgres_redis_activesupport.gemfile +0 -45
  833. data/gemfiles/ruby_2.5.6_rails6_postgres_redis_activesupport.gemfile.lock +0 -294
  834. data/gemfiles/ruby_2.5.6_rails6_postgres_sidekiq.gemfile +0 -46
  835. data/gemfiles/ruby_2.5.6_rails6_postgres_sidekiq.gemfile.lock +0 -300
  836. data/gemfiles/ruby_2.5.6_resque2_redis3.gemfile +0 -40
  837. data/gemfiles/ruby_2.5.6_resque2_redis3.gemfile.lock +0 -188
  838. data/gemfiles/ruby_2.5.6_resque2_redis4.gemfile +0 -40
  839. data/gemfiles/ruby_2.5.6_resque2_redis4.gemfile.lock +0 -188
  840. data/gemfiles/ruby_2.6.4_contrib.gemfile +0 -79
  841. data/gemfiles/ruby_2.6.4_contrib.gemfile.lock +0 -1524
  842. data/gemfiles/ruby_2.6.4_contrib_old.gemfile +0 -39
  843. data/gemfiles/ruby_2.6.4_contrib_old.gemfile.lock +0 -167
  844. data/gemfiles/ruby_2.6.4_core_old.gemfile +0 -38
  845. data/gemfiles/ruby_2.6.4_core_old.gemfile.lock +0 -163
  846. data/gemfiles/ruby_2.6.4_cucumber3.gemfile +0 -39
  847. data/gemfiles/ruby_2.6.4_cucumber3.gemfile.lock +0 -184
  848. data/gemfiles/ruby_2.6.4_cucumber4.gemfile +0 -39
  849. data/gemfiles/ruby_2.6.4_cucumber4.gemfile.lock +0 -216
  850. data/gemfiles/ruby_2.6.4_cucumber5.gemfile +0 -39
  851. data/gemfiles/ruby_2.6.4_cucumber5.gemfile.lock +0 -216
  852. data/gemfiles/ruby_2.6.4_rails5_mysql2.gemfile +0 -42
  853. data/gemfiles/ruby_2.6.4_rails5_mysql2.gemfile.lock +0 -276
  854. data/gemfiles/ruby_2.6.4_rails5_postgres.gemfile +0 -42
  855. data/gemfiles/ruby_2.6.4_rails5_postgres.gemfile.lock +0 -276
  856. data/gemfiles/ruby_2.6.4_rails5_postgres_redis.gemfile +0 -43
  857. data/gemfiles/ruby_2.6.4_rails5_postgres_redis.gemfile.lock +0 -278
  858. data/gemfiles/ruby_2.6.4_rails5_postgres_redis_activesupport.gemfile +0 -43
  859. data/gemfiles/ruby_2.6.4_rails5_postgres_redis_activesupport.gemfile.lock +0 -278
  860. data/gemfiles/ruby_2.6.4_rails5_postgres_sidekiq.gemfile +0 -44
  861. data/gemfiles/ruby_2.6.4_rails5_postgres_sidekiq.gemfile.lock +0 -284
  862. data/gemfiles/ruby_2.6.4_rails61_mysql2.gemfile +0 -42
  863. data/gemfiles/ruby_2.6.4_rails61_mysql2.gemfile.lock +0 -295
  864. data/gemfiles/ruby_2.6.4_rails61_postgres.gemfile +0 -42
  865. data/gemfiles/ruby_2.6.4_rails61_postgres.gemfile.lock +0 -295
  866. data/gemfiles/ruby_2.6.4_rails61_postgres_redis.gemfile +0 -43
  867. data/gemfiles/ruby_2.6.4_rails61_postgres_redis.gemfile.lock +0 -297
  868. data/gemfiles/ruby_2.6.4_rails61_postgres_sidekiq.gemfile +0 -43
  869. data/gemfiles/ruby_2.6.4_rails61_postgres_sidekiq.gemfile.lock +0 -302
  870. data/gemfiles/ruby_2.6.4_rails6_mysql2.gemfile +0 -42
  871. data/gemfiles/ruby_2.6.4_rails6_mysql2.gemfile.lock +0 -292
  872. data/gemfiles/ruby_2.6.4_rails6_postgres.gemfile +0 -42
  873. data/gemfiles/ruby_2.6.4_rails6_postgres.gemfile.lock +0 -292
  874. data/gemfiles/ruby_2.6.4_rails6_postgres_redis.gemfile +0 -43
  875. data/gemfiles/ruby_2.6.4_rails6_postgres_redis.gemfile.lock +0 -294
  876. data/gemfiles/ruby_2.6.4_rails6_postgres_redis_activesupport.gemfile +0 -43
  877. data/gemfiles/ruby_2.6.4_rails6_postgres_redis_activesupport.gemfile.lock +0 -294
  878. data/gemfiles/ruby_2.6.4_rails6_postgres_sidekiq.gemfile +0 -44
  879. data/gemfiles/ruby_2.6.4_rails6_postgres_sidekiq.gemfile.lock +0 -300
  880. data/gemfiles/ruby_2.6.4_resque2_redis3.gemfile +0 -40
  881. data/gemfiles/ruby_2.6.4_resque2_redis3.gemfile.lock +0 -190
  882. data/gemfiles/ruby_2.6.4_resque2_redis4.gemfile +0 -40
  883. data/gemfiles/ruby_2.6.4_resque2_redis4.gemfile.lock +0 -190
  884. data/gemfiles/ruby_2.7.0_contrib.gemfile +0 -78
  885. data/gemfiles/ruby_2.7.0_contrib.gemfile.lock +0 -1523
  886. data/gemfiles/ruby_2.7.0_contrib_old.gemfile +0 -39
  887. data/gemfiles/ruby_2.7.0_contrib_old.gemfile.lock +0 -167
  888. data/gemfiles/ruby_2.7.0_core_old.gemfile +0 -38
  889. data/gemfiles/ruby_2.7.0_core_old.gemfile.lock +0 -163
  890. data/gemfiles/ruby_2.7.0_cucumber3.gemfile +0 -39
  891. data/gemfiles/ruby_2.7.0_cucumber3.gemfile.lock +0 -184
  892. data/gemfiles/ruby_2.7.0_cucumber4.gemfile +0 -39
  893. data/gemfiles/ruby_2.7.0_cucumber4.gemfile.lock +0 -216
  894. data/gemfiles/ruby_2.7.0_cucumber5.gemfile +0 -39
  895. data/gemfiles/ruby_2.7.0_cucumber5.gemfile.lock +0 -216
  896. data/gemfiles/ruby_2.7.0_rails5_mysql2.gemfile +0 -42
  897. data/gemfiles/ruby_2.7.0_rails5_mysql2.gemfile.lock +0 -276
  898. data/gemfiles/ruby_2.7.0_rails5_postgres.gemfile +0 -42
  899. data/gemfiles/ruby_2.7.0_rails5_postgres.gemfile.lock +0 -276
  900. data/gemfiles/ruby_2.7.0_rails5_postgres_redis.gemfile +0 -44
  901. data/gemfiles/ruby_2.7.0_rails5_postgres_redis.gemfile.lock +0 -295
  902. data/gemfiles/ruby_2.7.0_rails5_postgres_redis_activesupport.gemfile +0 -44
  903. data/gemfiles/ruby_2.7.0_rails5_postgres_redis_activesupport.gemfile.lock +0 -295
  904. data/gemfiles/ruby_2.7.0_rails5_postgres_sidekiq.gemfile +0 -44
  905. data/gemfiles/ruby_2.7.0_rails5_postgres_sidekiq.gemfile.lock +0 -284
  906. data/gemfiles/ruby_2.7.0_rails61_mysql2.gemfile +0 -42
  907. data/gemfiles/ruby_2.7.0_rails61_mysql2.gemfile.lock +0 -295
  908. data/gemfiles/ruby_2.7.0_rails61_postgres.gemfile +0 -42
  909. data/gemfiles/ruby_2.7.0_rails61_postgres.gemfile.lock +0 -295
  910. data/gemfiles/ruby_2.7.0_rails61_postgres_redis.gemfile +0 -43
  911. data/gemfiles/ruby_2.7.0_rails61_postgres_redis.gemfile.lock +0 -297
  912. data/gemfiles/ruby_2.7.0_rails61_postgres_sidekiq.gemfile +0 -43
  913. data/gemfiles/ruby_2.7.0_rails61_postgres_sidekiq.gemfile.lock +0 -302
  914. data/gemfiles/ruby_2.7.0_rails6_mysql2.gemfile +0 -42
  915. data/gemfiles/ruby_2.7.0_rails6_mysql2.gemfile.lock +0 -292
  916. data/gemfiles/ruby_2.7.0_rails6_postgres.gemfile +0 -42
  917. data/gemfiles/ruby_2.7.0_rails6_postgres.gemfile.lock +0 -292
  918. data/gemfiles/ruby_2.7.0_rails6_postgres_redis.gemfile +0 -44
  919. data/gemfiles/ruby_2.7.0_rails6_postgres_redis.gemfile.lock +0 -311
  920. data/gemfiles/ruby_2.7.0_rails6_postgres_redis_activesupport.gemfile +0 -44
  921. data/gemfiles/ruby_2.7.0_rails6_postgres_redis_activesupport.gemfile.lock +0 -311
  922. data/gemfiles/ruby_2.7.0_rails6_postgres_sidekiq.gemfile +0 -44
  923. data/gemfiles/ruby_2.7.0_rails6_postgres_sidekiq.gemfile.lock +0 -300
  924. data/gemfiles/ruby_2.7.0_resque2_redis3.gemfile +0 -40
  925. data/gemfiles/ruby_2.7.0_resque2_redis3.gemfile.lock +0 -190
  926. data/gemfiles/ruby_2.7.0_resque2_redis4.gemfile +0 -40
  927. data/gemfiles/ruby_2.7.0_resque2_redis4.gemfile.lock +0 -190
  928. data/gemfiles/ruby_3.0.0_contrib.gemfile +0 -78
  929. data/gemfiles/ruby_3.0.0_contrib.gemfile.lock +0 -1540
  930. data/gemfiles/ruby_3.0.0_core_old.gemfile +0 -39
  931. data/gemfiles/ruby_3.0.0_core_old.gemfile.lock +0 -165
  932. data/gemfiles/ruby_3.0.0_cucumber3.gemfile +0 -40
  933. data/gemfiles/ruby_3.0.0_cucumber3.gemfile.lock +0 -186
  934. data/gemfiles/ruby_3.0.0_cucumber4.gemfile +0 -40
  935. data/gemfiles/ruby_3.0.0_cucumber4.gemfile.lock +0 -218
  936. data/gemfiles/ruby_3.0.0_cucumber5.gemfile +0 -40
  937. data/gemfiles/ruby_3.0.0_cucumber5.gemfile.lock +0 -218
  938. data/gemfiles/ruby_3.0.0_rails61_mysql2.gemfile +0 -43
  939. data/gemfiles/ruby_3.0.0_rails61_mysql2.gemfile.lock +0 -295
  940. data/gemfiles/ruby_3.0.0_rails61_postgres.gemfile +0 -43
  941. data/gemfiles/ruby_3.0.0_rails61_postgres.gemfile.lock +0 -295
  942. data/gemfiles/ruby_3.0.0_rails61_postgres_redis.gemfile +0 -44
  943. data/gemfiles/ruby_3.0.0_rails61_postgres_redis.gemfile.lock +0 -297
  944. data/gemfiles/ruby_3.0.0_rails61_postgres_sidekiq.gemfile +0 -44
  945. data/gemfiles/ruby_3.0.0_rails61_postgres_sidekiq.gemfile.lock +0 -302
  946. data/gemfiles/ruby_3.0.0_resque2_redis3.gemfile +0 -41
  947. data/gemfiles/ruby_3.0.0_resque2_redis3.gemfile.lock +0 -192
  948. data/gemfiles/ruby_3.0.0_resque2_redis4.gemfile +0 -41
  949. data/gemfiles/ruby_3.0.0_resque2_redis4.gemfile.lock +0 -192
  950. data/integration/README.md +0 -67
  951. data/integration/apps/rack/.dockerignore +0 -1
  952. data/integration/apps/rack/.envrc.sample +0 -1
  953. data/integration/apps/rack/.gitignore +0 -4
  954. data/integration/apps/rack/.rspec +0 -1
  955. data/integration/apps/rack/Dockerfile +0 -28
  956. data/integration/apps/rack/Dockerfile-ci +0 -11
  957. data/integration/apps/rack/Gemfile +0 -24
  958. data/integration/apps/rack/README.md +0 -93
  959. data/integration/apps/rack/app/acme.rb +0 -80
  960. data/integration/apps/rack/app/datadog.rb +0 -17
  961. data/integration/apps/rack/bin/run +0 -22
  962. data/integration/apps/rack/bin/setup +0 -17
  963. data/integration/apps/rack/bin/test +0 -24
  964. data/integration/apps/rack/config/puma.rb +0 -14
  965. data/integration/apps/rack/config/unicorn.rb +0 -23
  966. data/integration/apps/rack/config.ru +0 -6
  967. data/integration/apps/rack/docker-compose.ci.yml +0 -62
  968. data/integration/apps/rack/docker-compose.yml +0 -78
  969. data/integration/apps/rack/script/build-images +0 -38
  970. data/integration/apps/rack/script/ci +0 -51
  971. data/integration/apps/rack/spec/integration/basic_spec.rb +0 -10
  972. data/integration/apps/rack/spec/spec_helper.rb +0 -16
  973. data/integration/apps/rack/spec/support/integration_helper.rb +0 -22
  974. data/integration/apps/rails-five/.dockerignore +0 -1
  975. data/integration/apps/rails-five/.env +0 -3
  976. data/integration/apps/rails-five/.envrc.sample +0 -1
  977. data/integration/apps/rails-five/.gitignore +0 -30
  978. data/integration/apps/rails-five/Dockerfile +0 -25
  979. data/integration/apps/rails-five/Dockerfile-ci +0 -11
  980. data/integration/apps/rails-five/Gemfile +0 -104
  981. data/integration/apps/rails-five/README.md +0 -94
  982. data/integration/apps/rails-five/Rakefile +0 -6
  983. data/integration/apps/rails-five/app/channels/application_cable/channel.rb +0 -4
  984. data/integration/apps/rails-five/app/channels/application_cable/connection.rb +0 -4
  985. data/integration/apps/rails-five/app/controllers/application_controller.rb +0 -2
  986. data/integration/apps/rails-five/app/controllers/basic_controller.rb +0 -36
  987. data/integration/apps/rails-five/app/controllers/concerns/.keep +0 -0
  988. data/integration/apps/rails-five/app/controllers/health_controller.rb +0 -9
  989. data/integration/apps/rails-five/app/controllers/jobs_controller.rb +0 -12
  990. data/integration/apps/rails-five/app/jobs/application_job.rb +0 -2
  991. data/integration/apps/rails-five/app/jobs/test_job.rb +0 -12
  992. data/integration/apps/rails-five/app/mailers/application_mailer.rb +0 -4
  993. data/integration/apps/rails-five/app/models/application_record.rb +0 -3
  994. data/integration/apps/rails-five/app/models/concerns/.keep +0 -0
  995. data/integration/apps/rails-five/app/models/test.rb +0 -2
  996. data/integration/apps/rails-five/app/views/layouts/mailer.html.erb +0 -13
  997. data/integration/apps/rails-five/app/views/layouts/mailer.text.erb +0 -1
  998. data/integration/apps/rails-five/bin/bundle +0 -3
  999. data/integration/apps/rails-five/bin/rails +0 -9
  1000. data/integration/apps/rails-five/bin/rake +0 -9
  1001. data/integration/apps/rails-five/bin/run +0 -24
  1002. data/integration/apps/rails-five/bin/setup +0 -27
  1003. data/integration/apps/rails-five/bin/spring +0 -17
  1004. data/integration/apps/rails-five/bin/test +0 -21
  1005. data/integration/apps/rails-five/bin/update +0 -28
  1006. data/integration/apps/rails-five/config/application.rb +0 -97
  1007. data/integration/apps/rails-five/config/boot.rb +0 -4
  1008. data/integration/apps/rails-five/config/cable.yml +0 -10
  1009. data/integration/apps/rails-five/config/credentials.yml.enc +0 -1
  1010. data/integration/apps/rails-five/config/database.yml +0 -28
  1011. data/integration/apps/rails-five/config/environment.rb +0 -5
  1012. data/integration/apps/rails-five/config/environments/development.rb +0 -51
  1013. data/integration/apps/rails-five/config/environments/production.rb +0 -82
  1014. data/integration/apps/rails-five/config/environments/test.rb +0 -43
  1015. data/integration/apps/rails-five/config/initializers/datadog.rb +0 -18
  1016. data/integration/apps/rails-five/config/initializers/filter_parameter_logging.rb +0 -4
  1017. data/integration/apps/rails-five/config/initializers/resque.rb +0 -4
  1018. data/integration/apps/rails-five/config/initializers/rollbar.rb +0 -5
  1019. data/integration/apps/rails-five/config/initializers/wrap_parameters.rb +0 -14
  1020. data/integration/apps/rails-five/config/locales/en.yml +0 -33
  1021. data/integration/apps/rails-five/config/puma.rb +0 -24
  1022. data/integration/apps/rails-five/config/routes.rb +0 -11
  1023. data/integration/apps/rails-five/config/spring.rb +0 -6
  1024. data/integration/apps/rails-five/config/unicorn.rb +0 -29
  1025. data/integration/apps/rails-five/config.ru +0 -5
  1026. data/integration/apps/rails-five/db/migrate/20190927215052_create_tests.rb +0 -11
  1027. data/integration/apps/rails-five/db/schema.rb +0 -23
  1028. data/integration/apps/rails-five/db/seeds.rb +0 -7
  1029. data/integration/apps/rails-five/docker-compose.ci.yml +0 -98
  1030. data/integration/apps/rails-five/docker-compose.yml +0 -100
  1031. data/integration/apps/rails-five/lib/tasks/.keep +0 -0
  1032. data/integration/apps/rails-five/log/.keep +0 -0
  1033. data/integration/apps/rails-five/public/robots.txt +0 -1
  1034. data/integration/apps/rails-five/script/build-images +0 -35
  1035. data/integration/apps/rails-five/script/ci +0 -51
  1036. data/integration/apps/rails-five/spec/integration/basic_spec.rb +0 -10
  1037. data/integration/apps/rails-five/spec/spec_helper.rb +0 -16
  1038. data/integration/apps/rails-five/spec/support/integration_helper.rb +0 -22
  1039. data/integration/apps/rails-five/storage/.keep +0 -0
  1040. data/integration/apps/rails-five/tmp/.keep +0 -0
  1041. data/integration/apps/rails-five/vendor/.keep +0 -0
  1042. data/integration/apps/rspec/.dockerignore +0 -1
  1043. data/integration/apps/rspec/.envrc.sample +0 -1
  1044. data/integration/apps/rspec/.gitignore +0 -2
  1045. data/integration/apps/rspec/.rspec +0 -1
  1046. data/integration/apps/rspec/Dockerfile +0 -25
  1047. data/integration/apps/rspec/Dockerfile-ci +0 -11
  1048. data/integration/apps/rspec/Gemfile +0 -14
  1049. data/integration/apps/rspec/README.md +0 -70
  1050. data/integration/apps/rspec/agent.yaml +0 -3
  1051. data/integration/apps/rspec/app/datadog.rb +0 -13
  1052. data/integration/apps/rspec/app/fibonacci.rb +0 -30
  1053. data/integration/apps/rspec/bin/run +0 -20
  1054. data/integration/apps/rspec/bin/setup +0 -17
  1055. data/integration/apps/rspec/bin/test +0 -21
  1056. data/integration/apps/rspec/docker-compose.ci.yml +0 -51
  1057. data/integration/apps/rspec/docker-compose.yml +0 -63
  1058. data/integration/apps/rspec/script/build-images +0 -37
  1059. data/integration/apps/rspec/script/ci +0 -53
  1060. data/integration/apps/rspec/spec/fibonacci_spec.rb +0 -16
  1061. data/integration/apps/rspec/spec/rspec_spec.rb +0 -58
  1062. data/integration/apps/rspec/spec/spec_helper.rb +0 -24
  1063. data/integration/apps/ruby/.dockerignore +0 -1
  1064. data/integration/apps/ruby/.envrc.sample +0 -1
  1065. data/integration/apps/ruby/.gitignore +0 -2
  1066. data/integration/apps/ruby/Dockerfile +0 -25
  1067. data/integration/apps/ruby/Dockerfile-ci +0 -11
  1068. data/integration/apps/ruby/Gemfile +0 -11
  1069. data/integration/apps/ruby/README.md +0 -70
  1070. data/integration/apps/ruby/agent.yaml +0 -3
  1071. data/integration/apps/ruby/app/datadog.rb +0 -13
  1072. data/integration/apps/ruby/app/fibonacci.rb +0 -58
  1073. data/integration/apps/ruby/bin/run +0 -20
  1074. data/integration/apps/ruby/bin/setup +0 -17
  1075. data/integration/apps/ruby/bin/test +0 -21
  1076. data/integration/apps/ruby/docker-compose.ci.yml +0 -51
  1077. data/integration/apps/ruby/docker-compose.yml +0 -63
  1078. data/integration/apps/ruby/script/build-images +0 -38
  1079. data/integration/apps/ruby/script/ci +0 -51
  1080. data/integration/images/agent/Dockerfile +0 -2
  1081. data/integration/images/agent/agent.yaml +0 -3
  1082. data/integration/images/include/datadog/analyzer.rb +0 -71
  1083. data/integration/images/include/datadog/demo_env.rb +0 -101
  1084. data/integration/images/include/http-health-check +0 -33
  1085. data/integration/images/ruby/2.1/Dockerfile +0 -54
  1086. data/integration/images/ruby/2.2/Dockerfile +0 -54
  1087. data/integration/images/ruby/2.3/Dockerfile +0 -70
  1088. data/integration/images/ruby/2.4/Dockerfile +0 -54
  1089. data/integration/images/ruby/2.5/Dockerfile +0 -54
  1090. data/integration/images/ruby/2.6/Dockerfile +0 -54
  1091. data/integration/images/ruby/2.7/Dockerfile +0 -54
  1092. data/integration/images/ruby/3.0/Dockerfile +0 -54
  1093. data/integration/images/wrk/Dockerfile +0 -33
  1094. data/integration/images/wrk/scripts/entrypoint.sh +0 -17
  1095. data/integration/images/wrk/scripts/scenarios/basic/default.lua +0 -1
  1096. data/integration/images/wrk/scripts/scenarios/basic/fibonacci.lua +0 -1
  1097. data/integration/script/build-images +0 -43
  1098. data/lib/ddtrace/environment.rb +0 -41
  1099. data/lib/ddtrace/runtime/cgroup.rb +0 -44
  1100. data/lib/ddtrace/runtime/class_count.rb +0 -17
  1101. data/lib/ddtrace/runtime/container.rb +0 -87
  1102. data/lib/ddtrace/runtime/gc.rb +0 -16
  1103. data/lib/ddtrace/runtime/identity.rb +0 -48
  1104. data/lib/ddtrace/runtime/object_space.rb +0 -19
  1105. data/lib/ddtrace/runtime/socket.rb +0 -14
  1106. data/lib/ddtrace/runtime/thread_count.rb +0 -16
  1107. data/tasks/release_gem.rake +0 -28
@@ -1,3 +1,4 @@
1
+ # typed: true
1
2
  require 'ddtrace/profiling/backtrace_location'
2
3
  require 'ddtrace/profiling/events/stack'
3
4
  require 'ddtrace/utils/only_once'
@@ -11,17 +12,23 @@ module Datadog
11
12
  # Collects stack trace samples from Ruby threads for both CPU-time (if available) and wall-clock.
12
13
  # Runs on its own background thread.
13
14
  #
14
- # rubocop:disable Metrics/ClassLength
15
- class Stack < Worker
15
+ class Stack < Worker # rubocop:disable Metrics/ClassLength
16
16
  include Workers::Polling
17
17
 
18
18
  DEFAULT_MAX_TIME_USAGE_PCT = 2.0
19
19
  MIN_INTERVAL = 0.01
20
20
  THREAD_LAST_CPU_TIME_KEY = :datadog_profiler_last_cpu_time
21
+ THREAD_LAST_WALL_CLOCK_KEY = :datadog_profiler_last_wall_clock
22
+
23
+ # This default was picked based on the current sampling performance and on expected concurrency on an average
24
+ # Ruby MRI application. Lowering this optimizes for latency (less impact each time we sample), and raising
25
+ # optimizes for coverage (less chance to miss what a given thread is doing).
26
+ DEFAULT_MAX_THREADS_SAMPLED = 16
21
27
 
22
28
  attr_reader \
23
29
  :recorder,
24
30
  :max_frames,
31
+ :trace_identifiers_helper,
25
32
  :ignore_thread,
26
33
  :max_time_usage_pct,
27
34
  :thread_api
@@ -29,8 +36,10 @@ module Datadog
29
36
  def initialize(
30
37
  recorder,
31
38
  max_frames:,
39
+ trace_identifiers_helper:, # Usually an instance of Datadog::Profiling::TraceIdentifiers::Helper
32
40
  ignore_thread: nil,
33
41
  max_time_usage_pct: DEFAULT_MAX_TIME_USAGE_PCT,
42
+ max_threads_sampled: DEFAULT_MAX_THREADS_SAMPLED,
34
43
  thread_api: Thread,
35
44
  fork_policy: Workers::Async::Thread::FORK_POLICY_RESTART, # Restart in forks by default
36
45
  interval: MIN_INTERVAL,
@@ -38,8 +47,10 @@ module Datadog
38
47
  )
39
48
  @recorder = recorder
40
49
  @max_frames = max_frames
50
+ @trace_identifiers_helper = trace_identifiers_helper
41
51
  @ignore_thread = ignore_thread
42
52
  @max_time_usage_pct = max_time_usage_pct
53
+ @max_threads_sampled = max_threads_sampled
43
54
  @thread_api = thread_api
44
55
 
45
56
  # Workers::Async::Thread settings
@@ -57,10 +68,13 @@ module Datadog
57
68
  @build_backtrace_location = method(:build_backtrace_location).to_proc
58
69
  # Cache this buffer, since it's pretty expensive to keep accessing it
59
70
  @stack_sample_event_recorder = recorder[Events::StackSample]
71
+ # See below for details on why this is needed
72
+ @needs_process_waiter_workaround =
73
+ Gem::Version.new(RUBY_VERSION) >= Gem::Version.new('2.3') &&
74
+ Gem::Version.new(RUBY_VERSION) < Gem::Version.new('2.7')
60
75
  end
61
76
 
62
77
  def start
63
- @last_wall_time = Datadog::Utils::Time.get_time
64
78
  reset_cpu_time_tracking
65
79
  perform
66
80
  end
@@ -84,24 +98,14 @@ module Datadog
84
98
 
85
99
  def collect_events
86
100
  events = []
87
-
88
- # Compute wall time interval
89
- current_wall_time = Datadog::Utils::Time.get_time
90
- last_wall_time = if instance_variable_defined?(:@last_wall_time)
91
- @last_wall_time
92
- else
93
- current_wall_time
94
- end
95
-
96
- wall_time_interval_ns = ((current_wall_time - last_wall_time).round(9) * 1e9).to_i
97
- @last_wall_time = current_wall_time
101
+ current_wall_time_ns = get_current_wall_time_timestamp_ns
98
102
 
99
103
  # Collect backtraces from each thread
100
- thread_api.list.each do |thread|
104
+ threads_to_sample.each do |thread|
101
105
  next unless thread.alive?
102
106
  next if ignore_thread.is_a?(Proc) && ignore_thread.call(thread)
103
107
 
104
- event = collect_thread_event(thread, wall_time_interval_ns)
108
+ event = collect_thread_event(thread, current_wall_time_ns)
105
109
  events << event unless event.nil?
106
110
  end
107
111
 
@@ -111,7 +115,7 @@ module Datadog
111
115
  events
112
116
  end
113
117
 
114
- def collect_thread_event(thread, wall_time_interval_ns)
118
+ def collect_thread_event(thread, current_wall_time_ns)
115
119
  locations = thread.backtrace_locations
116
120
  return if locations.nil?
117
121
 
@@ -123,8 +127,10 @@ module Datadog
123
127
  locations = convert_backtrace_locations(locations)
124
128
 
125
129
  thread_id = thread.respond_to?(:pthread_thread_id) ? thread.pthread_thread_id : thread.object_id
126
- trace_id, span_id = get_trace_identifiers(thread)
130
+ trace_id, span_id, trace_resource = trace_identifiers_helper.trace_identifiers_for(thread)
127
131
  cpu_time = get_cpu_time_interval!(thread)
132
+ wall_time_interval_ns =
133
+ get_elapsed_since_last_sample_and_set_value(thread, THREAD_LAST_WALL_CLOCK_KEY, current_wall_time_ns)
128
134
 
129
135
  Events::StackSample.new(
130
136
  nil,
@@ -133,6 +139,7 @@ module Datadog
133
139
  thread_id,
134
140
  trace_id,
135
141
  span_id,
142
+ trace_resource,
136
143
  cpu_time,
137
144
  wall_time_interval_ns
138
145
  )
@@ -152,22 +159,7 @@ module Datadog
152
159
  # *before* the thread had time to finish the initialization
153
160
  return unless current_cpu_time_ns
154
161
 
155
- last_cpu_time_ns = (thread[THREAD_LAST_CPU_TIME_KEY] || current_cpu_time_ns)
156
- interval = current_cpu_time_ns - last_cpu_time_ns
157
-
158
- # Update CPU time for thread
159
- thread[THREAD_LAST_CPU_TIME_KEY] = current_cpu_time_ns
160
-
161
- # Return interval
162
- interval
163
- end
164
-
165
- def get_trace_identifiers(thread)
166
- return unless thread.is_a?(::Thread)
167
- return unless Datadog.respond_to?(:tracer) && Datadog.tracer.respond_to?(:active_correlation)
168
-
169
- identifier = Datadog.tracer.active_correlation(thread)
170
- [identifier.trace_id, identifier.span_id]
162
+ get_elapsed_since_last_sample_and_set_value(thread, THREAD_LAST_CPU_TIME_KEY, current_cpu_time_ns)
171
163
  end
172
164
 
173
165
  def compute_wait_time(used_time)
@@ -241,10 +233,10 @@ module Datadog
241
233
  end
242
234
 
243
235
  # If the profiler is started for a while, stopped and then restarted OR whenever the process forks, we need to
244
- # clean up the per-thread cpu time counters we keep, so that the first sample after starting doesn't end up with:
236
+ # clean up any leftover per-thread counters, so that the first sample after starting doesn't end up with:
245
237
  #
246
238
  # a) negative time: At least on my test docker container, and on the reliability environment, after the process
247
- # forks, the clock reference changes and (old cpu time - new cpu time) can be < 0
239
+ # forks, the cpu time reference changes and (old cpu time - new cpu time) can be < 0
248
240
  #
249
241
  # b) large amount of time: if the profiler was started, then stopped for some amount of time, and then
250
242
  # restarted, we don't want the first sample to be "blamed" for multiple minutes of CPU time
@@ -252,11 +244,58 @@ module Datadog
252
244
  # By resetting the last cpu time seen, we start with a clean slate every time we start the stack collector.
253
245
  def reset_cpu_time_tracking
254
246
  thread_api.list.each do |thread|
255
- thread[THREAD_LAST_CPU_TIME_KEY] = nil if thread[THREAD_LAST_CPU_TIME_KEY]
247
+ # See below for details on why this is needed
248
+ next if @needs_process_waiter_workaround && thread.is_a?(::Process::Waiter)
249
+
250
+ thread.thread_variable_set(THREAD_LAST_CPU_TIME_KEY, nil)
251
+ thread.thread_variable_set(THREAD_LAST_WALL_CLOCK_KEY, nil)
256
252
  end
257
253
  end
254
+
255
+ def get_elapsed_since_last_sample_and_set_value(thread, key, current_value)
256
+ # See cthread.rb for more details, but this is a workaround for https://bugs.ruby-lang.org/issues/17807 ;
257
+ # using all thread_variable related methods on these instances also triggers a crash and for now we just
258
+ # skip it for the affected Rubies
259
+ return 0 if @needs_process_waiter_workaround && thread.is_a?(::Process::Waiter)
260
+
261
+ last_value = thread.thread_variable_get(key) || current_value
262
+ thread.thread_variable_set(key, current_value)
263
+
264
+ current_value - last_value
265
+ end
266
+
267
+ # Whenever there are more than max_threads_sampled active, we only sample a subset of them.
268
+ # We do this to avoid impacting the latency of the service being profiled. We want to avoid doing
269
+ # a big burst of work all at once (sample everything), and instead do a little work each time
270
+ # (sample a bit by bit).
271
+ #
272
+ # Because we pick the threads to sample randomly, we'll eventually sample all threads -- just not at once.
273
+ # Notice also that this will interact with our dynamic sampling mechanism -- if samples are faster, we take
274
+ # them more often, if they are slower, we take them less often -- which again means that over a longer period
275
+ # we should take sample roughly the same samples.
276
+ #
277
+ # One downside of this approach is that if there really are many threads, the resulting wall clock times
278
+ # in a one minute profile may "drift" around the 60 second mark, e.g. maybe we only sampled a thread once per
279
+ # second and only 59 times, so we'll report 59s, but on the next report we'll include the missing one, so
280
+ # then the result will be 61s. I've observed 60 +- 1.68 secs for an app with ~65 threads, given the
281
+ # default maximum of 16 threads. This seems a reasonable enough margin of error given the improvement to
282
+ # latency (especially on such a large application! -> even bigger latency impact if we tried to sample all
283
+ # threads).
284
+ #
285
+ def threads_to_sample
286
+ all_threads = thread_api.list
287
+
288
+ if all_threads.size > @max_threads_sampled
289
+ all_threads.sample(@max_threads_sampled)
290
+ else
291
+ all_threads
292
+ end
293
+ end
294
+
295
+ def get_current_wall_time_timestamp_ns
296
+ Datadog::Utils::Time.get_time(:nanosecond)
297
+ end
258
298
  end
259
- # rubocop:enable Metrics/ClassLength
260
299
  end
261
300
  end
262
301
  end
@@ -1,3 +1,4 @@
1
+ # typed: true
1
2
  require 'set'
2
3
  require 'time'
3
4
 
@@ -23,8 +24,16 @@ module Datadog
23
24
  flush.event_groups.each { |event_group| template.add_events!(event_group.event_class, event_group.events) }
24
25
 
25
26
  Datadog.logger.debug do
27
+ max_events = Datadog.configuration.profiling.advanced.max_events
28
+ events_sampled =
29
+ if flush.event_count == max_events
30
+ 'max events limit hit, events were sampled [profile will be biased], '
31
+ else
32
+ ''
33
+ end
34
+
26
35
  "Encoding profile covering #{flush.start.iso8601} to #{flush.finish.iso8601}, " \
27
- "events: #{flush.event_count} (#{template.debug_statistics})"
36
+ "events: #{flush.event_count} (#{events_sampled}#{template.debug_statistics})"
28
37
  end
29
38
 
30
39
  # Build the profile and encode it
@@ -1,3 +1,4 @@
1
+ # typed: true
1
2
  module Datadog
2
3
  module Profiling
3
4
  # Describes a sample of some data obtained from the runtime.
@@ -1,3 +1,4 @@
1
+ # typed: true
1
2
  require 'ddtrace/profiling/event'
2
3
 
3
4
  module Datadog
@@ -6,12 +7,13 @@ module Datadog
6
7
  # Describes a stack profiling event
7
8
  class Stack < Event
8
9
  attr_reader \
9
- :frames,
10
10
  :hash,
11
- :span_id,
12
- :thread_id,
11
+ :frames,
13
12
  :total_frame_count,
14
- :trace_id
13
+ :thread_id,
14
+ :trace_id,
15
+ :span_id,
16
+ :trace_resource
15
17
 
16
18
  def initialize(
17
19
  timestamp,
@@ -19,7 +21,8 @@ module Datadog
19
21
  total_frame_count,
20
22
  thread_id,
21
23
  trace_id,
22
- span_id
24
+ span_id,
25
+ trace_resource
23
26
  )
24
27
  super(timestamp)
25
28
 
@@ -28,15 +31,16 @@ module Datadog
28
31
  @thread_id = thread_id
29
32
  @trace_id = trace_id
30
33
  @span_id = span_id
34
+ @trace_resource = trace_resource
31
35
 
32
36
  @hash = [
33
37
  thread_id,
34
38
  trace_id,
35
39
  span_id,
36
- [
37
- frames.collect(&:hash),
38
- total_frame_count
39
- ]
40
+ # trace_resource is deliberately not included -- events that share the same (trace_id, span_id)
41
+ # trace_resource might not match between pairs, but they refer to the same trace.
42
+ frames.collect(&:hash),
43
+ total_frame_count
40
44
  ].hash
41
45
  end
42
46
  end
@@ -54,6 +58,7 @@ module Datadog
54
58
  thread_id,
55
59
  trace_id,
56
60
  span_id,
61
+ trace_resource,
57
62
  cpu_time_interval_ns,
58
63
  wall_time_interval_ns
59
64
  )
@@ -63,40 +68,14 @@ module Datadog
63
68
  total_frame_count,
64
69
  thread_id,
65
70
  trace_id,
66
- span_id
71
+ span_id,
72
+ trace_resource
67
73
  )
68
74
 
69
75
  @cpu_time_interval_ns = cpu_time_interval_ns
70
76
  @wall_time_interval_ns = wall_time_interval_ns
71
77
  end
72
78
  end
73
-
74
- # Describes a stack sample with exception
75
- class StackExceptionSample < Stack
76
- attr_reader \
77
- :exception
78
-
79
- def initialize(
80
- timestamp,
81
- frames,
82
- total_frame_count,
83
- thread_id,
84
- trace_id,
85
- span_id,
86
- exception
87
- )
88
- super(
89
- timestamp,
90
- frames,
91
- total_frame_count,
92
- thread_id,
93
- trace_id,
94
- span_id
95
- )
96
-
97
- @exception = exception
98
- end
99
- end
100
79
  end
101
80
  end
102
81
  end
@@ -1,3 +1,4 @@
1
+ # typed: true
1
2
  require 'ddtrace/profiling/transport/io/client'
2
3
 
3
4
  module Datadog
@@ -1,3 +1,4 @@
1
+ # typed: true
1
2
  module Datadog
2
3
  module Profiling
3
4
  module Ext
@@ -43,9 +44,23 @@ module Datadog
43
44
  elsif Gem::Specification.find_all_by_name('rollbar', ROLLBAR_INCOMPATIBLE_VERSIONS).any?
44
45
  'You have an incompatible rollbar gem version installed; ensure that you have rollbar >= 3.1.2 by ' \
45
46
  "adding `gem 'rollbar', '>= 3.1.2'` to your Gemfile or gems.rb file. " \
46
- 'See https://github.com/rollbar/rollbar-gem/pull/1018 for details.'
47
+ 'See https://github.com/rollbar/rollbar-gem/pull/1018 for details'
48
+ elsif Gem::Specification.find_all_by_name('logging').any? && logging_inherit_context_enabled?
49
+ 'The `logging` gem is installed and its thread inherit context feature is enabled. ' \
50
+ "Please add LOGGING_INHERIT_CONTEXT=false to your application's environment variables to disable the " \
51
+ 'conflicting `logging` gem feature. ' \
52
+ 'See https://github.com/TwP/logging/pull/230 for details'
47
53
  end
48
54
  end
55
+
56
+ private_class_method def self.logging_inherit_context_enabled?
57
+ # The logging gem provides a mechanism to disable the conflicting behavior, see
58
+ # https://github.com/TwP/logging/blob/ae9872d093833b2a5a34cbe1faa4e895a81f6845/lib/logging/diagnostic_context.rb#L418
59
+ # Here we check if the behavior is enabled
60
+ inherit_context_configuration = ENV['LOGGING_INHERIT_CONTEXT']
61
+
62
+ inherit_context_configuration.nil? || !%w[false no 0].include?(inherit_context_configuration.downcase)
63
+ end
49
64
  end
50
65
  end
51
66
  end
@@ -1,3 +1,4 @@
1
+ # typed: false
1
2
  require 'ffi'
2
3
 
3
4
  module Datadog
@@ -1,3 +1,4 @@
1
+ # typed: false
1
2
  module Datadog
2
3
  module Profiling
3
4
  module Ext
@@ -1,5 +1,6 @@
1
- require 'ddtrace/runtime/identity'
2
- require 'ddtrace/runtime/socket'
1
+ # typed: false
2
+ require 'datadog/core/environment/identity'
3
+ require 'datadog/core/environment/socket'
3
4
 
4
5
  module Datadog
5
6
  module Profiling
@@ -23,16 +24,16 @@ module Datadog
23
24
  ) do
24
25
  def initialize(*args)
25
26
  super
26
- self.runtime_id = runtime_id || Datadog::Runtime::Identity.id
27
+ self.runtime_id = runtime_id || Datadog::Core::Environment::Identity.id
27
28
  self.service = service || Datadog.configuration.service
28
29
  self.env = env || Datadog.configuration.env
29
30
  self.version = version || Datadog.configuration.version
30
- self.host = host || Datadog::Runtime::Socket.hostname
31
- self.language = language || Datadog::Runtime::Identity.lang
32
- self.runtime_engine = runtime_engine || Datadog::Runtime::Identity.lang_engine
33
- self.runtime_platform = runtime_platform || Datadog::Runtime::Identity.lang_platform
34
- self.runtime_version = runtime_version || Datadog::Runtime::Identity.lang_version
35
- self.profiler_version = profiler_version || Datadog::Runtime::Identity.tracer_version
31
+ self.host = host || Datadog::Core::Environment::Socket.hostname
32
+ self.language = language || Datadog::Core::Environment::Identity.lang
33
+ self.runtime_engine = runtime_engine || Datadog::Core::Environment::Identity.lang_engine
34
+ self.runtime_platform = runtime_platform || Datadog::Core::Environment::Identity.lang_platform
35
+ self.runtime_version = runtime_version || Datadog::Core::Environment::Identity.lang_version
36
+ self.profiler_version = profiler_version || Datadog::Core::Environment::Identity.tracer_version
36
37
  self.tags = tags || Datadog.configuration.tags
37
38
  end
38
39
  end
@@ -0,0 +1,18 @@
1
+ # typed: true
2
+ module Datadog
3
+ module Profiling
4
+ # This module contains classes and methods which are implemented using native code in the
5
+ # ext/ddtrace_profiling_native_extension folder
6
+ module NativeExtension
7
+ private_class_method def self.working?
8
+ native_working?
9
+ end
10
+
11
+ unless singleton_class.private_method_defined?(:native_working?)
12
+ private_class_method def self.native_working?
13
+ false
14
+ end
15
+ end
16
+ end
17
+ end
18
+ end
@@ -1,3 +1,4 @@
1
+ # typed: true
1
2
  # frozen_string_literal: true
2
3
 
3
4
  require 'ddtrace/profiling/flush'
@@ -1,3 +1,4 @@
1
+ # typed: true
1
2
  require 'ddtrace/ext/profiling'
2
3
 
3
4
  module Datadog
@@ -24,20 +25,19 @@ module Datadog
24
25
  # [key, EventGroup]
25
26
  event_groups = {}
26
27
 
28
+ # Aggregate each event into a group
29
+ # with identical properties, but different values.
27
30
  events.each do |event|
28
31
  key = yield(event)
29
- values = build_sample_values(event)
32
+ values = build_event_values(event)
30
33
 
31
34
  unless key.nil?
32
35
  if event_groups.key?(key)
33
- # Update values for group
34
- group_values = event_groups[key].values
35
- group_values.each_with_index do |group_value, i|
36
- group_values[i] = group_value + values[i]
37
- end
36
+ # Update existing group from event
37
+ update_group(event_groups[key], event, values)
38
38
  else
39
39
  # Add new group
40
- event_groups[key] = EventGroup.new(event, values)
40
+ event_groups[key] = new_group(event, values)
41
41
  end
42
42
  end
43
43
  end
@@ -56,7 +56,7 @@ module Datadog
56
56
  index
57
57
  end
58
58
 
59
- def build_sample_values(stack_sample)
59
+ def build_event_values(event)
60
60
  # Build a value array that matches the length of the sample types
61
61
  # Populate all values with "no value" by default
62
62
  Array.new(@sample_type_mappings.length, Datadog::Ext::Profiling::Pprof::SAMPLE_VALUE_NO_VALUE)
@@ -68,7 +68,7 @@ module Datadog
68
68
 
69
69
  # Represents a grouped event
70
70
  # 'sample' is an example event object from the group.
71
- # 'values' is the the summation of the group's sample values
71
+ # 'values' is the summation of the group's sample values
72
72
  EventGroup = Struct.new(:sample, :values)
73
73
 
74
74
  # Error when the mapping of a sample type to value index is unknown
@@ -83,6 +83,20 @@ module Datadog
83
83
  "Mapping for sample value type '#{type}' to index is unknown."
84
84
  end
85
85
  end
86
+
87
+ protected
88
+
89
+ def new_group(event, values)
90
+ EventGroup.new(event, values)
91
+ end
92
+
93
+ def update_group(event_group, event, values)
94
+ # Update values for group
95
+ group_values = event_group.values
96
+ group_values.each_with_index do |group_value, i|
97
+ group_values[i] = group_value + values[i]
98
+ end
99
+ end
86
100
  end
87
101
  end
88
102
  end
@@ -1,3 +1,4 @@
1
+ # typed: true
1
2
  require 'ddtrace/utils/object_set'
2
3
 
3
4
  module Datadog
@@ -5,7 +6,9 @@ module Datadog
5
6
  module Pprof
6
7
  # Acts as a unique dictionary of protobuf messages
7
8
  class MessageSet < Utils::ObjectSet
8
- alias_method :messages, :objects
9
+ def messages
10
+ objects
11
+ end
9
12
  end
10
13
  end
11
14
  end
@@ -1,10 +1,11 @@
1
+ # typed: true
1
2
  module Datadog
2
3
  module Profiling
3
4
  module Pprof
4
5
  # Pprof output data.
5
6
  # Includes encoded data and list of types.
6
7
  Payload = Struct.new(:data, :types) do
7
- def initialize(*args)
8
+ def initialize(data, types)
8
9
  super
9
10
  self.types = types || []
10
11
  end
@@ -1,3 +1,4 @@
1
+ # typed: false
1
2
  # Generated by the protocol buffer compiler. DO NOT EDIT!
2
3
  # source: lib/ddtrace/profiling/pprof/pprof.proto
3
4
 
@@ -1,3 +1,4 @@
1
+ # typed: true
1
2
  require 'ddtrace/ext/profiling'
2
3
  require 'ddtrace/profiling/events/stack'
3
4
  require 'ddtrace/profiling/pprof/builder'
@@ -29,6 +30,7 @@ module Datadog
29
30
  def initialize(*_)
30
31
  super
31
32
 
33
+ @most_recent_trace_samples = {}
32
34
  @processed_unique_stacks = 0
33
35
  @processed_with_trace_ids = 0
34
36
  end
@@ -39,9 +41,28 @@ module Datadog
39
41
  end
40
42
 
41
43
  def stack_sample_group_key(stack_sample)
44
+ # We want to make sure we have the most recent sample for any trace.
45
+ # (This is done here to save an iteration over all samples.)
46
+ update_most_recent_trace_sample(stack_sample)
47
+
42
48
  stack_sample.hash
43
49
  end
44
50
 
51
+ # Track the most recent sample for each trace
52
+ def update_most_recent_trace_sample(stack_sample)
53
+ return unless stack_sample.trace_id && stack_sample.trace_resource
54
+
55
+ # Update trace resource with most recent value
56
+ if (most_recent_trace_sample = @most_recent_trace_samples[stack_sample.trace_id])
57
+ if most_recent_trace_sample.timestamp < stack_sample.timestamp
58
+ @most_recent_trace_samples[stack_sample.trace_id] = stack_sample
59
+ end
60
+ else
61
+ # Add trace resource
62
+ @most_recent_trace_samples[stack_sample.trace_id] = stack_sample
63
+ end
64
+ end
65
+
45
66
  def build_samples(stack_samples)
46
67
  groups = group_events(stack_samples, &method(:stack_sample_group_key))
47
68
  groups.collect do |_group_key, group|
@@ -63,7 +84,7 @@ module Datadog
63
84
  )
64
85
  end
65
86
 
66
- def build_sample_values(stack_sample)
87
+ def build_event_values(stack_sample)
67
88
  no_value = Datadog::Ext::Profiling::Pprof::SAMPLE_VALUE_NO_VALUE
68
89
  values = super(stack_sample)
69
90
  values[sample_value_index(:cpu_time_ns)] = stack_sample.cpu_time_interval_ns || no_value
@@ -79,19 +100,35 @@ module Datadog
79
100
  )
80
101
  ]
81
102
 
82
- unless stack_sample.trace_id.nil? || stack_sample.trace_id.zero?
103
+ trace_id = stack_sample.trace_id || 0
104
+ span_id = stack_sample.span_id || 0
105
+
106
+ if trace_id != 0 && span_id != 0
83
107
  @processed_with_trace_ids += 1
108
+
84
109
  labels << Perftools::Profiles::Label.new(
85
110
  key: builder.string_table.fetch(Datadog::Ext::Profiling::Pprof::LABEL_KEY_TRACE_ID),
86
- str: builder.string_table.fetch(stack_sample.trace_id.to_s)
111
+ str: builder.string_table.fetch(trace_id.to_s)
87
112
  )
88
- end
89
113
 
90
- unless stack_sample.span_id.nil? || stack_sample.span_id.zero?
91
114
  labels << Perftools::Profiles::Label.new(
92
115
  key: builder.string_table.fetch(Datadog::Ext::Profiling::Pprof::LABEL_KEY_SPAN_ID),
93
- str: builder.string_table.fetch(stack_sample.span_id.to_s)
116
+ str: builder.string_table.fetch(span_id.to_s)
94
117
  )
118
+
119
+ # Use most up-to-date trace resource, if available.
120
+ # Otherwise, use the trace resource provided.
121
+ trace_resource = (
122
+ @most_recent_trace_samples[stack_sample.trace_id] \
123
+ || stack_sample
124
+ ).trace_resource
125
+
126
+ if trace_resource && !trace_resource.empty?
127
+ labels << Perftools::Profiles::Label.new(
128
+ key: builder.string_table.fetch(Datadog::Ext::Profiling::Pprof::LABEL_KEY_TRACE_ENDPOINT),
129
+ str: builder.string_table.fetch(trace_resource)
130
+ )
131
+ end
95
132
  end
96
133
 
97
134
  labels
@@ -1,3 +1,4 @@
1
+ # typed: strict
1
2
  require 'ddtrace/utils/string_table'
2
3
 
3
4
  module Datadog
@@ -1,3 +1,4 @@
1
+ # typed: false
1
2
  require 'ddtrace/profiling/pprof/payload'
2
3
  require 'ddtrace/profiling/pprof/message_set'
3
4
  require 'ddtrace/profiling/pprof/builder'
@@ -1,3 +1,4 @@
1
+ # typed: strict
1
2
  require 'ddtrace'
2
3
 
3
4
  Datadog.profiler.start if Datadog.profiler