scout_apm 3.0.0.pre23 → 4.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (134) hide show
  1. checksums.yaml +5 -5
  2. data/.gitignore +1 -1
  3. data/.rubocop.yml +3 -4
  4. data/.travis.yml +17 -14
  5. data/CHANGELOG.markdown +150 -4
  6. data/Gemfile +2 -8
  7. data/README.markdown +30 -4
  8. data/Rakefile +1 -1
  9. data/ext/allocations/allocations.c +2 -0
  10. data/gems/README.md +28 -0
  11. data/gems/octoshark.gemfile +4 -0
  12. data/gems/rails3.gemfile +5 -0
  13. data/gems/rails4.gemfile +4 -0
  14. data/gems/rails5.gemfile +4 -0
  15. data/gems/rails6.gemfile +4 -0
  16. data/lib/scout_apm.rb +39 -9
  17. data/lib/scout_apm/agent.rb +29 -10
  18. data/lib/scout_apm/agent/exit_handler.rb +0 -1
  19. data/lib/scout_apm/agent_context.rb +26 -3
  20. data/lib/scout_apm/app_server_load.rb +7 -2
  21. data/lib/scout_apm/attribute_arranger.rb +0 -2
  22. data/lib/scout_apm/auto_instrument.rb +5 -0
  23. data/lib/scout_apm/auto_instrument/instruction_sequence.rb +31 -0
  24. data/lib/scout_apm/auto_instrument/layer.rb +23 -0
  25. data/lib/scout_apm/auto_instrument/parser.rb +27 -0
  26. data/lib/scout_apm/auto_instrument/rails.rb +175 -0
  27. data/lib/scout_apm/background_job_integrations/delayed_job.rb +1 -1
  28. data/lib/scout_apm/background_job_integrations/legacy_sneakers.rb +55 -0
  29. data/lib/scout_apm/background_job_integrations/que.rb +134 -0
  30. data/lib/scout_apm/background_job_integrations/resque.rb +6 -2
  31. data/lib/scout_apm/background_job_integrations/shoryuken.rb +124 -0
  32. data/lib/scout_apm/background_job_integrations/sidekiq.rb +5 -19
  33. data/lib/scout_apm/background_job_integrations/sneakers.rb +87 -0
  34. data/lib/scout_apm/config.rb +48 -7
  35. data/lib/scout_apm/detailed_trace.rb +217 -0
  36. data/lib/scout_apm/environment.rb +3 -0
  37. data/lib/scout_apm/error.rb +27 -0
  38. data/lib/scout_apm/error_service.rb +32 -0
  39. data/lib/scout_apm/error_service/error_buffer.rb +39 -0
  40. data/lib/scout_apm/error_service/error_record.rb +211 -0
  41. data/lib/scout_apm/error_service/ignored_exceptions.rb +66 -0
  42. data/lib/scout_apm/error_service/middleware.rb +32 -0
  43. data/lib/scout_apm/error_service/notifier.rb +33 -0
  44. data/lib/scout_apm/error_service/payload.rb +47 -0
  45. data/lib/scout_apm/error_service/periodic_work.rb +17 -0
  46. data/lib/scout_apm/error_service/railtie.rb +11 -0
  47. data/lib/scout_apm/error_service/sidekiq.rb +80 -0
  48. data/lib/scout_apm/extensions/transaction_callback_payload.rb +1 -1
  49. data/lib/scout_apm/fake_store.rb +3 -0
  50. data/lib/scout_apm/framework_integrations/rails_2.rb +2 -1
  51. data/lib/scout_apm/framework_integrations/rails_3_or_4.rb +17 -6
  52. data/lib/scout_apm/git_revision.rb +6 -3
  53. data/lib/scout_apm/instant/middleware.rb +2 -1
  54. data/lib/scout_apm/instrument_manager.rb +8 -7
  55. data/lib/scout_apm/instruments/action_controller_rails_2.rb +3 -1
  56. data/lib/scout_apm/instruments/action_controller_rails_3_rails4.rb +56 -55
  57. data/lib/scout_apm/instruments/action_view.rb +114 -26
  58. data/lib/scout_apm/instruments/active_record.rb +66 -19
  59. data/lib/scout_apm/instruments/http.rb +48 -0
  60. data/lib/scout_apm/instruments/memcached.rb +43 -0
  61. data/lib/scout_apm/instruments/mongoid.rb +9 -4
  62. data/lib/scout_apm/instruments/net_http.rb +8 -1
  63. data/lib/scout_apm/job_record.rb +4 -2
  64. data/lib/scout_apm/layaway_file.rb +4 -0
  65. data/lib/scout_apm/layer.rb +5 -56
  66. data/lib/scout_apm/layer_children_set.rb +15 -6
  67. data/lib/scout_apm/layer_converters/converter_base.rb +15 -30
  68. data/lib/scout_apm/layer_converters/database_converter.rb +2 -15
  69. data/lib/scout_apm/layer_converters/slow_job_converter.rb +12 -2
  70. data/lib/scout_apm/layer_converters/slow_request_converter.rb +14 -4
  71. data/lib/scout_apm/layer_converters/trace_converter.rb +184 -0
  72. data/lib/scout_apm/limited_layer.rb +0 -7
  73. data/lib/scout_apm/metric_stats.rb +0 -8
  74. data/lib/scout_apm/middleware.rb +1 -1
  75. data/lib/scout_apm/periodic_work.rb +19 -0
  76. data/lib/scout_apm/remote/message.rb +4 -0
  77. data/lib/scout_apm/reporter.rb +8 -3
  78. data/lib/scout_apm/reporting.rb +2 -1
  79. data/lib/scout_apm/request_histograms.rb +8 -0
  80. data/lib/scout_apm/serializers/app_server_load_serializer.rb +4 -0
  81. data/lib/scout_apm/serializers/directive_serializer.rb +4 -0
  82. data/lib/scout_apm/serializers/payload_serializer.rb +2 -2
  83. data/lib/scout_apm/serializers/payload_serializer_to_json.rb +30 -15
  84. data/lib/scout_apm/slow_job_record.rb +5 -1
  85. data/lib/scout_apm/slow_policy/age_policy.rb +33 -0
  86. data/lib/scout_apm/slow_policy/percent_policy.rb +22 -0
  87. data/lib/scout_apm/slow_policy/percentile_policy.rb +24 -0
  88. data/lib/scout_apm/slow_policy/policy.rb +21 -0
  89. data/lib/scout_apm/slow_policy/speed_policy.rb +16 -0
  90. data/lib/scout_apm/slow_request_policy.rb +18 -60
  91. data/lib/scout_apm/slow_transaction.rb +3 -1
  92. data/lib/scout_apm/store.rb +14 -10
  93. data/lib/scout_apm/tracked_request.rb +41 -30
  94. data/lib/scout_apm/transaction_time_consumed.rb +51 -0
  95. data/lib/scout_apm/utils/active_record_metric_name.rb +16 -3
  96. data/lib/scout_apm/utils/backtrace_parser.rb +3 -0
  97. data/lib/scout_apm/utils/marshal_logging.rb +90 -0
  98. data/lib/scout_apm/utils/sql_sanitizer.rb +10 -1
  99. data/lib/scout_apm/utils/sql_sanitizer_regex.rb +7 -0
  100. data/lib/scout_apm/utils/sql_sanitizer_regex_1_8_7.rb +6 -0
  101. data/lib/scout_apm/utils/unique_id.rb +27 -0
  102. data/lib/scout_apm/version.rb +1 -1
  103. data/scout_apm.gemspec +13 -7
  104. data/test/test_helper.rb +2 -2
  105. data/test/unit/agent_context_test.rb +29 -0
  106. data/test/unit/auto_instrument/assignments-instrumented.rb +31 -0
  107. data/test/unit/auto_instrument/assignments.rb +31 -0
  108. data/test/unit/auto_instrument/controller-ast.txt +57 -0
  109. data/test/unit/auto_instrument/controller-instrumented.rb +49 -0
  110. data/test/unit/auto_instrument/controller.rb +49 -0
  111. data/test/unit/auto_instrument/rescue_from-instrumented.rb +13 -0
  112. data/test/unit/auto_instrument/rescue_from.rb +13 -0
  113. data/test/unit/auto_instrument_test.rb +54 -0
  114. data/test/unit/error_service/error_buffer_test.rb +25 -0
  115. data/test/unit/error_service/ignored_exceptions_test.rb +49 -0
  116. data/test/unit/extensions/periodic_callbacks_test.rb +2 -2
  117. data/test/unit/instruments/active_record_test.rb +40 -0
  118. data/test/unit/layer_children_set_test.rb +9 -0
  119. data/test/unit/request_histograms_test.rb +17 -0
  120. data/test/unit/serializers/payload_serializer_test.rb +39 -5
  121. data/test/unit/slow_request_policy_test.rb +42 -9
  122. data/test/unit/sql_sanitizer_test.rb +47 -0
  123. data/test/unit/transaction_time_consumed_test.rb +46 -0
  124. data/test/unit/utils/active_record_metric_name_test.rb +10 -2
  125. metadata +101 -19
  126. data/ext/stacks/extconf.rb +0 -37
  127. data/ext/stacks/scout_atomics.h +0 -86
  128. data/ext/stacks/stacks.c +0 -814
  129. data/lib/scout_apm/slow_job_policy.rb +0 -94
  130. data/lib/scout_apm/trace_compactor.rb +0 -312
  131. data/lib/scout_apm/utils/fake_stacks.rb +0 -88
  132. data/test/unit/instruments/active_record_instruments_test.rb +0 -5
  133. data/test/unit/slow_job_policy_test.rb +0 -6
  134. data/tester.rb +0 -53
