ddtrace 0.42.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.
- checksums.yaml +5 -5
- data/.circleci/config.yml +274 -137
- data/.circleci/images/primary/Dockerfile-3.0.0 +73 -0
- data/.circleci/images/primary/{Dockerfile-jruby-9.2 → Dockerfile-jruby-9.2-latest} +2 -1
- data/.circleci/images/primary/Dockerfile-jruby-9.2.0.0 +73 -0
- data/.circleci/images/primary/Dockerfile-truffleruby-21.0.0 +73 -0
- data/.github/workflows/add-milestone-to-pull-requests.yml +42 -0
- data/.github/workflows/create-next-milestone.yml +20 -0
- data/.rubocop.yml +250 -7
- data/.rubocop_todo.yml +397 -0
- data/.simplecov +9 -0
- data/Appraisals +386 -142
- data/CHANGELOG.md +1218 -362
- data/CONTRIBUTING.md +1 -1
- data/Gemfile +55 -3
- data/LICENSE-3rdparty.csv +2 -0
- data/README.md +1 -0
- data/Rakefile +216 -29
- data/ddtrace.gemspec +4 -36
- data/docker-compose.yml +105 -7
- data/docs/DevelopmentGuide.md +30 -2
- data/docs/GettingStarted.md +242 -22
- data/integration/README.md +68 -0
- data/integration/apps/rack/.dockerignore +1 -0
- data/integration/apps/rack/.envrc.sample +1 -0
- data/integration/apps/rack/.gitignore +4 -0
- data/integration/apps/rack/.rspec +1 -0
- data/integration/apps/rack/Dockerfile +25 -0
- data/integration/apps/rack/Dockerfile-ci +11 -0
- data/integration/apps/rack/Gemfile +24 -0
- data/integration/apps/rack/README.md +93 -0
- data/integration/apps/rack/app/acme.rb +80 -0
- data/integration/apps/rack/app/datadog.rb +17 -0
- data/integration/apps/rack/bin/run +22 -0
- data/integration/apps/rack/bin/setup +17 -0
- data/integration/apps/rack/bin/test +24 -0
- data/integration/apps/rack/config.ru +6 -0
- data/integration/apps/rack/config/puma.rb +14 -0
- data/integration/apps/rack/config/unicorn.rb +23 -0
- data/integration/apps/rack/docker-compose.ci.yml +62 -0
- data/integration/apps/rack/docker-compose.yml +78 -0
- data/integration/apps/rack/script/build-images +38 -0
- data/integration/apps/rack/script/ci +50 -0
- data/integration/apps/rack/spec/integration/basic_spec.rb +10 -0
- data/integration/apps/rack/spec/spec_helper.rb +16 -0
- data/integration/apps/rack/spec/support/integration_helper.rb +22 -0
- data/integration/apps/rails-five/.dockerignore +1 -0
- data/integration/apps/rails-five/.env +3 -0
- data/integration/apps/rails-five/.envrc.sample +1 -0
- data/integration/apps/rails-five/.gitignore +30 -0
- data/integration/apps/rails-five/Dockerfile +25 -0
- data/integration/apps/rails-five/Dockerfile-ci +11 -0
- data/integration/apps/rails-five/Gemfile +104 -0
- data/integration/apps/rails-five/README.md +94 -0
- data/integration/apps/rails-five/Rakefile +6 -0
- data/integration/apps/rails-five/app/channels/application_cable/channel.rb +4 -0
- data/integration/apps/rails-five/app/channels/application_cable/connection.rb +4 -0
- data/integration/apps/rails-five/app/controllers/application_controller.rb +2 -0
- data/integration/apps/rails-five/app/controllers/basic_controller.rb +36 -0
- data/integration/apps/rails-five/app/controllers/concerns/.keep +0 -0
- data/integration/apps/rails-five/app/controllers/health_controller.rb +9 -0
- data/integration/apps/rails-five/app/controllers/jobs_controller.rb +12 -0
- data/integration/apps/rails-five/app/jobs/application_job.rb +2 -0
- data/integration/apps/rails-five/app/jobs/test_job.rb +12 -0
- data/integration/apps/rails-five/app/mailers/application_mailer.rb +4 -0
- data/integration/apps/rails-five/app/models/application_record.rb +3 -0
- data/integration/apps/rails-five/app/models/concerns/.keep +0 -0
- data/integration/apps/rails-five/app/models/test.rb +2 -0
- data/integration/apps/rails-five/app/views/layouts/mailer.html.erb +13 -0
- data/integration/apps/rails-five/app/views/layouts/mailer.text.erb +1 -0
- data/integration/apps/rails-five/bin/bundle +3 -0
- data/integration/apps/rails-five/bin/rails +9 -0
- data/integration/apps/rails-five/bin/rake +9 -0
- data/integration/apps/rails-five/bin/run +24 -0
- data/integration/apps/rails-five/bin/setup +27 -0
- data/integration/apps/rails-five/bin/spring +17 -0
- data/integration/apps/rails-five/bin/test +21 -0
- data/integration/apps/rails-five/bin/update +28 -0
- data/integration/apps/rails-five/config.ru +5 -0
- data/integration/apps/rails-five/config/application.rb +97 -0
- data/integration/apps/rails-five/config/boot.rb +4 -0
- data/integration/apps/rails-five/config/cable.yml +10 -0
- data/integration/apps/rails-five/config/credentials.yml.enc +1 -0
- data/integration/apps/rails-five/config/database.yml +28 -0
- data/integration/apps/rails-five/config/environment.rb +5 -0
- data/integration/apps/rails-five/config/environments/development.rb +51 -0
- data/integration/apps/rails-five/config/environments/production.rb +82 -0
- data/integration/apps/rails-five/config/environments/test.rb +43 -0
- data/integration/apps/rails-five/config/initializers/datadog.rb +18 -0
- data/integration/apps/rails-five/config/initializers/filter_parameter_logging.rb +4 -0
- data/integration/apps/rails-five/config/initializers/resque.rb +4 -0
- data/integration/apps/rails-five/config/initializers/rollbar.rb +5 -0
- data/integration/apps/rails-five/config/initializers/wrap_parameters.rb +14 -0
- data/integration/apps/rails-five/config/locales/en.yml +33 -0
- data/integration/apps/rails-five/config/puma.rb +24 -0
- data/integration/apps/rails-five/config/routes.rb +11 -0
- data/integration/apps/rails-five/config/spring.rb +6 -0
- data/integration/apps/rails-five/config/unicorn.rb +29 -0
- data/integration/apps/rails-five/db/migrate/20190927215052_create_tests.rb +11 -0
- data/integration/apps/rails-five/db/schema.rb +23 -0
- data/integration/apps/rails-five/db/seeds.rb +7 -0
- data/integration/apps/rails-five/docker-compose.ci.yml +98 -0
- data/integration/apps/rails-five/docker-compose.yml +100 -0
- data/integration/apps/rails-five/lib/tasks/.keep +0 -0
- data/integration/apps/rails-five/log/.keep +0 -0
- data/integration/apps/rails-five/public/robots.txt +1 -0
- data/integration/apps/rails-five/script/build-images +35 -0
- data/integration/apps/rails-five/script/ci +50 -0
- data/integration/apps/rails-five/spec/integration/basic_spec.rb +10 -0
- data/integration/apps/rails-five/spec/spec_helper.rb +16 -0
- data/integration/apps/rails-five/spec/support/integration_helper.rb +22 -0
- data/integration/apps/rails-five/storage/.keep +0 -0
- data/integration/apps/rails-five/tmp/.keep +0 -0
- data/integration/apps/rails-five/vendor/.keep +0 -0
- data/integration/apps/ruby/.dockerignore +1 -0
- data/integration/apps/ruby/.envrc.sample +1 -0
- data/integration/apps/ruby/.gitignore +2 -0
- data/integration/apps/ruby/Dockerfile +25 -0
- data/integration/apps/ruby/Dockerfile-ci +11 -0
- data/integration/apps/ruby/Gemfile +11 -0
- data/integration/apps/ruby/README.md +70 -0
- data/integration/apps/ruby/agent.yaml +3 -0
- data/integration/apps/ruby/app/datadog.rb +13 -0
- data/integration/apps/ruby/app/fibonacci.rb +58 -0
- data/integration/apps/ruby/bin/run +20 -0
- data/integration/apps/ruby/bin/setup +17 -0
- data/integration/apps/ruby/bin/test +21 -0
- data/integration/apps/ruby/docker-compose.ci.yml +51 -0
- data/integration/apps/ruby/docker-compose.yml +63 -0
- data/integration/apps/ruby/script/build-images +38 -0
- data/integration/apps/ruby/script/ci +50 -0
- data/integration/images/agent/Dockerfile +2 -0
- data/integration/images/agent/agent.yaml +3 -0
- data/integration/images/include/datadog/analyzer.rb +71 -0
- data/integration/images/include/datadog/demo_env.rb +101 -0
- data/integration/images/include/http-health-check +33 -0
- data/integration/images/ruby/2.0/Dockerfile +54 -0
- data/integration/images/ruby/2.1/Dockerfile +54 -0
- data/integration/images/ruby/2.2/Dockerfile +54 -0
- data/integration/images/ruby/2.3/Dockerfile +70 -0
- data/integration/images/ruby/2.4/Dockerfile +54 -0
- data/integration/images/ruby/2.5/Dockerfile +54 -0
- data/integration/images/ruby/2.6/Dockerfile +54 -0
- data/integration/images/ruby/2.7/Dockerfile +54 -0
- data/integration/images/ruby/3.0/Dockerfile +54 -0
- data/integration/images/wrk/Dockerfile +33 -0
- data/integration/images/wrk/scripts/entrypoint.sh +17 -0
- data/integration/images/wrk/scripts/scenarios/basic/default.lua +1 -0
- data/integration/images/wrk/scripts/scenarios/basic/fibonacci.lua +1 -0
- data/integration/script/build-images +43 -0
- data/lib/ddtrace.rb +10 -5
- data/lib/ddtrace/analytics.rb +2 -0
- data/lib/ddtrace/auto_instrument.rb +3 -0
- data/lib/ddtrace/auto_instrument_base.rb +6 -0
- data/lib/ddtrace/buffer.rb +4 -4
- data/lib/ddtrace/configuration.rb +108 -23
- data/lib/ddtrace/configuration/base.rb +1 -1
- data/lib/ddtrace/configuration/components.rb +2 -2
- data/lib/ddtrace/configuration/option_definition.rb +1 -3
- data/lib/ddtrace/configuration/options.rb +4 -7
- data/lib/ddtrace/configuration/settings.rb +21 -5
- data/lib/ddtrace/context.rb +23 -6
- data/lib/ddtrace/context_provider.rb +12 -2
- data/lib/ddtrace/contrib/action_cable/event.rb +1 -0
- data/lib/ddtrace/contrib/action_cable/integration.rb +7 -0
- data/lib/ddtrace/contrib/action_pack/action_controller/instrumentation.rb +1 -3
- data/lib/ddtrace/contrib/action_pack/integration.rb +7 -0
- data/lib/ddtrace/contrib/action_view/event.rb +1 -5
- data/lib/ddtrace/contrib/action_view/events/render_partial.rb +1 -0
- data/lib/ddtrace/contrib/action_view/events/render_template.rb +1 -0
- data/lib/ddtrace/contrib/action_view/integration.rb +7 -0
- data/lib/ddtrace/contrib/action_view/utils.rb +1 -1
- data/lib/ddtrace/contrib/active_record/configuration/resolver.rb +101 -18
- data/lib/ddtrace/contrib/active_record/integration.rb +7 -0
- data/lib/ddtrace/contrib/active_record/utils.rb +68 -21
- data/lib/ddtrace/contrib/active_support/cache/instrumentation.rb +104 -3
- data/lib/ddtrace/contrib/active_support/cache/patcher.rb +21 -0
- data/lib/ddtrace/contrib/active_support/ext.rb +3 -0
- data/lib/ddtrace/contrib/active_support/integration.rb +7 -1
- data/lib/ddtrace/contrib/active_support/notifications/event.rb +12 -1
- data/lib/ddtrace/contrib/active_support/notifications/subscriber.rb +1 -0
- data/lib/ddtrace/contrib/active_support/notifications/subscription.rb +9 -5
- data/lib/ddtrace/contrib/auto_instrument.rb +49 -0
- data/lib/ddtrace/contrib/aws/instrumentation.rb +2 -1
- data/lib/ddtrace/contrib/aws/patcher.rb +1 -1
- data/lib/ddtrace/contrib/aws/services.rb +3 -0
- data/lib/ddtrace/contrib/configurable.rb +63 -37
- data/lib/ddtrace/contrib/configuration/resolver.rb +70 -5
- data/lib/ddtrace/contrib/configuration/resolvers/pattern_resolver.rb +20 -20
- data/lib/ddtrace/contrib/configuration/settings.rb +7 -6
- data/lib/ddtrace/contrib/cucumber/configuration/settings.rb +28 -0
- data/lib/ddtrace/contrib/cucumber/ext.rb +17 -0
- data/lib/ddtrace/contrib/cucumber/formatter.rb +98 -0
- data/lib/ddtrace/contrib/cucumber/instrumentation.rb +24 -0
- data/lib/ddtrace/contrib/cucumber/integration.rb +45 -0
- data/lib/ddtrace/contrib/cucumber/patcher.rb +23 -0
- data/lib/ddtrace/contrib/dalli/patcher.rb +0 -38
- data/lib/ddtrace/contrib/delayed_job/configuration/settings.rb +1 -0
- data/lib/ddtrace/contrib/delayed_job/plugin.rb +2 -1
- data/lib/ddtrace/contrib/elasticsearch/patcher.rb +1 -0
- data/lib/ddtrace/contrib/elasticsearch/quantize.rb +3 -2
- data/lib/ddtrace/contrib/ethon/easy_patch.rb +11 -10
- data/lib/ddtrace/contrib/ethon/ext.rb +1 -0
- data/lib/ddtrace/contrib/excon/middleware.rb +9 -7
- data/lib/ddtrace/contrib/extensions.rb +53 -3
- data/lib/ddtrace/contrib/faraday/middleware.rb +1 -3
- data/lib/ddtrace/contrib/faraday/patcher.rb +0 -36
- data/lib/ddtrace/contrib/grape/configuration/settings.rb +7 -0
- data/lib/ddtrace/contrib/grape/endpoint.rb +47 -21
- data/lib/ddtrace/contrib/grape/ext.rb +1 -0
- data/lib/ddtrace/contrib/grape/patcher.rb +0 -42
- data/lib/ddtrace/contrib/grpc/datadog_interceptor.rb +8 -8
- data/lib/ddtrace/contrib/grpc/datadog_interceptor/server.rb +1 -0
- data/lib/ddtrace/contrib/grpc/patcher.rb +0 -36
- data/lib/ddtrace/contrib/http/circuit_breaker.rb +1 -3
- data/lib/ddtrace/contrib/http/instrumentation.rb +7 -7
- data/lib/ddtrace/contrib/httpclient/configuration/settings.rb +32 -0
- data/lib/ddtrace/contrib/httpclient/ext.rb +17 -0
- data/lib/ddtrace/contrib/httpclient/instrumentation.rb +147 -0
- data/lib/ddtrace/contrib/httpclient/integration.rb +43 -0
- data/lib/ddtrace/contrib/httpclient/patcher.rb +38 -0
- data/lib/ddtrace/contrib/httprb/instrumentation.rb +15 -21
- data/lib/ddtrace/contrib/httprb/patcher.rb +5 -2
- data/lib/ddtrace/contrib/kafka/event.rb +1 -1
- data/lib/ddtrace/contrib/mongodb/instrumentation.rb +2 -0
- data/lib/ddtrace/contrib/mongodb/subscribers.rb +2 -3
- data/lib/ddtrace/contrib/patchable.rb +18 -7
- data/lib/ddtrace/contrib/patcher.rb +9 -6
- data/lib/ddtrace/contrib/presto/patcher.rb +5 -2
- data/lib/ddtrace/contrib/qless/configuration/settings.rb +35 -0
- data/lib/ddtrace/contrib/qless/ext.rb +20 -0
- data/lib/ddtrace/contrib/qless/integration.rb +38 -0
- data/lib/ddtrace/contrib/qless/patcher.rb +35 -0
- data/lib/ddtrace/contrib/qless/qless_job.rb +73 -0
- data/lib/ddtrace/contrib/qless/tracer_cleaner.rb +33 -0
- data/lib/ddtrace/contrib/que/configuration/settings.rb +1 -0
- data/lib/ddtrace/contrib/que/ext.rb +19 -19
- data/lib/ddtrace/contrib/que/tracer.rb +3 -2
- data/lib/ddtrace/contrib/racecar/event.rb +1 -0
- data/lib/ddtrace/contrib/rack/configuration/settings.rb +3 -3
- data/lib/ddtrace/contrib/rack/integration.rb +7 -0
- data/lib/ddtrace/contrib/rack/middlewares.rb +6 -11
- data/lib/ddtrace/contrib/rack/patcher.rb +1 -3
- data/lib/ddtrace/contrib/rack/request_queue.rb +6 -1
- data/lib/ddtrace/contrib/rails/auto_instrument_railtie.rb +10 -0
- data/lib/ddtrace/contrib/rails/patcher.rb +11 -4
- data/lib/ddtrace/contrib/rails/utils.rb +4 -0
- data/lib/ddtrace/contrib/rake/instrumentation.rb +4 -2
- data/lib/ddtrace/contrib/rake/integration.rb +1 -1
- data/lib/ddtrace/contrib/redis/configuration/resolver.rb +14 -5
- data/lib/ddtrace/contrib/redis/configuration/settings.rb +5 -0
- data/lib/ddtrace/contrib/redis/ext.rb +1 -0
- data/lib/ddtrace/contrib/redis/patcher.rb +20 -3
- data/lib/ddtrace/contrib/redis/quantize.rb +28 -0
- data/lib/ddtrace/contrib/redis/tags.rb +5 -1
- data/lib/ddtrace/contrib/redis/vendor/LICENSE +20 -0
- data/lib/ddtrace/contrib/redis/vendor/resolver.rb +6 -7
- data/lib/ddtrace/contrib/registry.rb +2 -2
- data/lib/ddtrace/contrib/resque/configuration/settings.rb +1 -0
- data/lib/ddtrace/contrib/resque/integration.rb +1 -1
- data/lib/ddtrace/contrib/resque/resque_job.rb +3 -1
- data/lib/ddtrace/contrib/rest_client/request_patch.rb +1 -3
- data/lib/ddtrace/contrib/rspec/configuration/settings.rb +28 -0
- data/lib/ddtrace/contrib/rspec/example.rb +75 -0
- data/lib/ddtrace/contrib/rspec/ext.rb +16 -0
- data/lib/ddtrace/contrib/rspec/integration.rb +46 -0
- data/lib/ddtrace/contrib/rspec/patcher.rb +23 -0
- data/lib/ddtrace/contrib/sequel/utils.rb +5 -6
- data/lib/ddtrace/contrib/shoryuken/configuration/settings.rb +1 -0
- data/lib/ddtrace/contrib/shoryuken/tracer.rb +3 -1
- data/lib/ddtrace/contrib/sidekiq/configuration/settings.rb +1 -0
- data/lib/ddtrace/contrib/sidekiq/server_tracer.rb +5 -7
- data/lib/ddtrace/contrib/sidekiq/tracing.rb +0 -1
- data/lib/ddtrace/contrib/sinatra/env.rb +1 -3
- data/lib/ddtrace/contrib/sinatra/headers.rb +1 -3
- data/lib/ddtrace/contrib/sinatra/tracer.rb +1 -3
- data/lib/ddtrace/contrib/sinatra/tracer_middleware.rb +5 -5
- data/lib/ddtrace/contrib/sneakers/configuration/settings.rb +1 -0
- data/lib/ddtrace/contrib/sneakers/ext.rb +11 -11
- data/lib/ddtrace/contrib/sneakers/tracer.rb +16 -21
- data/lib/ddtrace/contrib/status_code_matcher.rb +69 -0
- data/lib/ddtrace/correlation.rb +1 -0
- data/lib/ddtrace/diagnostics/environment_logger.rb +2 -1
- data/lib/ddtrace/distributed_tracing/headers/headers.rb +1 -0
- data/lib/ddtrace/distributed_tracing/headers/helpers.rb +1 -3
- data/lib/ddtrace/ext/app_types.rb +1 -0
- data/lib/ddtrace/ext/ci.rb +297 -0
- data/lib/ddtrace/ext/distributed.rb +8 -2
- data/lib/ddtrace/ext/git.rb +11 -0
- data/lib/ddtrace/ext/http.rb +1 -1
- data/lib/ddtrace/ext/runtime.rb +4 -1
- data/lib/ddtrace/ext/test.rb +24 -0
- data/lib/ddtrace/forced_tracing.rb +2 -0
- data/lib/ddtrace/logger.rb +1 -1
- data/lib/ddtrace/metrics.rb +10 -6
- data/lib/ddtrace/opentracer/distributed_headers.rb +3 -0
- data/lib/ddtrace/opentracer/span.rb +2 -6
- data/lib/ddtrace/opentracer/thread_local_scope.rb +1 -0
- data/lib/ddtrace/patcher.rb +25 -4
- data/lib/ddtrace/pin.rb +8 -61
- data/lib/ddtrace/pipeline/span_filter.rb +1 -1
- data/lib/ddtrace/propagation/grpc_propagator.rb +1 -0
- data/lib/ddtrace/propagation/http_propagator.rb +17 -2
- data/lib/ddtrace/quantization/http.rb +1 -0
- data/lib/ddtrace/runtime/cgroup.rb +2 -2
- data/lib/ddtrace/runtime/container.rb +27 -29
- data/lib/ddtrace/runtime/identity.rb +12 -5
- data/lib/ddtrace/sampler.rb +1 -1
- data/lib/ddtrace/sampling/rate_limiter.rb +65 -16
- data/lib/ddtrace/sampling/rule_sampler.rb +1 -0
- data/lib/ddtrace/span.rb +7 -7
- data/lib/ddtrace/sync_writer.rb +12 -12
- data/lib/ddtrace/tracer.rb +21 -6
- data/lib/ddtrace/transport/http.rb +15 -8
- data/lib/ddtrace/transport/http/adapters/net.rb +27 -8
- data/lib/ddtrace/transport/http/adapters/registry.rb +1 -0
- data/lib/ddtrace/transport/http/adapters/unix_socket.rb +2 -4
- data/lib/ddtrace/transport/http/builder.rb +7 -1
- data/lib/ddtrace/transport/http/env.rb +8 -0
- data/lib/ddtrace/transport/http/traces.rb +2 -3
- data/lib/ddtrace/transport/io.rb +1 -1
- data/lib/ddtrace/transport/io/response.rb +1 -3
- data/lib/ddtrace/transport/io/traces.rb +6 -0
- data/lib/ddtrace/transport/traces.rb +18 -1
- data/lib/ddtrace/utils.rb +10 -11
- data/lib/ddtrace/utils/compression.rb +27 -0
- data/lib/ddtrace/utils/forking.rb +52 -0
- data/lib/ddtrace/utils/object_set.rb +41 -0
- data/lib/ddtrace/utils/only_once.rb +40 -0
- data/lib/ddtrace/utils/sequence.rb +17 -0
- data/lib/ddtrace/utils/string_table.rb +45 -0
- data/lib/ddtrace/utils/time.rb +32 -1
- data/lib/ddtrace/vendor/active_record/MIT-LICENSE +20 -0
- data/lib/ddtrace/vendor/multipart-post/LICENSE +11 -0
- data/lib/ddtrace/vendor/multipart-post/multipart.rb +12 -0
- data/lib/ddtrace/vendor/multipart-post/multipart/post.rb +8 -0
- data/lib/ddtrace/vendor/multipart-post/multipart/post/composite_read_io.rb +116 -0
- data/lib/ddtrace/vendor/multipart-post/multipart/post/multipartable.rb +57 -0
- data/lib/ddtrace/vendor/multipart-post/multipart/post/parts.rb +135 -0
- data/lib/ddtrace/vendor/multipart-post/multipart/post/version.rb +9 -0
- data/lib/ddtrace/vendor/multipart-post/net/http/post/multipart.rb +32 -0
- data/lib/ddtrace/version.rb +1 -1
- data/lib/ddtrace/workers.rb +5 -0
- data/lib/ddtrace/workers/async.rb +11 -3
- data/lib/ddtrace/workers/loop.rb +17 -3
- data/lib/ddtrace/workers/polling.rb +1 -0
- data/lib/ddtrace/workers/queue.rb +1 -0
- data/lib/ddtrace/workers/runtime_metrics.rb +7 -3
- data/lib/ddtrace/workers/trace_writer.rb +10 -10
- data/lib/ddtrace/writer.rb +26 -5
- metadata +186 -373
- data/lib/ddtrace/augmentation.rb +0 -13
- data/lib/ddtrace/augmentation/method_wrapper.rb +0 -20
- data/lib/ddtrace/augmentation/method_wrapping.rb +0 -38
- data/lib/ddtrace/augmentation/shim.rb +0 -102
- data/lib/ddtrace/monkey.rb +0 -58
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
require 'ddtrace'
|
|
2
|
+
|
|
3
|
+
module Datadog
|
|
4
|
+
module Contrib
|
|
5
|
+
# Extensions for auto instrumentation added to the base library
|
|
6
|
+
# AutoInstrumentation enables all integration
|
|
7
|
+
module AutoInstrument
|
|
8
|
+
def self.extended(base)
|
|
9
|
+
base.send(:extend, Patch)
|
|
10
|
+
end
|
|
11
|
+
|
|
12
|
+
# Patch adds method for invoking auto_instrumentation
|
|
13
|
+
module Patch
|
|
14
|
+
def add_auto_instrument
|
|
15
|
+
super
|
|
16
|
+
|
|
17
|
+
if Datadog::Contrib::Rails::Utils.railtie_supported?
|
|
18
|
+
require 'ddtrace/contrib/rails/auto_instrument_railtie'
|
|
19
|
+
else
|
|
20
|
+
AutoInstrument.patch_all
|
|
21
|
+
end
|
|
22
|
+
AutoInstrument.patch_all
|
|
23
|
+
end
|
|
24
|
+
end
|
|
25
|
+
|
|
26
|
+
def self.patch_all
|
|
27
|
+
integrations = []
|
|
28
|
+
|
|
29
|
+
Datadog.registry.each do |integration|
|
|
30
|
+
# some instrumentations are automatically enabled when the `rails` instrumentation is enabled,
|
|
31
|
+
# patching them on their own automatically outside of the rails integration context would
|
|
32
|
+
# cause undesirable service naming, so we exclude them based their auto_instrument? setting.
|
|
33
|
+
# we also don't want to mix rspec/cucumber integration in as rspec is env we run tests in.
|
|
34
|
+
next unless integration.klass.auto_instrument?
|
|
35
|
+
|
|
36
|
+
integrations << integration.name
|
|
37
|
+
end
|
|
38
|
+
|
|
39
|
+
Datadog.configure do |c|
|
|
40
|
+
c.reduce_log_verbosity
|
|
41
|
+
# This will activate auto-instrumentation for Rails
|
|
42
|
+
integrations.each do |integration_name|
|
|
43
|
+
c.use integration_name
|
|
44
|
+
end
|
|
45
|
+
end
|
|
46
|
+
end
|
|
47
|
+
end
|
|
48
|
+
end
|
|
49
|
+
end
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
require 'ddtrace/contrib/analytics'
|
|
2
2
|
require 'ddtrace/contrib/aws/ext'
|
|
3
|
+
require 'ddtrace/ext/http'
|
|
3
4
|
require 'ddtrace/ext/integration'
|
|
4
5
|
|
|
5
6
|
module Datadog
|
|
@@ -26,7 +27,7 @@ module Datadog
|
|
|
26
27
|
|
|
27
28
|
def annotate!(span, context)
|
|
28
29
|
span.service = configuration[:service_name]
|
|
29
|
-
span.span_type = Datadog::Ext::
|
|
30
|
+
span.span_type = Datadog::Ext::HTTP::TYPE_OUTBOUND
|
|
30
31
|
span.name = Ext::SPAN_COMMAND
|
|
31
32
|
span.resource = context.safely(:resource)
|
|
32
33
|
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
require 'ddtrace/contrib/patcher'
|
|
2
|
-
require 'ddtrace/ext/app_types'
|
|
3
2
|
require 'ddtrace/contrib/aws/ext'
|
|
4
3
|
|
|
5
4
|
module Datadog
|
|
@@ -36,6 +35,7 @@ module Datadog
|
|
|
36
35
|
|
|
37
36
|
available_services.each_with_object([]) do |service, constants|
|
|
38
37
|
next if ::Aws.autoload?(service)
|
|
38
|
+
|
|
39
39
|
constants << ::Aws.const_get(service, false).const_get(:Client, false) rescue next
|
|
40
40
|
end
|
|
41
41
|
end
|
|
@@ -52,6 +52,7 @@ module Datadog
|
|
|
52
52
|
ElasticLoadBalancingV2
|
|
53
53
|
ElasticTranscoder
|
|
54
54
|
ElasticsearchService
|
|
55
|
+
EventBridge
|
|
55
56
|
Firehose
|
|
56
57
|
GameLift
|
|
57
58
|
Glacier
|
|
@@ -98,12 +99,14 @@ module Datadog
|
|
|
98
99
|
STS
|
|
99
100
|
SWF
|
|
100
101
|
ServiceCatalog
|
|
102
|
+
Schemas
|
|
101
103
|
Shield
|
|
102
104
|
SimpleDB
|
|
103
105
|
Snowball
|
|
104
106
|
States
|
|
105
107
|
StorageGateway
|
|
106
108
|
Support
|
|
109
|
+
Textract
|
|
107
110
|
WAF
|
|
108
111
|
WAFRegional
|
|
109
112
|
WorkDocs
|
|
@@ -3,7 +3,11 @@ require 'ddtrace/contrib/configuration/settings'
|
|
|
3
3
|
|
|
4
4
|
module Datadog
|
|
5
5
|
module Contrib
|
|
6
|
-
# Defines configurable behavior for integrations
|
|
6
|
+
# Defines configurable behavior for integrations.
|
|
7
|
+
#
|
|
8
|
+
# This module is responsible for coordination between
|
|
9
|
+
# the configuration resolver and default configuration
|
|
10
|
+
# fallback.
|
|
7
11
|
module Configurable
|
|
8
12
|
def self.included(base)
|
|
9
13
|
base.send(:include, InstanceMethods)
|
|
@@ -11,64 +15,86 @@ module Datadog
|
|
|
11
15
|
|
|
12
16
|
# Configurable instance behavior for integrations
|
|
13
17
|
module InstanceMethods
|
|
18
|
+
# Provides a new configuration instance for this integration.
|
|
19
|
+
#
|
|
20
|
+
# This method normally needs to be overridden for each integration
|
|
21
|
+
# as their settings, defaults and environment variables are
|
|
22
|
+
# specific for each integration.
|
|
23
|
+
#
|
|
24
|
+
# DEV(1.0): Rename to `new_configuration`, make it protected.
|
|
25
|
+
# DEV(1.0):
|
|
26
|
+
# DEV(1.0): This method always provides a new instance of the configuration object for
|
|
27
|
+
# DEV(1.0): the current integration, not the currently effective default configuration.
|
|
28
|
+
# DEV(1.0): This is a misnomer of its function.
|
|
29
|
+
# DEV(1.0):
|
|
30
|
+
# DEV(1.0): Unfortunately, change this would be a breaking change for all custom integrations,
|
|
31
|
+
# DEV(1.0): thus we have to be very intentional with the right time to make this change.
|
|
32
|
+
# DEV(1.0): Currently marking this for a 1.0 milestone.
|
|
14
33
|
def default_configuration
|
|
15
34
|
Configuration::Settings.new
|
|
16
35
|
end
|
|
17
36
|
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
37
|
+
# Get matching configuration by matcher.
|
|
38
|
+
# If no match, returns the default configuration instance.
|
|
39
|
+
def configuration(matcher = :default)
|
|
40
|
+
return default_configuration_instance if matcher == :default
|
|
22
41
|
|
|
23
|
-
|
|
24
|
-
# If no match, returns default configuration.
|
|
25
|
-
def configuration(key = :default)
|
|
26
|
-
configurations[configuration_key(key)]
|
|
42
|
+
resolver.get(matcher) || default_configuration_instance
|
|
27
43
|
end
|
|
28
44
|
|
|
29
|
-
#
|
|
30
|
-
#
|
|
31
|
-
def
|
|
32
|
-
|
|
33
|
-
|
|
45
|
+
# Resolves the matching configuration for integration-specific value.
|
|
46
|
+
# If no match, returns the default configuration instance.
|
|
47
|
+
def resolve(value)
|
|
48
|
+
return default_configuration_instance if value == :default
|
|
49
|
+
|
|
50
|
+
resolver.resolve(value) || default_configuration_instance
|
|
34
51
|
end
|
|
35
52
|
|
|
53
|
+
# Returns all registered matchers and their respective configurations.
|
|
36
54
|
def configurations
|
|
37
|
-
|
|
38
|
-
default: default_configuration
|
|
39
|
-
}
|
|
55
|
+
resolver.configurations.merge(default: default_configuration_instance)
|
|
40
56
|
end
|
|
41
57
|
|
|
42
|
-
# Create or update configuration with
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
58
|
+
# Create or update configuration associated with `matcher` with
|
|
59
|
+
# the provided `options` and `&block`.
|
|
60
|
+
def configure(matcher = :default, options = {}, &block)
|
|
61
|
+
config = if matcher == :default
|
|
62
|
+
default_configuration_instance
|
|
63
|
+
else
|
|
64
|
+
# Get or add the configuration
|
|
65
|
+
resolver.get(matcher) || resolver.add(matcher, default_configuration)
|
|
66
|
+
end
|
|
48
67
|
|
|
49
68
|
# Apply the settings
|
|
50
69
|
config.configure(options, &block)
|
|
51
70
|
config
|
|
52
71
|
end
|
|
53
72
|
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
@
|
|
73
|
+
# Resets all configuration options
|
|
74
|
+
def reset_configuration!
|
|
75
|
+
@resolver = nil
|
|
76
|
+
@default_configuration = nil
|
|
58
77
|
end
|
|
59
78
|
|
|
60
|
-
|
|
61
|
-
resolver.add(key)
|
|
62
|
-
config_key = resolver.resolve(key)
|
|
63
|
-
configurations[config_key] = default_configuration
|
|
64
|
-
end
|
|
79
|
+
protected
|
|
65
80
|
|
|
66
|
-
|
|
67
|
-
|
|
81
|
+
# DEV(1.0): Rename to `default_configuration`, make it public.
|
|
82
|
+
# DEV(1.0): See comment on `default_configuration` for more information.
|
|
83
|
+
def default_configuration_instance
|
|
84
|
+
@default_configuration ||= default_configuration # rubocop:disable Naming/MemoizedInstanceVariableName
|
|
85
|
+
end
|
|
68
86
|
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
87
|
+
# Overridable configuration resolver.
|
|
88
|
+
#
|
|
89
|
+
# This resolver is responsible for performing the matching
|
|
90
|
+
# of `#configure(matcher)` `matcher`s with `value`s provided
|
|
91
|
+
# in subsequent calls to `#resolve(value)`.
|
|
92
|
+
#
|
|
93
|
+
# By default, the `value` in `#resolve(value)` must be equal
|
|
94
|
+
# to the `matcher` object provided in `#configure(matcher)`
|
|
95
|
+
# to retrieve the associated configuration.
|
|
96
|
+
def resolver
|
|
97
|
+
@resolver ||= Configuration::Resolver.new
|
|
72
98
|
end
|
|
73
99
|
end
|
|
74
100
|
end
|
|
@@ -1,14 +1,79 @@
|
|
|
1
1
|
module Datadog
|
|
2
2
|
module Contrib
|
|
3
3
|
module Configuration
|
|
4
|
-
# Resolves
|
|
4
|
+
# Resolves an integration-specific matcher to an associated
|
|
5
|
+
# object.
|
|
6
|
+
#
|
|
7
|
+
# Integrations that perform any configuration matching
|
|
8
|
+
# based on patterns might want to override this class
|
|
9
|
+
# to provide richer matching. For example, match configuration
|
|
10
|
+
# based on: HTTP request parameters, request headers,
|
|
11
|
+
# async queue name.
|
|
12
|
+
#
|
|
13
|
+
# When overriding this class, for simple use cases, only
|
|
14
|
+
# overriding `#parse_matcher` might suffice. See
|
|
15
|
+
# `#parse_matcher`'s documentation for more information.
|
|
5
16
|
class Resolver
|
|
6
|
-
|
|
7
|
-
|
|
17
|
+
attr_reader :configurations
|
|
18
|
+
|
|
19
|
+
def initialize
|
|
20
|
+
@configurations = {}
|
|
21
|
+
end
|
|
22
|
+
|
|
23
|
+
# Adds a new `matcher`, associating with it a `value`.
|
|
24
|
+
#
|
|
25
|
+
# This `value` is returned when `#resolve` is called
|
|
26
|
+
# with a matching value for this matcher. When multiple
|
|
27
|
+
# matchers would match, `#resolve` returns the latest
|
|
28
|
+
# added one.
|
|
29
|
+
#
|
|
30
|
+
# The `matcher` can be transformed internally by the
|
|
31
|
+
# `#parse_matcher` method before being stored.
|
|
32
|
+
#
|
|
33
|
+
# The `value` can also be retrieved by calling `#get`
|
|
34
|
+
# with the same `matcher` added by this method.
|
|
35
|
+
#
|
|
36
|
+
# @param [Object] matcher integration-specific matcher
|
|
37
|
+
# @param [Object] value arbitrary value to be associated with `matcher`
|
|
38
|
+
def add(matcher, value)
|
|
39
|
+
@configurations[parse_matcher(matcher)] = value
|
|
40
|
+
end
|
|
41
|
+
|
|
42
|
+
# Retrieves the stored value for a `matcher`
|
|
43
|
+
# previously stored by `#add`.
|
|
44
|
+
#
|
|
45
|
+
# @param [Object] matcher integration-specific matcher
|
|
46
|
+
# @return [Object] previously stored `value` from `#add`, or `nil` if not found
|
|
47
|
+
def get(matcher)
|
|
48
|
+
@configurations[parse_matcher(matcher)]
|
|
49
|
+
end
|
|
50
|
+
|
|
51
|
+
# Matches an arbitrary value against the configured
|
|
52
|
+
# matchers previously set with `#add`.
|
|
53
|
+
#
|
|
54
|
+
# If multiple matchers would match, returns the latest one.
|
|
55
|
+
#
|
|
56
|
+
# @param [Object] value integration-specific value
|
|
57
|
+
# @return [Object] matching `value` configured at `#add`, or `nil` if none match
|
|
58
|
+
def resolve(value)
|
|
59
|
+
@configurations[value]
|
|
8
60
|
end
|
|
9
61
|
|
|
10
|
-
|
|
11
|
-
|
|
62
|
+
protected
|
|
63
|
+
|
|
64
|
+
# Converts `matcher` into an appropriate key
|
|
65
|
+
# for the internal Hash storage.
|
|
66
|
+
#
|
|
67
|
+
# It's recommended to override this method,
|
|
68
|
+
# instead of the public methods, if the
|
|
69
|
+
# integration can simply convert both
|
|
70
|
+
# `matcher` (provided to `#add`) and `value`
|
|
71
|
+
# (provided to `#resolve`) to the same value.
|
|
72
|
+
#
|
|
73
|
+
# @param [Object] matcher integration-specific matcher
|
|
74
|
+
# @return [Object] processed matcher
|
|
75
|
+
def parse_matcher(matcher)
|
|
76
|
+
matcher
|
|
12
77
|
end
|
|
13
78
|
end
|
|
14
79
|
end
|
|
@@ -5,32 +5,32 @@ module Datadog
|
|
|
5
5
|
module Configuration
|
|
6
6
|
# Resolves a value to a configuration key
|
|
7
7
|
module Resolvers
|
|
8
|
-
# Matches
|
|
9
|
-
|
|
10
|
-
|
|
8
|
+
# Matches Strings and Regexps against `object.to_s` objects
|
|
9
|
+
# and Procs against plain objects.
|
|
10
|
+
class PatternResolver < Contrib::Configuration::Resolver
|
|
11
|
+
def resolve(value)
|
|
12
|
+
return if configurations.empty?
|
|
13
|
+
|
|
11
14
|
# Try to find a matching pattern
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
pattern === name.to_s # Co-erce to string
|
|
19
|
-
end
|
|
15
|
+
_, config = configurations.reverse_each.find do |matcher, _|
|
|
16
|
+
matcher === if matcher.is_a?(Proc)
|
|
17
|
+
value
|
|
18
|
+
else
|
|
19
|
+
value.to_s
|
|
20
|
+
end
|
|
20
21
|
end
|
|
21
22
|
|
|
22
|
-
|
|
23
|
-
matching_pattern || :default
|
|
24
|
-
end
|
|
25
|
-
|
|
26
|
-
def add(pattern)
|
|
27
|
-
patterns << (pattern.is_a?(Regexp) || pattern.is_a?(Proc) ? pattern : pattern.to_s)
|
|
23
|
+
config
|
|
28
24
|
end
|
|
29
25
|
|
|
30
|
-
|
|
26
|
+
protected
|
|
31
27
|
|
|
32
|
-
def
|
|
33
|
-
|
|
28
|
+
def parse_matcher(matcher)
|
|
29
|
+
if matcher.is_a?(Regexp) || matcher.is_a?(Proc)
|
|
30
|
+
matcher
|
|
31
|
+
else
|
|
32
|
+
matcher.to_s
|
|
33
|
+
end
|
|
34
34
|
end
|
|
35
35
|
end
|
|
36
36
|
end
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
require 'ddtrace/configuration/base'
|
|
2
|
+
require 'ddtrace/utils/only_once'
|
|
2
3
|
|
|
3
4
|
module Datadog
|
|
4
5
|
module Contrib
|
|
@@ -7,6 +8,8 @@ module Datadog
|
|
|
7
8
|
class Settings
|
|
8
9
|
include Datadog::Configuration::Base
|
|
9
10
|
|
|
11
|
+
DEPRECATION_WARN_ONLY_ONCE = Datadog::Utils::OnlyOnce.new
|
|
12
|
+
|
|
10
13
|
option :analytics_enabled, default: false
|
|
11
14
|
option :analytics_sample_rate, default: 1.0
|
|
12
15
|
option :enabled, default: true
|
|
@@ -14,7 +17,7 @@ module Datadog
|
|
|
14
17
|
option :tracer do |o|
|
|
15
18
|
o.delegate_to { Datadog.tracer }
|
|
16
19
|
o.on_set do |_value|
|
|
17
|
-
log_deprecation_warning
|
|
20
|
+
log_deprecation_warning
|
|
18
21
|
end
|
|
19
22
|
end
|
|
20
23
|
|
|
@@ -41,11 +44,9 @@ module Datadog
|
|
|
41
44
|
the correct tracer internally.
|
|
42
45
|
).freeze
|
|
43
46
|
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
do_once(method_name) do
|
|
48
|
-
Datadog.logger.warn("#{method_name}:#{DEPRECATION_WARNING}:#{caller.join("\n")}")
|
|
47
|
+
def log_deprecation_warning
|
|
48
|
+
DEPRECATION_WARN_ONLY_ONCE.run do
|
|
49
|
+
Datadog.logger.warn("tracer:#{DEPRECATION_WARNING}:#{caller.join("\n")}")
|
|
49
50
|
end
|
|
50
51
|
end
|
|
51
52
|
end
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
require 'ddtrace/contrib/configuration/settings'
|
|
2
|
+
require 'ddtrace/contrib/cucumber/ext'
|
|
3
|
+
|
|
4
|
+
module Datadog
|
|
5
|
+
module Contrib
|
|
6
|
+
module Cucumber
|
|
7
|
+
module Configuration
|
|
8
|
+
# Custom settings for the Cucumber integration
|
|
9
|
+
class Settings < Contrib::Configuration::Settings
|
|
10
|
+
option :enabled do |o|
|
|
11
|
+
o.default { env_to_bool(Ext::ENV_ENABLED, true) }
|
|
12
|
+
o.lazy
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
option :service_name do |o|
|
|
16
|
+
o.default { Datadog.configuration.service || Ext::SERVICE_NAME }
|
|
17
|
+
o.lazy
|
|
18
|
+
end
|
|
19
|
+
|
|
20
|
+
option :operation_name do |o|
|
|
21
|
+
o.default { ENV.key?(Ext::ENV_OPERATION_NAME) ? ENV[Ext::ENV_OPERATION_NAME] : Ext::OPERATION_NAME }
|
|
22
|
+
o.lazy
|
|
23
|
+
end
|
|
24
|
+
end
|
|
25
|
+
end
|
|
26
|
+
end
|
|
27
|
+
end
|
|
28
|
+
end
|