ddtrace 0.45.0 → 0.47.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 (302) hide show
  1. checksums.yaml +5 -5
  2. data/.circleci/config.yml +131 -12
  3. data/.circleci/images/primary/{Dockerfile-jruby-9.2 → Dockerfile-jruby-9.2-latest} +2 -1
  4. data/.circleci/images/primary/Dockerfile-jruby-9.2.0.0 +73 -0
  5. data/.circleci/images/primary/Dockerfile-truffleruby-21.0.0 +73 -0
  6. data/.github/workflows/create-next-milestone.yml +2 -2
  7. data/.rubocop.yml +250 -7
  8. data/.rubocop_todo.yml +397 -0
  9. data/.simplecov +6 -0
  10. data/Appraisals +16 -1
  11. data/CHANGELOG.md +150 -1
  12. data/Gemfile +53 -3
  13. data/LICENSE-3rdparty.csv +2 -0
  14. data/Rakefile +5 -23
  15. data/ddtrace.gemspec +6 -36
  16. data/docker-compose.yml +75 -7
  17. data/docs/DevelopmentGuide.md +28 -0
  18. data/docs/GettingStarted.md +69 -17
  19. data/integration/README.md +68 -0
  20. data/integration/apps/rack/.dockerignore +1 -0
  21. data/integration/apps/rack/.envrc.sample +1 -0
  22. data/integration/apps/rack/.gitignore +4 -0
  23. data/integration/apps/rack/.rspec +1 -0
  24. data/integration/apps/rack/Dockerfile +25 -0
  25. data/integration/apps/rack/Dockerfile-ci +11 -0
  26. data/integration/apps/rack/Gemfile +24 -0
  27. data/integration/apps/rack/README.md +93 -0
  28. data/integration/apps/rack/app/acme.rb +80 -0
  29. data/integration/apps/rack/app/datadog.rb +17 -0
  30. data/integration/apps/rack/bin/run +22 -0
  31. data/integration/apps/rack/bin/setup +17 -0
  32. data/integration/apps/rack/bin/test +24 -0
  33. data/integration/apps/rack/config.ru +6 -0
  34. data/integration/apps/rack/config/puma.rb +14 -0
  35. data/integration/apps/rack/config/unicorn.rb +23 -0
  36. data/integration/apps/rack/docker-compose.ci.yml +62 -0
  37. data/integration/apps/rack/docker-compose.yml +78 -0
  38. data/integration/apps/rack/script/build-images +38 -0
  39. data/integration/apps/rack/script/ci +50 -0
  40. data/integration/apps/rack/spec/integration/basic_spec.rb +10 -0
  41. data/integration/apps/rack/spec/spec_helper.rb +16 -0
  42. data/integration/apps/rack/spec/support/integration_helper.rb +22 -0
  43. data/integration/apps/rails-five/.dockerignore +1 -0
  44. data/integration/apps/rails-five/.env +3 -0
  45. data/integration/apps/rails-five/.envrc.sample +1 -0
  46. data/integration/apps/rails-five/.gitignore +30 -0
  47. data/integration/apps/rails-five/Dockerfile +25 -0
  48. data/integration/apps/rails-five/Dockerfile-ci +11 -0
  49. data/integration/apps/rails-five/Gemfile +104 -0
  50. data/integration/apps/rails-five/README.md +94 -0
  51. data/integration/apps/rails-five/Rakefile +6 -0
  52. data/integration/apps/rails-five/app/channels/application_cable/channel.rb +4 -0
  53. data/integration/apps/rails-five/app/channels/application_cable/connection.rb +4 -0
  54. data/integration/apps/rails-five/app/controllers/application_controller.rb +2 -0
  55. data/integration/apps/rails-five/app/controllers/basic_controller.rb +36 -0
  56. data/integration/apps/rails-five/app/controllers/concerns/.keep +0 -0
  57. data/integration/apps/rails-five/app/controllers/health_controller.rb +9 -0
  58. data/integration/apps/rails-five/app/controllers/jobs_controller.rb +12 -0
  59. data/integration/apps/rails-five/app/jobs/application_job.rb +2 -0
  60. data/integration/apps/rails-five/app/jobs/test_job.rb +12 -0
  61. data/integration/apps/rails-five/app/mailers/application_mailer.rb +4 -0
  62. data/integration/apps/rails-five/app/models/application_record.rb +3 -0
  63. data/integration/apps/rails-five/app/models/concerns/.keep +0 -0
  64. data/integration/apps/rails-five/app/models/test.rb +2 -0
  65. data/integration/apps/rails-five/app/views/layouts/mailer.html.erb +13 -0
  66. data/integration/apps/rails-five/app/views/layouts/mailer.text.erb +1 -0
  67. data/integration/apps/rails-five/bin/bundle +3 -0
  68. data/integration/apps/rails-five/bin/rails +9 -0
  69. data/integration/apps/rails-five/bin/rake +9 -0
  70. data/integration/apps/rails-five/bin/run +24 -0
  71. data/integration/apps/rails-five/bin/setup +27 -0
  72. data/integration/apps/rails-five/bin/spring +17 -0
  73. data/integration/apps/rails-five/bin/test +21 -0
  74. data/integration/apps/rails-five/bin/update +28 -0
  75. data/integration/apps/rails-five/config.ru +5 -0
  76. data/integration/apps/rails-five/config/application.rb +97 -0
  77. data/integration/apps/rails-five/config/boot.rb +4 -0
  78. data/integration/apps/rails-five/config/cable.yml +10 -0
  79. data/integration/apps/rails-five/config/credentials.yml.enc +1 -0
  80. data/integration/apps/rails-five/config/database.yml +28 -0
  81. data/integration/apps/rails-five/config/environment.rb +5 -0
  82. data/integration/apps/rails-five/config/environments/development.rb +51 -0
  83. data/integration/apps/rails-five/config/environments/production.rb +82 -0
  84. data/integration/apps/rails-five/config/environments/test.rb +43 -0
  85. data/integration/apps/rails-five/config/initializers/datadog.rb +18 -0
  86. data/integration/apps/rails-five/config/initializers/filter_parameter_logging.rb +4 -0
  87. data/integration/apps/rails-five/config/initializers/resque.rb +4 -0
  88. data/integration/apps/rails-five/config/initializers/rollbar.rb +5 -0
  89. data/integration/apps/rails-five/config/initializers/wrap_parameters.rb +14 -0
  90. data/integration/apps/rails-five/config/locales/en.yml +33 -0
  91. data/integration/apps/rails-five/config/puma.rb +24 -0
  92. data/integration/apps/rails-five/config/routes.rb +11 -0
  93. data/integration/apps/rails-five/config/spring.rb +6 -0
  94. data/integration/apps/rails-five/config/unicorn.rb +29 -0
  95. data/integration/apps/rails-five/db/migrate/20190927215052_create_tests.rb +11 -0
  96. data/integration/apps/rails-five/db/schema.rb +23 -0
  97. data/integration/apps/rails-five/db/seeds.rb +7 -0
  98. data/integration/apps/rails-five/docker-compose.ci.yml +98 -0
  99. data/integration/apps/rails-five/docker-compose.yml +100 -0
  100. data/integration/apps/rails-five/lib/tasks/.keep +0 -0
  101. data/integration/apps/rails-five/log/.keep +0 -0
  102. data/integration/apps/rails-five/public/robots.txt +1 -0
  103. data/integration/apps/rails-five/script/build-images +35 -0
  104. data/integration/apps/rails-five/script/ci +50 -0
  105. data/integration/apps/rails-five/spec/integration/basic_spec.rb +10 -0
  106. data/integration/apps/rails-five/spec/spec_helper.rb +16 -0
  107. data/integration/apps/rails-five/spec/support/integration_helper.rb +22 -0
  108. data/integration/apps/rails-five/storage/.keep +0 -0
  109. data/integration/apps/rails-five/tmp/.keep +0 -0
  110. data/integration/apps/rails-five/vendor/.keep +0 -0
  111. data/integration/apps/ruby/.dockerignore +1 -0
  112. data/integration/apps/ruby/.envrc.sample +1 -0
  113. data/integration/apps/ruby/.gitignore +2 -0
  114. data/integration/apps/ruby/Dockerfile +25 -0
  115. data/integration/apps/ruby/Dockerfile-ci +11 -0
  116. data/integration/apps/ruby/Gemfile +11 -0
  117. data/integration/apps/ruby/README.md +70 -0
  118. data/integration/apps/ruby/agent.yaml +3 -0
  119. data/integration/apps/ruby/app/datadog.rb +13 -0
  120. data/integration/apps/ruby/app/fibonacci.rb +58 -0
  121. data/integration/apps/ruby/bin/run +20 -0
  122. data/integration/apps/ruby/bin/setup +17 -0
  123. data/integration/apps/ruby/bin/test +21 -0
  124. data/integration/apps/ruby/docker-compose.ci.yml +51 -0
  125. data/integration/apps/ruby/docker-compose.yml +63 -0
  126. data/integration/apps/ruby/script/build-images +38 -0
  127. data/integration/apps/ruby/script/ci +50 -0
  128. data/integration/images/agent/Dockerfile +2 -0
  129. data/integration/images/agent/agent.yaml +3 -0
  130. data/integration/images/include/datadog/analyzer.rb +71 -0
  131. data/integration/images/include/datadog/demo_env.rb +101 -0
  132. data/integration/images/include/http-health-check +33 -0
  133. data/integration/images/ruby/2.0/Dockerfile +54 -0
  134. data/integration/images/ruby/2.1/Dockerfile +54 -0
  135. data/integration/images/ruby/2.2/Dockerfile +54 -0
  136. data/integration/images/ruby/2.3/Dockerfile +70 -0
  137. data/integration/images/ruby/2.4/Dockerfile +54 -0
  138. data/integration/images/ruby/2.5/Dockerfile +54 -0
  139. data/integration/images/ruby/2.6/Dockerfile +54 -0
  140. data/integration/images/ruby/2.7/Dockerfile +54 -0
  141. data/integration/images/ruby/3.0/Dockerfile +54 -0
  142. data/integration/images/wrk/Dockerfile +33 -0
  143. data/integration/images/wrk/scripts/entrypoint.sh +17 -0
  144. data/integration/images/wrk/scripts/scenarios/basic/default.lua +1 -0
  145. data/integration/images/wrk/scripts/scenarios/basic/fibonacci.lua +1 -0
  146. data/integration/script/build-images +43 -0
  147. data/lib/ddtrace.rb +0 -5
  148. data/lib/ddtrace/analytics.rb +2 -0
  149. data/lib/ddtrace/buffer.rb +4 -4
  150. data/lib/ddtrace/configuration.rb +92 -23
  151. data/lib/ddtrace/configuration/base.rb +1 -1
  152. data/lib/ddtrace/configuration/components.rb +2 -2
  153. data/lib/ddtrace/configuration/option_definition.rb +1 -3
  154. data/lib/ddtrace/configuration/options.rb +4 -7
  155. data/lib/ddtrace/configuration/settings.rb +17 -3
  156. data/lib/ddtrace/context.rb +5 -6
  157. data/lib/ddtrace/context_provider.rb +0 -1
  158. data/lib/ddtrace/contrib/action_cable/event.rb +1 -0
  159. data/lib/ddtrace/contrib/action_pack/action_controller/instrumentation.rb +1 -3
  160. data/lib/ddtrace/contrib/action_view/event.rb +1 -1
  161. data/lib/ddtrace/contrib/action_view/utils.rb +1 -1
  162. data/lib/ddtrace/contrib/active_record/configuration/resolver.rb +101 -18
  163. data/lib/ddtrace/contrib/active_record/utils.rb +1 -0
  164. data/lib/ddtrace/contrib/active_support/notifications/event.rb +2 -1
  165. data/lib/ddtrace/contrib/active_support/notifications/subscriber.rb +1 -0
  166. data/lib/ddtrace/contrib/active_support/notifications/subscription.rb +9 -5
  167. data/lib/ddtrace/contrib/auto_instrument.rb +1 -0
  168. data/lib/ddtrace/contrib/aws/patcher.rb +1 -0
  169. data/lib/ddtrace/contrib/aws/services.rb +2 -0
  170. data/lib/ddtrace/contrib/configurable.rb +63 -39
  171. data/lib/ddtrace/contrib/configuration/resolver.rb +70 -5
  172. data/lib/ddtrace/contrib/configuration/resolvers/pattern_resolver.rb +19 -20
  173. data/lib/ddtrace/contrib/configuration/settings.rb +7 -6
  174. data/lib/ddtrace/contrib/cucumber/configuration/settings.rb +0 -10
  175. data/lib/ddtrace/contrib/cucumber/ext.rb +0 -2
  176. data/lib/ddtrace/contrib/cucumber/formatter.rb +5 -11
  177. data/lib/ddtrace/contrib/dalli/patcher.rb +0 -38
  178. data/lib/ddtrace/contrib/delayed_job/plugin.rb +0 -1
  179. data/lib/ddtrace/contrib/elasticsearch/patcher.rb +1 -0
  180. data/lib/ddtrace/contrib/elasticsearch/quantize.rb +3 -2
  181. data/lib/ddtrace/contrib/ethon/easy_patch.rb +5 -5
  182. data/lib/ddtrace/contrib/excon/middleware.rb +2 -6
  183. data/lib/ddtrace/contrib/extensions.rb +27 -3
  184. data/lib/ddtrace/contrib/faraday/middleware.rb +1 -3
  185. data/lib/ddtrace/contrib/faraday/patcher.rb +0 -36
  186. data/lib/ddtrace/contrib/grape/endpoint.rb +8 -15
  187. data/lib/ddtrace/contrib/grape/patcher.rb +0 -42
  188. data/lib/ddtrace/contrib/grpc/datadog_interceptor.rb +8 -8
  189. data/lib/ddtrace/contrib/grpc/datadog_interceptor/server.rb +1 -0
  190. data/lib/ddtrace/contrib/grpc/patcher.rb +0 -36
  191. data/lib/ddtrace/contrib/http/circuit_breaker.rb +1 -3
  192. data/lib/ddtrace/contrib/http/instrumentation.rb +5 -5
  193. data/lib/ddtrace/contrib/httpclient/instrumentation.rb +14 -19
  194. data/lib/ddtrace/contrib/httpclient/patcher.rb +5 -2
  195. data/lib/ddtrace/contrib/httprb/instrumentation.rb +14 -20
  196. data/lib/ddtrace/contrib/httprb/patcher.rb +5 -2
  197. data/lib/ddtrace/contrib/mongodb/instrumentation.rb +2 -0
  198. data/lib/ddtrace/contrib/mongodb/subscribers.rb +2 -3
  199. data/lib/ddtrace/contrib/patcher.rb +9 -6
  200. data/lib/ddtrace/contrib/presto/patcher.rb +5 -2
  201. data/lib/ddtrace/contrib/qless/qless_job.rb +1 -0
  202. data/lib/ddtrace/contrib/qless/tracer_cleaner.rb +1 -0
  203. data/lib/ddtrace/contrib/que/ext.rb +19 -19
  204. data/lib/ddtrace/contrib/que/tracer.rb +1 -1
  205. data/lib/ddtrace/contrib/racecar/event.rb +1 -0
  206. data/lib/ddtrace/contrib/rack/configuration/settings.rb +3 -3
  207. data/lib/ddtrace/contrib/rack/middlewares.rb +5 -10
  208. data/lib/ddtrace/contrib/rack/patcher.rb +1 -3
  209. data/lib/ddtrace/contrib/rails/patcher.rb +6 -2
  210. data/lib/ddtrace/contrib/rake/instrumentation.rb +4 -2
  211. data/lib/ddtrace/contrib/redis/configuration/resolver.rb +11 -4
  212. data/lib/ddtrace/contrib/redis/quantize.rb +1 -0
  213. data/lib/ddtrace/contrib/redis/vendor/LICENSE +20 -0
  214. data/lib/ddtrace/contrib/redis/vendor/resolver.rb +6 -7
  215. data/lib/ddtrace/contrib/registry.rb +2 -2
  216. data/lib/ddtrace/contrib/resque/integration.rb +1 -1
  217. data/lib/ddtrace/contrib/resque/resque_job.rb +2 -0
  218. data/lib/ddtrace/contrib/rest_client/request_patch.rb +1 -3
  219. data/lib/ddtrace/contrib/rspec/configuration/settings.rb +0 -10
  220. data/lib/ddtrace/contrib/rspec/example.rb +24 -10
  221. data/lib/ddtrace/contrib/rspec/ext.rb +0 -3
  222. data/lib/ddtrace/contrib/rspec/integration.rb +1 -1
  223. data/lib/ddtrace/contrib/rspec/patcher.rb +0 -2
  224. data/lib/ddtrace/contrib/sequel/utils.rb +5 -6
  225. data/lib/ddtrace/contrib/shoryuken/tracer.rb +0 -1
  226. data/lib/ddtrace/contrib/sidekiq/server_tracer.rb +2 -7
  227. data/lib/ddtrace/contrib/sidekiq/tracing.rb +0 -1
  228. data/lib/ddtrace/contrib/sinatra/env.rb +1 -3
  229. data/lib/ddtrace/contrib/sinatra/headers.rb +1 -3
  230. data/lib/ddtrace/contrib/sinatra/tracer.rb +1 -3
  231. data/lib/ddtrace/contrib/sinatra/tracer_middleware.rb +3 -3
  232. data/lib/ddtrace/contrib/sneakers/ext.rb +11 -11
  233. data/lib/ddtrace/contrib/sneakers/tracer.rb +2 -4
  234. data/lib/ddtrace/contrib/status_code_matcher.rb +5 -3
  235. data/lib/ddtrace/correlation.rb +1 -0
  236. data/lib/ddtrace/diagnostics/environment_logger.rb +2 -1
  237. data/lib/ddtrace/distributed_tracing/headers/headers.rb +1 -0
  238. data/lib/ddtrace/distributed_tracing/headers/helpers.rb +1 -3
  239. data/lib/ddtrace/ext/ci.rb +2 -2
  240. data/lib/ddtrace/ext/distributed.rb +1 -1
  241. data/lib/ddtrace/ext/http.rb +1 -1
  242. data/lib/ddtrace/ext/runtime.rb +3 -1
  243. data/lib/ddtrace/forced_tracing.rb +2 -0
  244. data/lib/ddtrace/logger.rb +1 -1
  245. data/lib/ddtrace/metrics.rb +10 -6
  246. data/lib/ddtrace/opentracer/distributed_headers.rb +3 -0
  247. data/lib/ddtrace/opentracer/span.rb +2 -6
  248. data/lib/ddtrace/opentracer/thread_local_scope.rb +1 -0
  249. data/lib/ddtrace/patcher.rb +25 -4
  250. data/lib/ddtrace/pin.rb +8 -61
  251. data/lib/ddtrace/pipeline/span_filter.rb +1 -1
  252. data/lib/ddtrace/propagation/grpc_propagator.rb +1 -0
  253. data/lib/ddtrace/quantization/http.rb +1 -0
  254. data/lib/ddtrace/runtime/cgroup.rb +2 -2
  255. data/lib/ddtrace/runtime/container.rb +27 -29
  256. data/lib/ddtrace/runtime/identity.rb +8 -0
  257. data/lib/ddtrace/sampler.rb +1 -1
  258. data/lib/ddtrace/sampling/rule_sampler.rb +1 -0
  259. data/lib/ddtrace/span.rb +7 -7
  260. data/lib/ddtrace/sync_writer.rb +12 -12
  261. data/lib/ddtrace/tracer.rb +7 -5
  262. data/lib/ddtrace/transport/http.rb +15 -8
  263. data/lib/ddtrace/transport/http/adapters/net.rb +27 -8
  264. data/lib/ddtrace/transport/http/adapters/registry.rb +1 -0
  265. data/lib/ddtrace/transport/http/adapters/unix_socket.rb +2 -4
  266. data/lib/ddtrace/transport/http/builder.rb +7 -1
  267. data/lib/ddtrace/transport/http/env.rb +8 -0
  268. data/lib/ddtrace/transport/http/traces.rb +2 -3
  269. data/lib/ddtrace/transport/io.rb +1 -1
  270. data/lib/ddtrace/transport/io/response.rb +1 -3
  271. data/lib/ddtrace/transport/io/traces.rb +6 -0
  272. data/lib/ddtrace/transport/traces.rb +18 -1
  273. data/lib/ddtrace/utils/compression.rb +27 -0
  274. data/lib/ddtrace/utils/object_set.rb +41 -0
  275. data/lib/ddtrace/utils/only_once.rb +40 -0
  276. data/lib/ddtrace/utils/sequence.rb +17 -0
  277. data/lib/ddtrace/utils/string_table.rb +45 -0
  278. data/lib/ddtrace/utils/time.rb +32 -1
  279. data/lib/ddtrace/vendor/active_record/MIT-LICENSE +20 -0
  280. data/lib/ddtrace/vendor/multipart-post/LICENSE +11 -0
  281. data/lib/ddtrace/vendor/multipart-post/multipart.rb +12 -0
  282. data/lib/ddtrace/vendor/multipart-post/multipart/post.rb +8 -0
  283. data/lib/ddtrace/vendor/multipart-post/multipart/post/composite_read_io.rb +116 -0
  284. data/lib/ddtrace/vendor/multipart-post/multipart/post/multipartable.rb +57 -0
  285. data/lib/ddtrace/vendor/multipart-post/multipart/post/parts.rb +135 -0
  286. data/lib/ddtrace/vendor/multipart-post/multipart/post/version.rb +9 -0
  287. data/lib/ddtrace/vendor/multipart-post/net/http/post/multipart.rb +32 -0
  288. data/lib/ddtrace/version.rb +1 -1
  289. data/lib/ddtrace/workers.rb +5 -0
  290. data/lib/ddtrace/workers/async.rb +11 -3
  291. data/lib/ddtrace/workers/loop.rb +17 -3
  292. data/lib/ddtrace/workers/polling.rb +1 -0
  293. data/lib/ddtrace/workers/queue.rb +1 -0
  294. data/lib/ddtrace/workers/trace_writer.rb +10 -10
  295. data/lib/ddtrace/writer.rb +7 -4
  296. metadata +152 -402
  297. data/lib/ddtrace/augmentation.rb +0 -13
  298. data/lib/ddtrace/augmentation/method_wrapper.rb +0 -20
  299. data/lib/ddtrace/augmentation/method_wrapping.rb +0 -38
  300. data/lib/ddtrace/augmentation/shim.rb +0 -102
  301. data/lib/ddtrace/contrib/rspec/example_group.rb +0 -61
  302. data/lib/ddtrace/monkey.rb +0 -58