@@ -1,6 +1,7 @@
1
1
  require 'test_helper'
2
2
 
3
3
  require 'scout_apm/slow_request_policy'
4
+ require 'scout_apm/slow_policy/policy'
4
5
  require 'scout_apm/layer'
5
6
 
6
7
  class FakeRequest
@@ -16,30 +17,62 @@ class FakeRequest
16
17
  end
17
18
  end
18
19
 
20
+ class FixedPolicy < ScoutApm::SlowPolicy::Policy
21
+ attr_reader :stored
22
+
23
+ def initialize(x)
24
+ @x = x
25
+ end
26
+
27
+ def call(req)
28
+ @x
29
+ end
30
+
31
+ def stored!(req)
32
+ @stored = true
33
+ end
34
+ end
35
+
19
36
  class SlowRequestPolicyTest < Minitest::Test
20
37
  def setup
21
38
  @context = ScoutApm::AgentContext.new
22
39
  end
23
40
 
24
- def test_stored_records_current_time
41
+ def test_age_policy_stored_records_current_time
25
42
  test_start = Time.now
26
- policy = ScoutApm::SlowRequestPolicy.new(@context)
43
+ policy = ScoutApm::SlowPolicy::AgePolicy.new(@context)
27
44
  request = FakeRequest.new("users/index")
28
45
 
29
46
  policy.stored!(request)
30
47
  assert policy.last_seen[request.unique_name] > test_start
31
48
  end
32
49
 
33
- def test_score
50
+ def test_sums_up_score
51
+ policy = ScoutApm::SlowRequestPolicy.new(@context)
52
+ request = FakeRequest.new("users/index")
53
+
54
+ policy.add(FixedPolicy.new(1))
55
+ policy.add(FixedPolicy.new(2))
56
+
57
+ assert_equal 3, policy.score(request)
58
+ end
59
+
60
+ def test_calls_store_on_policies
34
61
  policy = ScoutApm::SlowRequestPolicy.new(@context)
35
62
  request = FakeRequest.new("users/index")
36
63
 
37
- request.set_duration(10) # 10 seconds
38
- policy.last_seen[request.unique_name] = Time.now - 120 # 2 minutes since last seen
39
- @context.request_histograms.add(request.unique_name, 1)
64
+ policy.add(fp1 = FixedPolicy.new(1))
65
+ policy.add(fp2 = FixedPolicy.new(2))
66
+ policy.stored!(request)
67
+
68
+ assert_equal true, fp1.stored
69
+ assert_equal true, fp2.stored
70
+ end
71
+
72
+ def test_checks_new_policy_api
73
+ policy = ScoutApm::SlowRequestPolicy.new(@context)
40
74
 
41
- # Actual value I have in console is 1.499
42
- assert policy.score(request) > 1.45
43
- assert policy.score(request) < 1.55
75
+ assert_raises { policy.add(Object.new) }
76
+ assert_raises { policy.add(->(req){1}) } # only implements call
44
77
  end
45
78
  end
@@ -28,7 +28,23 @@ module ScoutApm
28
28
  sql = %q|SELECT "users".* FROM "users" INNER JOIN "blogs" ON "blogs"."user_id" = "users"."id" WHERE (blogs.title = 'hello world')|
29
29
  ss = SqlSanitizer.new(sql).tap{ |it| it.database_engine = :postgres }
30
30
  assert_equal %q|SELECT "users".* FROM "users" INNER JOIN "blogs" ON "blogs"."user_id" = "users"."id" WHERE (blogs.title = ?)|, ss.to_s