@@ -0,0 +1,80 @@
1
+ require 'rack'
2
+
3
+ module Acme
4
+ class Application
5
+ def call(env)
6
+ request = Rack::Request.new(env)
7
+ router.route!(request)
8
+ end
9
+
10
+ def router
11
+ Router.new(
12
+ '/' => { controller: controllers[:health], action: :check },
13
+ '/health' => { controller: controllers[:health], action: :check },
14
+ '/basic/fibonacci' => { controller: controllers[:basic], action: :fibonacci },
15
+ '/basic/default' => { controller: controllers[:basic], action: :default }
16
+ )
17
+ end
18
+
19
+ def controllers
20
+ {
21
+ basic: Controllers::Basic.new,
22
+ health: Controllers::Health.new
23
+ }
24
+ end
25
+ end
26
+
27
+ class Router
28
+ attr_reader :routes
29
+
30
+ def initialize(routes)
31
+ @routes = routes
32
+ end
33
+
34
+ def route!(request)
35
+ begin
36
+ if route = routes[request.path]
37
+ route[:controller].send(route[:action], request)
38
+ else
39
+ not_found(request)
40
+ end
41
+ rescue StandardError => e
42
+ application_error(request, e)
43
+ end
44
+ end
45
+
46
+ def not_found(request)
47
+ [404, { 'Content-Type' => 'text/plain' }, ["404 Not Found: #{request.path}"]]
48
+ end
49
+
50
+ def application_error(request, error)
51
+ [500, { 'Content-Type' => 'text/plain' }, ["500 Application Error: #{error.message} Location: #{error.backtrace.first(3)}"]]
52
+ end
53
+ end
54
+
55
+ module Controllers
56
+ class Basic
57
+ def fibonacci(request)
58
+ n = rand(25..35)
59
+ result = fib(n)
60
+ ['200', { 'Content-Type' => 'text/plain' }, ["Basic: Fibonacci(#{n}): #{result}"]]
61
+ end
62
+
63
+ def default(request)
64
+ ['200', { 'Content-Type' => 'text/plain' }, ['Basic: Default']]
65
+ end
66
+
67
+ private
68
+
69
+ def fib(n)
70
+ n <= 1 ? n : fib(n-1) + fib(n-2)
71
+ end
72
+ end
73
+
74
+ class Health
75
+ def check(request)
76
+ ['204', {}, []]
77
+ end
78
+ end
79
+ end
80
+ end
@@ -0,0 +1,17 @@
1
+ require 'datadog/demo_env'
2
+ require 'ddtrace'
3
+
4
+ Datadog.configure do |c|
5
+ c.diagnostics.debug = true if Datadog::DemoEnv.feature?('debug')
6
+ c.analytics_enabled = true if Datadog::DemoEnv.feature?('analytics')
7
+ c.runtime_metrics.enabled = true if Datadog::DemoEnv.feature?('runtime_metrics')
8
+
9
+ if Datadog::DemoEnv.feature?('tracing')
10
+ c.use :rack, service_name: 'acme-rack'
11
+ end
12
+
13
+ if Datadog::DemoEnv.feature?('pprof_to_file')
14
+ # Reconfigure transport to write pprof to file
15
+ c.profiling.exporter.transport = Datadog::DemoEnv.profiler_file_transport
16
+ end
17
+ end
@@ -0,0 +1,22 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ # Start application process
4
+ puts "\n== Starting application process =="
5
+
6
+ profiling = Datadog::DemoEnv.feature?('profiling') ? 'DD_PROFILING_ENABLED=true ddtracerb exec ' : ''
7
+ process = (ARGV[0] || Datadog::DemoEnv.process)
8
+ command = case process
9
+ when 'puma'
10
+ "bundle exec #{profiling}puma -C /app/config/puma.rb /app/config.ru"
11
+ when 'unicorn'
12
+ "bundle exec #{profiling}unicorn -c /app/config/unicorn.rb /app/config.ru"
13
+ when 'irb'
14
+ "bundle exec #{profiling}irb"
15
+ when nil, ''
16
+ abort("\n== ERROR: Must specify a application process! ==")
17
+ else
18
+ abort("\n== ERROR: Unknown application process '#{process}' ==")
19
+ end
20
+
21
+ puts "Run: #{command}"
22
+ Kernel.exec(command)
@@ -0,0 +1,17 @@
1
+ #!/usr/bin/env ruby
2
+ require 'fileutils'
3
+ include FileUtils
4
+
5
+ # path to your application root.
6
+ APP_ROOT = File.expand_path('..', __dir__)
7
+
8
+ def system!(*args)
9
+ puts "Run: #{args.join(' ')}"
10
+ system(*args) || abort("\n== Command #{args} failed ==")
11
+ end
12
+
13
+ chdir APP_ROOT do
14
+ puts "\n== Installing dependencies =="
15
+ system! 'gem install bundler --conservative'
16
+ system('bundle check') || system!('bundle install')
17
+ end
@@ -0,0 +1,24 @@
1
+ #!/usr/bin/env ruby
2
+ require 'fileutils'
3
+ include FileUtils
4
+
5
+ # path to your application root.
6
+ APP_ROOT = File.expand_path('..', __dir__)
7
+
8
+ def system!(*args)
9
+ puts "Run: #{args.join(' ')}"
10
+ system(*args) || abort("\n== Command #{args} failed ==")
11
+ end
12
+
13
+ chdir APP_ROOT do
14
+ puts "\n== Performing setup =="
15
+ system!('./bin/setup')
16
+
17
+ if ENV['TEST_INTEGRATION']
18
+ puts "\n== Wait for healthy HTTP server... =="
19
+ system!('bash /vendor/dd-demo/http-health-check')
20
+ end
21
+
22
+ puts "\n== Run test suite =="
23
+ system!('rspec')
24
+ end
@@ -0,0 +1,6 @@
1
+ require 'datadog/demo_env'
2
+ require_relative 'app/datadog'
3
+ require_relative 'app/acme'
4
+
5
+ use Datadog::Contrib::Rack::TraceMiddleware if Datadog::DemoEnv.feature?('tracing')
6
+ run Acme::Application.new
@@ -0,0 +1,14 @@
1
+ require 'datadog/demo_env'
2
+
3
+ Datadog::DemoEnv.print_env('Puma master environment')
4
+
5
+ workers Integer(ENV["WEB_CONCURRENCY"] || 1)
6
+ threads 2, Integer(ENV['WEB_MAX_THREADS'] || 24)
7
+
8
+ preload_app!
9
+
10
+ bind 'tcp://0.0.0.0:80'
11
+
12
+ on_worker_boot do
13
+ Datadog::DemoEnv.print_env('Puma worker environment')
14
+ end
@@ -0,0 +1,23 @@
1
+ require 'datadog/demo_env'
2
+
3
+ # config/unicorn.rb
4
+ worker_processes Integer(ENV["WEB_CONCURRENCY"] || 3)
5
+ timeout 15
6
+ preload_app true
7
+
8
+ Datadog::DemoEnv.print_env('Unicorn master environment')
9
+
10
+ before_fork do |server, worker|
11
+ Signal.trap 'TERM' do
12
+ puts 'Unicorn master intercepting TERM and sending myself QUIT instead'
13
+ Process.kill 'QUIT', Process.pid
14
+ end
15
+ end
16
+
17
+ after_fork do |server, worker|
18
+ Signal.trap 'TERM' do
19
+ puts 'Unicorn worker intercepting TERM and doing nothing. Wait for master to send QUIT'
20
+ end
21
+
22
+ Datadog::DemoEnv.print_env('Unicorn worker environment')
23
+ end
@@ -0,0 +1,62 @@
1
+ version: '3.4'
2
+ services:
3
+ app:
4
+ # Build at dd-trace-rb level to copy in current code
5
+ # and use it as the `ddtrace` gem.
6
+ build:
7
+ context: ../../..
8
+ dockerfile: integration/apps/rack/Dockerfile-ci
9
+ args:
10
+ BASE_IMAGE: ${APP_IMAGE}
11
+ depends_on:
12
+ - ddagent
13
+ environment:
14
+ - BUNDLE_GEMFILE=/app/Gemfile
15
+ - DD_AGENT_HOST=ddagent
16
+ - DD_METRIC_AGENT_PORT=8125
17
+ - DD_TRACE_AGENT_PORT=8126
18
+ - DD_HEALTH_METRICS_ENABLED=true
19
+ - DD_SERVICE=acme-rack
20
+ - DD_PROFILING_ENABLED=true
21
+ # Use these to choose what is run
22
+ - DD_DEMO_ENV_PROCESS=puma
23
+ - DD_DEMO_ENV_FEATURES=tracing
24
+ expose:
25
+ - "80"
26
+ stdin_open: true
27
+ tty: true
28
+ ddagent:
29
+ image: datadog/dd-apm-demo:agent
30
+ environment:
31
+ - DD_APM_ENABLED=true
32
+ - DD_PROCESS_AGENT_ENABLED=false
33
+ - DD_BIND_HOST=0.0.0.0
34
+ - DD_API_KEY=invalid_api_key
35
+ - LOG_LEVEL=DEBUG
36
+ - DD_LOGS_STDOUT=yes
37
+ - DD_DOGSTATSD_NON_LOCAL_TRAFFIC=true
38
+ expose:
39
+ - "8125/udp"
40
+ - "8126"
41
+ # Build at dd-trace-rb level to copy in current code
42
+ # and use it as the `ddtrace` gem.
43
+ integration-tester:
44
+ build:
45
+ context: ../../..
46
+ dockerfile: integration/apps/rack/Dockerfile-ci
47
+ args:
48
+ BASE_IMAGE: ${APP_IMAGE}
49
+ command: bin/test
50
+ depends_on:
51
+ - app
52
+ environment:
53
+ - TEST_HOSTNAME=app
54
+ - TEST_PORT=80
55
+ - TEST_INTEGRATION=true
56
+ - HEALTH_CHECK_URL=http://app/health
57
+ - HEALTH_CHECK_INTERVAL=1
58
+ - HEALTH_CHECK_MAX_ATTEMPTS=30
59
+ # volumes:
60
+ # - .:/app
61
+ # - ../../images/include:/vendor/dd-demo
62
+ # - ../../..:/vendor/dd-trace-rb
@@ -0,0 +1,78 @@
1
+ version: '3.4'
2
+ services:
3
+ app:
4
+ build:
5
+ context: .
6
+ args:
7
+ BASE_IMAGE: datadog/dd-apm-demo:rb-2.7
8
+ depends_on:
9
+ - ddagent
10
+ environment:
11
+ - BUNDLE_GEMFILE=/app/Gemfile
12
+ - DD_AGENT_HOST=ddagent
13
+ - DD_METRIC_AGENT_PORT=8125
14
+ - DD_TRACE_AGENT_PORT=8126
15
+ - DD_HEALTH_METRICS_ENABLED=true
16
+ - DD_SERVICE=acme-rack
17
+ - DD_PROFILING_ENABLED=true
18
+ # Use these to choose what is run
19
+ - DD_DEMO_ENV_PROCESS=puma
20
+ - DD_DEMO_ENV_FEATURES=tracing
21
+ # Use this for a local version of ddtrace
22
+ - DD_DEMO_ENV_GEM_LOCAL_DDTRACE=/vendor/dd-trace-rb
23
+ # Use these for a specific revision of ddtrace
24
+ # - DD_DEMO_ENV_GEM_GIT_DDTRACE=https://github.com/DataDog/dd-trace-rb.git
25
+ # - DD_DEMO_ENV_GEM_REF_DDTRACE=f233336994315bfa04dac581387a8152bab8b85a
26
+ expose:
27
+ - "80"
28
+ stdin_open: true
29
+ tty: true
30
+ volumes:
31
+ - .:/app
32
+ - ./data/app:/data/app
33
+ - bundle:/usr/local/bundle
34
+ - ../../images/include:/vendor/dd-demo
35
+ - ../../..:/vendor/dd-trace-rb
36
+ ddagent:
37
+ image: datadog/dd-apm-demo:agent
38
+ environment:
39
+ - DD_APM_ENABLED=true
40
+ - DD_PROCESS_AGENT_ENABLED=false
41
+ - DD_BIND_HOST=0.0.0.0
42
+ - DD_API_KEY
43
+ - LOG_LEVEL=DEBUG
44
+ - DD_LOGS_STDOUT=yes
45
+ - DD_DOGSTATSD_NON_LOCAL_TRAFFIC=true
46
+ expose:
47
+ - "8125/udp"
48
+ - "8126"
49
+ volumes:
50
+ - ../../images/agent/agent.yaml:/etc/datadog-agent/datadog.yaml
51
+ # For monitoring performance of containers (e.g. CPU, Memory, etc...)
52
+ # - type: bind
53
+ # source: ../../images/agent/agent.yaml
54
+ # target: /etc/datadog-agent/datadog.yaml
55
+ # - type: bind
56
+ # source: /var/run/docker.sock
57
+ # target: /var/run/docker.sock:ro
58
+ # - type: bind
59
+ # source: /proc/
60
+ # target: /host/proc/:ro
61
+ # - type: bind
62
+ # source: /sys/fs/cgroup/
63
+ # target: /host/sys/fs/cgroup:ro
64
+ load-tester:
65
+ build:
66
+ context: ../../images
67
+ dockerfile: wrk/Dockerfile
68
+ command: -t10 -c10 -d43200s -s /scripts/scenarios/basic/default.lua http://app/basic/default
69
+ depends_on:
70
+ - app
71
+ environment:
72
+ - HEALTH_CHECK_URL=http://app/health
73
+ - HEALTH_CHECK_INTERVAL=1
74
+ - HEALTH_CHECK_MAX_ATTEMPTS=30
75
+ volumes:
76
+ - ../../images/wrk/scripts:/scripts
77
+ volumes:
78
+ bundle:
@@ -0,0 +1,38 @@
1
+ #!/bin/bash
2
+ set -euo pipefail
3
+
4
+ APP_SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" >/dev/null 2>&1 && pwd )"
5
+ APP_DIR=${APP_SCRIPT_DIR%/script}
6
+ cd $APP_DIR
7
+
8
+ while getopts ":v:" opt; do
9
+ case $opt in
10
+ v)
11
+ APP_RUBY_VERSION=$OPTARG
12
+ ;;
13
+ \?)
14
+ echo "Invalid option: -$OPTARG" >&2
15
+ exit 1
16
+ ;;
17
+ :)
18
+ echo "Option -$OPTARG requires an argument." >&2
19
+ exit 1
20
+ ;;
21
+ esac
22
+ done
23
+
24
+ echo "== Building Rack images... =="
25
+ if [ -v APP_RUBY_VERSION ]; then
26
+ docker build --build-arg BASE_IMAGE=datadog/dd-apm-demo:rb-$APP_RUBY_VERSION -t datadog/dd-apm-demo:rb-$APP_RUBY_VERSION-rack .
27
+ else
28
+ docker build --build-arg BASE_IMAGE=datadog/dd-apm-demo:rb-2.0 -t datadog/dd-apm-demo:rb-2.0-rack .
29
+ docker build --build-arg BASE_IMAGE=datadog/dd-apm-demo:rb-2.1 -t datadog/dd-apm-demo:rb-2.1-rack .
30
+ docker build --build-arg BASE_IMAGE=datadog/dd-apm-demo:rb-2.2 -t datadog/dd-apm-demo:rb-2.2-rack .
31
+ docker build --build-arg BASE_IMAGE=datadog/dd-apm-demo:rb-2.3 -t datadog/dd-apm-demo:rb-2.3-rack .
32
+ docker build --build-arg BASE_IMAGE=datadog/dd-apm-demo:rb-2.4 -t datadog/dd-apm-demo:rb-2.4-rack .
33
+ docker build --build-arg BASE_IMAGE=datadog/dd-apm-demo:rb-2.5 -t datadog/dd-apm-demo:rb-2.5-rack .
34
+ docker build --build-arg BASE_IMAGE=datadog/dd-apm-demo:rb-2.6 -t datadog/dd-apm-demo:rb-2.6-rack .
35
+ docker build --build-arg BASE_IMAGE=datadog/dd-apm-demo:rb-2.7 -t datadog/dd-apm-demo:rb-2.7-rack .
36
+ docker build --build-arg BASE_IMAGE=datadog/dd-apm-demo:rb-3.0 -t datadog/dd-apm-demo:rb-3.0-rack .
37
+ fi
38
+ echo "== Done building Rack images. =="
@@ -0,0 +1,50 @@
1
+ #!/bin/bash
2
+ set -euo pipefail
3
+
4
+ APP_SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" >/dev/null 2>&1 && pwd )"
5
+ APP_DIR=${APP_SCRIPT_DIR%/script}
6
+ cd $APP_DIR
7
+
8
+ # Parse options
9
+ while getopts "v:" opt; do
10
+ case $opt in
11
+ v)
12
+ APP_RUBY_VERSION=$OPTARG
13
+ ;;
14
+ \?)
15
+ echo "Invalid option: -$OPTARG" >&2
16
+ exit 1
17
+ ;;
18
+ :)
19
+ echo "Option -$OPTARG requires an argument." >&2
20
+ exit 1
21
+ ;;
22
+ esac
23
+ done
24
+
25
+ # Validate options
26
+ if [ -z ${APP_RUBY_VERSION+x} ]; then
27
+ echo "You must specify a Ruby version with -v. (e.g. 2.7)" >&2
28
+ exit 1
29
+ fi
30
+
31
+ # Set configuration
32
+ APP_BASE_IMAGE=${APP_BASE_IMAGE:-datadog/dd-apm-demo:rb-$APP_RUBY_VERSION}
33
+ APP_IMAGE=${APP_IMAGE:-$APP_BASE_IMAGE-rack}
34
+ APP_COMPOSE_FILES="-f docker-compose.ci.yml"
35
+
36
+ echo "== Running integration tests... =="
37
+ echo " - App: rack"
38
+ echo " - Ruby version: $APP_RUBY_VERSION"
39
+ echo " - Base image: $APP_BASE_IMAGE"
40
+ echo " - App image: $APP_IMAGE"
41
+ echo ""
42
+
43
+ # Pull/build any missing images
44
+ APP_IMAGE=$APP_IMAGE docker-compose $APP_COMPOSE_FILES build
45
+
46
+ # Run the test suite
47
+ APP_IMAGE=$APP_IMAGE docker-compose $APP_COMPOSE_FILES run integration-tester
48
+
49
+ # Cleanup
50
+ APP_IMAGE=$APP_IMAGE docker-compose $APP_COMPOSE_FILES down -t 0 --remove-orphans