31
+ end
32
+
33
+ def test_postgres_strips_after_where
34
+ raw_sql = %q|SELECT DISTINCT ON (flagged_traces.metric_name) flagged_traces.metric_name, "flagged_traces"."trace_id", "flagged_traces"."trace_type", "flagged_traces"."trace_occurred_at", flagged_traces.details ->> 'uri' as uri, (flagged_traces.details ->> 'n_sum_millis')::float as potential_savings, (flagged_traces.details ->> 'n_count')::float as num_queries FROM "flagged_traces" WHERE "flagged_traces"."app_id" = 5 AND "flagged_traces"."trace_type" = 'Request' AND ("flagged_traces"."trace_occurred_at" BETWEEN '2019-04-17 12:28:00.000000' AND '2019-04-18 12:28:00.000000') AND "flagged_traces"."flag_type" = 'nplusone' ORDER BY "flagged_traces"."metric_name" ASC, potential_savings DESC|
35
+ sanitized_sql = SqlSanitizer.new(raw_sql).tap { |it| it.database_engine = :postgres}
36
+ expected_sql = %q|SELECT DISTINCT ON (flagged_traces.metric_name) flagged_traces.metric_name, "flagged_traces"."trace_id", "flagged_traces"."trace_type", "flagged_traces"."trace_occurred_at", flagged_traces.details ->> 'uri' as uri, (flagged_traces.details ->> 'n_sum_millis')::float as potential_savings, (flagged_traces.details ->> 'n_count')::float as num_queries FROM "flagged_traces" WHERE "flagged_traces"."app_id" = ? AND "flagged_traces"."trace_type" = ? AND ("flagged_traces"."trace_occurred_at" BETWEEN ? AND ?) AND "flagged_traces"."flag_type" = ? ORDER BY "flagged_traces"."metric_name" ASC, potential_savings DESC|
37
+ assert_equal expected_sql, sanitized_sql.to_s
38
+ end
39
+
40
+ def test_postgres_strips_subquery_strings
41
+ raw_sql = %q|"SELECT 'orgs'.* FROM "orgs" WHERE "orgs"."name" = 'Scout' AND "orgs"."created_by_user_id" IN (SELECT 'users'.'id' FROM "users" WHERE (id > AVG(id)) AND "type" = 'USER' AND "created_at" BETWEEN '2019-04-17 12:28:00.000000' AND '2019-04-18 12:28:00.000000')"|
42
+ sanitized_sql = SqlSanitizer.new(raw_sql).tap { |it| it.database_engine = :postgres}
43
+ expected_sql = %q|"SELECT 'orgs'.* FROM "orgs" WHERE "orgs"."name" = ? AND "orgs"."created_by_user_id" IN (SELECT 'users'.'id' FROM "users" WHERE (id > AVG(id)) AND "type" = ? AND "created_at" BETWEEN ? AND ?)"|
44
+ assert_equal expected_sql, sanitized_sql.to_s
45
+ end
31
46
 
47
+ def test_postgres_strips_integers
32
48
  # Strip integers
33
49
  sql = %q|SELECT "blogs".* FROM "blogs" WHERE (view_count > 10)|
34
50
  ss = SqlSanitizer.new(sql).tap{ |it| it.database_engine = :postgres }
@@ -89,6 +105,30 @@ module ScoutApm
89
105
  assert_equal %q|INSERT INTO `users` VALUES (?, ?)|, ss.to_s
90
106
  end
91
107
 
108
+ def test_sqlserver_integers
109
+ skip "SQLServer Support requires Ruby 1.9+ For Regexes"
110
+
111
+ sql = "EXEC sp_executesql N'SELECT [users].* FROM [users] WHERE (age > 50) ORDER BY [users].[id] ASC OFFSET 0 ROWS FETCH NEXT @0 ROWS ONLY', N'@0 int', @0 = 10"
112
+ ss = SqlSanitizer.new(sql).tap{ |it| it.database_engine = :sqlserver }
113
+ assert_equal %q|SELECT [users].* FROM [users] WHERE (age > ?) ORDER BY [users].[id] ASC OFFSET ? ROWS FETCH NEXT @0 ROWS ONLY|, ss.to_s
114
+ end
115
+
116
+ def test_sqlserver_strings
117
+ skip "SQLServer Support requires Ruby 1.9+ For Regexes"
118
+
119
+ sql = "EXEC sp_executesql N'SELECT [users].* FROM [users] WHERE [users].[email] = @0 ORDER BY [users].[id] ASC OFFSET 0 ROWS FETCH NEXT @1 ROWS ONLY', N'@0 nvarchar(4000), @1 int', @0 = N'foo', @1 = 10"
120
+ ss = SqlSanitizer.new(sql).tap{ |it| it.database_engine = :sqlserver }
121
+ assert_equal %q|SELECT [users].* FROM [users] WHERE [users].[email] = @0 ORDER BY [users].[id] ASC OFFSET ? ROWS FETCH NEXT @1 ROWS ONLY|, ss.to_s
122
+ end
123
+
124
+ def test_sqlserver_in_clause
125
+ skip "SQLServer Support requires Ruby 1.9+ For Regexes"
126
+
127
+ sql = "EXEC sp_executesql N'SELECT [users].* FROM [users] WHERE (id IN (1,2,3)) ORDER BY [users].[id] ASC OFFSET 0 ROWS FETCH NEXT @0 ROWS ONLY', N'@0 int', @0 = 10"
128
+ ss = SqlSanitizer.new(sql).tap{ |it| it.database_engine = :sqlserver }
129
+ assert_equal %q|SELECT [users].* FROM [users] WHERE (id IN (?)) ORDER BY [users].[id] ASC OFFSET ? ROWS FETCH NEXT @0 ROWS ONLY|, ss.to_s
130
+ end
131
+
92
132
  def test_scrubs_invalid_encoding
93
133
  skip "Ruby 1.8.7 has no concept of encoding" if RUBY_VERSION.start_with?("1.8.")
94
134
 
@@ -99,6 +139,13 @@ module ScoutApm
99
139
  assert_equal %q|SELECT `blogs`.* FROM `blogs` WHERE (title = ?)|, ss.to_s
100
140
  end
101
141
 
142
+ def test_set_columns
143
+ sql = %q|UPDATE "mytable" SET "myfield" = 'fieldcontent', "countofthings" = 10 WHERE "user_id" = 10|
144
+
145
+ ss = SqlSanitizer.new(sql).tap{ |it| it.database_engine = :postgres }
146
+ assert_equal %q|UPDATE "mytable" SET "myfield" = ?, "countofthings" = ? WHERE "user_id" = ?|, ss.to_s
147
+ end
148
+
102
149
  def assert_faster_than(target_seconds)
103
150
  t1 = ::Time.now
104
151
  yield
@@ -0,0 +1,46 @@
1
+ require 'test_helper'
2
+
3
+ require 'scout_apm/transaction_time_consumed'
4
+
5
+ module ScoutApm
6
+ class TransactionTimeConsumedTest < Minitest::Test
7
+ def setup
8
+ @ttc = ScoutApm::TransactionTimeConsumed.new
9
+ end
10
+
11
+ def test_insert_new_times
12
+ @ttc.add("Controller/Foo", 1.5)
13
+ @ttc.add("Controller/Foo", 2.75)
14
+ assert_equal 4.25, @ttc.total_time_for("Controller/Foo")
15
+ end
16
+
17
+ def test_insert_tracks_endpoints_separately
18
+ @ttc.add("Controller/Foo", 1.5)
19
+ @ttc.add("Controller/Foo", 2.75)
20
+ @ttc.add("Controller/Bar", 5)
21
+ @ttc.add("Controller/Bar", 5)
22
+ assert_equal 4.25, @ttc.total_time_for("Controller/Foo")
23
+ assert_equal 10.0, @ttc.total_time_for("Controller/Bar")
24
+ end
25
+
26
+ def test_calculates_percent_of_total
27
+ @ttc.add("Controller/Foo", 1)
28
+ @ttc.add("Controller/Bar", 4)
29
+ assert_equal 0.2, @ttc.percent_of_total("Controller/Foo")
30
+ assert_equal 0.8, @ttc.percent_of_total("Controller/Bar")
31
+ end
32
+
33
+ def test_counts_total_call_count
34
+ @ttc.add("Controller/Foo", 1)
35
+ @ttc.add("Controller/Foo", 1)
36
+ @ttc.add("Controller/Foo", 1)
37
+ @ttc.add("Controller/Bar", 4)
38
+ assert_equal 3, @ttc.call_count_for("Controller/Foo")
39
+ assert_equal 1, @ttc.call_count_for("Controller/Bar")
40
+ end
41
+
42
+ def test_percent_of_total_is_0_with_no_data
43
+ assert_equal 0.0, @ttc.percent_of_total("Controller/Foo")
44
+ end
45
+ end
46
+ end
@@ -64,6 +64,16 @@ class ActiveRecordMetricNameTest < Minitest::Test
64
64
  assert_equal "User/find", mn.to_s
65
65
  end
66
66
 
67
+ def test_begin_statement
68
+ mn = ScoutApm::Utils::ActiveRecordMetricName.new("BEGIN", nil)
69
+ assert_equal "SQL/begin", mn.to_s
70
+ end
71
+
72
+ def test_commit
73
+ mn = ScoutApm::Utils::ActiveRecordMetricName.new("COMMIT", nil)
74
+ assert_equal "SQL/commit", mn.to_s
75
+ end
76
+
67
77
 
68
78
  # Regex test cases, pass these in w/ "SQL" as the AR provided name field
69
79
  [
@@ -89,8 +99,6 @@ class ActiveRecordMetricNameTest < Minitest::Test
89
99
  # Stuff we don't care about in SQL
90
100
  ["SQL/other", 'SET SESSION statement_timeout = ?'],
91
101
  ["SQL/other", 'SHOW TIME ZONE'],
92
- ["SQL/other", 'BEGIN'],
93
- ["SQL/other", 'COMMIT'],
94
102
 
95
103
  # Empty strings, or invalid SQL
96
104
  ["SQL/other", ''],
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: scout_apm
3
3
  version: !ruby/object:Gem::Version
4
- version: 3.0.0.pre23
4
+ version: 4.0.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Derek Haynes
@@ -9,7 +9,7 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2018-05-07 00:00:00.000000000 Z
12
+ date: 2020-11-25 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: minitest
@@ -109,6 +109,48 @@ dependencies:
109
109
  - - ">="
110
110
  - !ruby/object:Gem::Version
111
111
  version: '0'
112
+ - !ruby/object:Gem::Dependency
113
+ name: parser
114
+ requirement: !ruby/object:Gem::Requirement
115
+ requirements:
116
+ - - ">="
117
+ - !ruby/object:Gem::Version
118
+ version: '0'
119
+ type: :runtime
120
+ prerelease: false
121
+ version_requirements: !ruby/object:Gem::Requirement
122
+ requirements:
123
+ - - ">="
124
+ - !ruby/object:Gem::Version
125
+ version: '0'
126
+ - !ruby/object:Gem::Dependency
127
+ name: activerecord
128
+ requirement: !ruby/object:Gem::Requirement
129
+ requirements:
130
+ - - ">="
131
+ - !ruby/object:Gem::Version
132
+ version: '0'
133
+ type: :development
134
+ prerelease: false
135
+ version_requirements: !ruby/object:Gem::Requirement
136
+ requirements:
137
+ - - ">="
138
+ - !ruby/object:Gem::Version
139
+ version: '0'
140
+ - !ruby/object:Gem::Dependency
141
+ name: sqlite3
142
+ requirement: !ruby/object:Gem::Requirement
143
+ requirements:
144
+ - - ">="
145
+ - !ruby/object:Gem::Version
146
+ version: '0'
147
+ type: :development
148
+ prerelease: false
149
+ version_requirements: !ruby/object:Gem::Requirement
150
+ requirements:
151
+ - - ">="
152
+ - !ruby/object:Gem::Version
153
+ version: '0'
112
154
  - !ruby/object:Gem::Dependency
113
155
  name: rubocop
114
156
  requirement: !ruby/object:Gem::Requirement
@@ -171,7 +213,6 @@ email:
171
213
  executables: []
172
214
  extensions:
173
215
  - ext/allocations/extconf.rb
174
- - ext/stacks/extconf.rb
175
216
  - ext/rusage/extconf.rb
176
217
  extra_rdoc_files: []
177
218
  files:
@@ -190,9 +231,12 @@ files:
190
231
  - ext/rusage/README.md
191
232
  - ext/rusage/extconf.rb
192
233
  - ext/rusage/rusage.c
193
- - ext/stacks/extconf.rb
194
- - ext/stacks/scout_atomics.h
195
- - ext/stacks/stacks.c
234
+ - gems/README.md
235
+ - gems/octoshark.gemfile
236
+ - gems/rails3.gemfile
237
+ - gems/rails4.gemfile
238
+ - gems/rails5.gemfile
239
+ - gems/rails6.gemfile
196
240
  - lib/scout_apm.rb
197
241
  - lib/scout_apm/agent.rb
198
242
  - lib/scout_apm/agent/exit_handler.rb
@@ -200,9 +244,18 @@ files:
200
244
  - lib/scout_apm/agent_context.rb
201
245
  - lib/scout_apm/app_server_load.rb
202
246
  - lib/scout_apm/attribute_arranger.rb
247
+ - lib/scout_apm/auto_instrument.rb
248
+ - lib/scout_apm/auto_instrument/instruction_sequence.rb
249
+ - lib/scout_apm/auto_instrument/layer.rb
250
+ - lib/scout_apm/auto_instrument/parser.rb
251
+ - lib/scout_apm/auto_instrument/rails.rb
203
252
  - lib/scout_apm/background_job_integrations/delayed_job.rb
253
+ - lib/scout_apm/background_job_integrations/legacy_sneakers.rb
254
+ - lib/scout_apm/background_job_integrations/que.rb
204
255
  - lib/scout_apm/background_job_integrations/resque.rb
256
+ - lib/scout_apm/background_job_integrations/shoryuken.rb
205
257
  - lib/scout_apm/background_job_integrations/sidekiq.rb
258
+ - lib/scout_apm/background_job_integrations/sneakers.rb
206
259
  - lib/scout_apm/background_recorder.rb
207
260
  - lib/scout_apm/background_worker.rb
208
261
  - lib/scout_apm/bucket_name_splitter.rb
@@ -212,7 +265,19 @@ files:
212
265
  - lib/scout_apm/db_query_metric_set.rb
213
266
  - lib/scout_apm/db_query_metric_stats.rb
214
267
  - lib/scout_apm/debug.rb
268
+ - lib/scout_apm/detailed_trace.rb
215
269
  - lib/scout_apm/environment.rb
270
+ - lib/scout_apm/error.rb
271
+ - lib/scout_apm/error_service.rb
272
+ - lib/scout_apm/error_service/error_buffer.rb
273
+ - lib/scout_apm/error_service/error_record.rb
274
+ - lib/scout_apm/error_service/ignored_exceptions.rb
275
+ - lib/scout_apm/error_service/middleware.rb
276
+ - lib/scout_apm/error_service/notifier.rb
277
+ - lib/scout_apm/error_service/payload.rb
278
+ - lib/scout_apm/error_service/periodic_work.rb
279
+ - lib/scout_apm/error_service/railtie.rb
280
+ - lib/scout_apm/error_service/sidekiq.rb
216
281
  - lib/scout_apm/extensions/config.rb
217
282
  - lib/scout_apm/extensions/transaction_callback_payload.rb
218
283
  - lib/scout_apm/fake_store.rb
@@ -227,15 +292,16 @@ files:
227
292
  - lib/scout_apm/instant/middleware.rb
228
293
  - lib/scout_apm/instant_reporting.rb
229
294
  - lib/scout_apm/instrument_manager.rb
230
- - lib/scout_apm/instruments/.DS_Store
231
295
  - lib/scout_apm/instruments/action_controller_rails_2.rb
232
296
  - lib/scout_apm/instruments/action_controller_rails_3_rails4.rb
233
297
  - lib/scout_apm/instruments/action_view.rb
234
298
  - lib/scout_apm/instruments/active_record.rb
235
299
  - lib/scout_apm/instruments/elasticsearch.rb
236
300
  - lib/scout_apm/instruments/grape.rb
301
+ - lib/scout_apm/instruments/http.rb
237
302
  - lib/scout_apm/instruments/http_client.rb
238
303
  - lib/scout_apm/instruments/influxdb.rb
304
+ - lib/scout_apm/instruments/memcached.rb
239
305
  - lib/scout_apm/instruments/middleware_detailed.rb
240
306
  - lib/scout_apm/instruments/middleware_summary.rb
241
307
  - lib/scout_apm/instruments/mongoid.rb
@@ -266,6 +332,7 @@ files:
266
332
  - lib/scout_apm/layer_converters/request_queue_time_converter.rb
267
333
  - lib/scout_apm/layer_converters/slow_job_converter.rb
268
334
  - lib/scout_apm/layer_converters/slow_request_converter.rb
335
+ - lib/scout_apm/layer_converters/trace_converter.rb
269
336
  - lib/scout_apm/limited_layer.rb
270
337
  - lib/scout_apm/logger.rb
271
338
  - lib/scout_apm/metric_meta.rb
@@ -302,8 +369,12 @@ files:
302
369
  - lib/scout_apm/server_integrations/thin.rb
303
370
  - lib/scout_apm/server_integrations/unicorn.rb
304
371
  - lib/scout_apm/server_integrations/webrick.rb
305
- - lib/scout_apm/slow_job_policy.rb
306
372
  - lib/scout_apm/slow_job_record.rb
373
+ - lib/scout_apm/slow_policy/age_policy.rb
374
+ - lib/scout_apm/slow_policy/percent_policy.rb
375
+ - lib/scout_apm/slow_policy/percentile_policy.rb
376
+ - lib/scout_apm/slow_policy/policy.rb
377
+ - lib/scout_apm/slow_policy/speed_policy.rb
307
378
  - lib/scout_apm/slow_request_policy.rb
308
379
  - lib/scout_apm/slow_transaction.rb
309
380
  - lib/scout_apm/stack_item.rb
@@ -311,16 +382,16 @@ files:
311
382
  - lib/scout_apm/synchronous_recorder.rb
312
383
  - lib/scout_apm/tasks/doctor.rb
313
384
  - lib/scout_apm/tasks/support.rb
314
- - lib/scout_apm/trace_compactor.rb
315
385
  - lib/scout_apm/tracer.rb
316
386
  - lib/scout_apm/tracked_request.rb
317
387
  - lib/scout_apm/transaction.rb
388
+ - lib/scout_apm/transaction_time_consumed.rb
318
389
  - lib/scout_apm/utils/active_record_metric_name.rb
319
390
  - lib/scout_apm/utils/backtrace_parser.rb
320
- - lib/scout_apm/utils/fake_stacks.rb
321
391
  - lib/scout_apm/utils/gzip_helper.rb
322
392
  - lib/scout_apm/utils/installed_gems.rb
323
393
  - lib/scout_apm/utils/klass_helper.rb
394
+ - lib/scout_apm/utils/marshal_logging.rb
324
395
  - lib/scout_apm/utils/numbers.rb
325
396
  - lib/scout_apm/utils/scm.rb
326
397
  - lib/scout_apm/utils/sql_sanitizer.rb
@@ -333,20 +404,32 @@ files:
333
404
  - scout_apm.gemspec
334
405
  - test/data/config_test_1.yml
335
406
  - test/test_helper.rb
407
+ - test/tmp/README.md
408
+ - test/unit/agent_context_test.rb
336
409
  - test/unit/agent_test.rb
410
+ - test/unit/auto_instrument/assignments-instrumented.rb
411
+ - test/unit/auto_instrument/assignments.rb
412
+ - test/unit/auto_instrument/controller-ast.txt
413
+ - test/unit/auto_instrument/controller-instrumented.rb
414
+ - test/unit/auto_instrument/controller.rb
415
+ - test/unit/auto_instrument/rescue_from-instrumented.rb
416
+ - test/unit/auto_instrument/rescue_from.rb
417
+ - test/unit/auto_instrument_test.rb
337
418
  - test/unit/background_job_integrations/sidekiq_test.rb
338
419
  - test/unit/config_test.rb
339
420
  - test/unit/context_test.rb
340
421
  - test/unit/db_query_metric_set_test.rb
341
422
  - test/unit/db_query_metric_stats_test.rb
342
423
  - test/unit/environment_test.rb
424
+ - test/unit/error_service/error_buffer_test.rb
425
+ - test/unit/error_service/ignored_exceptions_test.rb
343
426
  - test/unit/extensions/periodic_callbacks_test.rb
344
427
  - test/unit/extensions/transaction_callbacks_test.rb
345
428
  - test/unit/fake_store_test.rb
346
429
  - test/unit/git_revision_test.rb
347
430
  - test/unit/histogram_test.rb
348
431
  - test/unit/ignored_uris_test.rb
349
- - test/unit/instruments/active_record_instruments_test.rb
432
+ - test/unit/instruments/active_record_test.rb
350
433
  - test/unit/instruments/net_http_test.rb
351
434
  - test/unit/instruments/percentile_sampler_test.rb
352
435
  - test/unit/layaway_test.rb
@@ -360,20 +443,20 @@ files:
360
443
  - test/unit/remote/test_message.rb
361
444
  - test/unit/remote/test_router.rb
362
445
  - test/unit/remote/test_server.rb
446
+ - test/unit/request_histograms_test.rb
363
447
  - test/unit/scored_item_set_test.rb
364
448
  - test/unit/serializers/payload_serializer_test.rb
365
- - test/unit/slow_job_policy_test.rb
366
449
  - test/unit/slow_request_policy_test.rb
367
450
  - test/unit/sql_sanitizer_test.rb
368
451
  - test/unit/store_test.rb
369
452
  - test/unit/tracer_test.rb
370
453
  - test/unit/tracked_request_test.rb
371
454
  - test/unit/transaction_test.rb
455
+ - test/unit/transaction_time_consumed_test.rb
372
456
  - test/unit/utils/active_record_metric_name_test.rb
373
457
  - test/unit/utils/backtrace_parser_test.rb
374
458
  - test/unit/utils/numbers_test.rb
375
459
  - test/unit/utils/scm.rb
376
- - tester.rb
377
460
  homepage: https://github.com/scoutapp/scout_apm_ruby
378
461
  licenses:
379
462
  - Proprietary (See LICENSE.md)
@@ -385,17 +468,16 @@ require_paths:
385
468
  - data
386
469
  required_ruby_version: !ruby/object:Gem::Requirement
387
470
  requirements:
388
- - - ">="
471
+ - - "~>"
389
472
  - !ruby/object:Gem::Version
390
- version: '0'
473
+ version: '2.1'
391
474
  required_rubygems_version: !ruby/object:Gem::Requirement
392
475
  requirements:
393
- - - ">"
476
+ - - ">="
394
477
  - !ruby/object:Gem::Version
395
- version: 1.3.1
478
+ version: '0'
396
479
  requirements: []
397
- rubyforge_project: scout_apm
398
- rubygems_version: 2.6.12
480
+ rubygems_version: 3.0.3
399
481
  signing_key:
400
482
  specification_version: 4
401
483
  summary: Ruby application performance monitoring