bugsnag 6.15.0 → 6.16.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (646) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +26 -0
  3. data/VERSION +1 -1
  4. data/bugsnag.gemspec +1 -1
  5. data/lib/bugsnag.rb +20 -10
  6. data/lib/bugsnag/configuration.rb +49 -1
  7. data/lib/bugsnag/delivery/thread_queue.rb +18 -3
  8. data/lib/bugsnag/integrations/delayed_job.rb +13 -1
  9. data/lib/bugsnag/integrations/mailman.rb +2 -1
  10. data/lib/bugsnag/integrations/que.rb +2 -1
  11. data/lib/bugsnag/integrations/rack.rb +3 -1
  12. data/lib/bugsnag/integrations/railtie.rb +17 -5
  13. data/lib/bugsnag/integrations/rake.rb +4 -2
  14. data/lib/bugsnag/integrations/resque.rb +2 -2
  15. data/lib/bugsnag/integrations/shoryuken.rb +2 -1
  16. data/lib/bugsnag/integrations/sidekiq.rb +1 -1
  17. data/lib/bugsnag/middleware/delayed_job.rb +1 -0
  18. metadata +2 -630
  19. data/.buildkite/pipeline.yml +0 -470
  20. data/.github/PULL_REQUEST_TEMPLATE.md +0 -84
  21. data/.gitignore +0 -55
  22. data/.rdoc_options +0 -27
  23. data/.rspec +0 -3
  24. data/.rubocop.yml +0 -57
  25. data/.rubocop_todo.yml +0 -1049
  26. data/CONTRIBUTING.md +0 -64
  27. data/Gemfile +0 -50
  28. data/Rakefile +0 -37
  29. data/TESTING.md +0 -81
  30. data/UPGRADING.md +0 -91
  31. data/docker-compose.yml +0 -46
  32. data/dockerfiles/Dockerfile.jruby-unit-tests +0 -13
  33. data/dockerfiles/Dockerfile.ruby-maze-runner +0 -26
  34. data/dockerfiles/Dockerfile.ruby-unit-tests +0 -12
  35. data/features/.gitignore +0 -1
  36. data/features/delayed_job.feature +0 -36
  37. data/features/fixtures/delayed_job/Dockerfile +0 -15
  38. data/features/fixtures/delayed_job/app/.gitignore +0 -21
  39. data/features/fixtures/delayed_job/app/Gemfile +0 -57
  40. data/features/fixtures/delayed_job/app/README.md +0 -24
  41. data/features/fixtures/delayed_job/app/Rakefile +0 -24
  42. data/features/fixtures/delayed_job/app/app/assets/config/manifest.js +0 -3
  43. data/features/fixtures/delayed_job/app/app/assets/images/.keep +0 -0
  44. data/features/fixtures/delayed_job/app/app/assets/javascripts/application.js +0 -16
  45. data/features/fixtures/delayed_job/app/app/assets/javascripts/cable.js +0 -13
  46. data/features/fixtures/delayed_job/app/app/assets/javascripts/channels/.keep +0 -0
  47. data/features/fixtures/delayed_job/app/app/assets/stylesheets/application.css +0 -15
  48. data/features/fixtures/delayed_job/app/app/channels/application_cable/channel.rb +0 -4
  49. data/features/fixtures/delayed_job/app/app/channels/application_cable/connection.rb +0 -4
  50. data/features/fixtures/delayed_job/app/app/controllers/application_controller.rb +0 -3
  51. data/features/fixtures/delayed_job/app/app/controllers/concerns/.keep +0 -0
  52. data/features/fixtures/delayed_job/app/app/helpers/application_helper.rb +0 -2
  53. data/features/fixtures/delayed_job/app/app/jobs/application_job.rb +0 -2
  54. data/features/fixtures/delayed_job/app/app/mailers/application_mailer.rb +0 -4
  55. data/features/fixtures/delayed_job/app/app/models/application_record.rb +0 -3
  56. data/features/fixtures/delayed_job/app/app/models/concerns/.keep +0 -0
  57. data/features/fixtures/delayed_job/app/app/models/test_model.rb +0 -10
  58. data/features/fixtures/delayed_job/app/app/views/layouts/application.html.erb +0 -14
  59. data/features/fixtures/delayed_job/app/app/views/layouts/mailer.html.erb +0 -13
  60. data/features/fixtures/delayed_job/app/app/views/layouts/mailer.text.erb +0 -1
  61. data/features/fixtures/delayed_job/app/config.ru +0 -5
  62. data/features/fixtures/delayed_job/app/config/application.rb +0 -15
  63. data/features/fixtures/delayed_job/app/config/boot.rb +0 -3
  64. data/features/fixtures/delayed_job/app/config/cable.yml +0 -9
  65. data/features/fixtures/delayed_job/app/config/database.yml +0 -25
  66. data/features/fixtures/delayed_job/app/config/environment.rb +0 -5
  67. data/features/fixtures/delayed_job/app/config/environments/development.rb +0 -54
  68. data/features/fixtures/delayed_job/app/config/environments/production.rb +0 -86
  69. data/features/fixtures/delayed_job/app/config/environments/test.rb +0 -42
  70. data/features/fixtures/delayed_job/app/config/initializers/application_controller_renderer.rb +0 -8
  71. data/features/fixtures/delayed_job/app/config/initializers/assets.rb +0 -11
  72. data/features/fixtures/delayed_job/app/config/initializers/backtrace_silencers.rb +0 -7
  73. data/features/fixtures/delayed_job/app/config/initializers/bugsnag.rb +0 -14
  74. data/features/fixtures/delayed_job/app/config/initializers/cookies_serializer.rb +0 -5
  75. data/features/fixtures/delayed_job/app/config/initializers/delayed_job.rb +0 -3
  76. data/features/fixtures/delayed_job/app/config/initializers/filter_parameter_logging.rb +0 -4
  77. data/features/fixtures/delayed_job/app/config/initializers/inflections.rb +0 -16
  78. data/features/fixtures/delayed_job/app/config/initializers/mime_types.rb +0 -4
  79. data/features/fixtures/delayed_job/app/config/initializers/new_framework_defaults.rb +0 -26
  80. data/features/fixtures/delayed_job/app/config/initializers/session_store.rb +0 -3
  81. data/features/fixtures/delayed_job/app/config/initializers/wrap_parameters.rb +0 -14
  82. data/features/fixtures/delayed_job/app/config/locales/en.yml +0 -23
  83. data/features/fixtures/delayed_job/app/config/puma.rb +0 -47
  84. data/features/fixtures/delayed_job/app/config/routes.rb +0 -3
  85. data/features/fixtures/delayed_job/app/config/secrets.yml +0 -22
  86. data/features/fixtures/delayed_job/app/config/spring.rb +0 -6
  87. data/features/fixtures/delayed_job/app/db/migrate/20181024232549_create_delayed_jobs.rb +0 -22
  88. data/features/fixtures/delayed_job/app/db/migrate/20181024232817_create_test_models.rb +0 -8
  89. data/features/fixtures/delayed_job/app/db/schema.rb +0 -30
  90. data/features/fixtures/delayed_job/app/db/seeds.rb +0 -7
  91. data/features/fixtures/delayed_job/app/lib/assets/.keep +0 -0
  92. data/features/fixtures/delayed_job/app/lib/tasks/.keep +0 -0
  93. data/features/fixtures/delayed_job/app/log/.keep +0 -0
  94. data/features/fixtures/delayed_job/app/public/404.html +0 -67
  95. data/features/fixtures/delayed_job/app/public/422.html +0 -67
  96. data/features/fixtures/delayed_job/app/public/500.html +0 -66
  97. data/features/fixtures/delayed_job/app/public/apple-touch-icon-precomposed.png +0 -0
  98. data/features/fixtures/delayed_job/app/public/apple-touch-icon.png +0 -0
  99. data/features/fixtures/delayed_job/app/public/favicon.ico +0 -0
  100. data/features/fixtures/delayed_job/app/public/robots.txt +0 -5
  101. data/features/fixtures/delayed_job/app/test/controllers/.keep +0 -0
  102. data/features/fixtures/delayed_job/app/test/fixtures/.keep +0 -0
  103. data/features/fixtures/delayed_job/app/test/fixtures/files/.keep +0 -0
  104. data/features/fixtures/delayed_job/app/test/fixtures/test_models.yml +0 -11
  105. data/features/fixtures/delayed_job/app/test/helpers/.keep +0 -0
  106. data/features/fixtures/delayed_job/app/test/integration/.keep +0 -0
  107. data/features/fixtures/delayed_job/app/test/mailers/.keep +0 -0
  108. data/features/fixtures/delayed_job/app/test/models/.keep +0 -0
  109. data/features/fixtures/delayed_job/app/test/models/test_model_test.rb +0 -7
  110. data/features/fixtures/delayed_job/app/test/test_helper.rb +0 -10
  111. data/features/fixtures/delayed_job/app/tmp/.keep +0 -0
  112. data/features/fixtures/docker-compose.yml +0 -303
  113. data/features/fixtures/expected_breadcrumbs/active_job.json +0 -9
  114. data/features/fixtures/expected_breadcrumbs/mongo_failed.json +0 -15
  115. data/features/fixtures/expected_breadcrumbs/mongo_filtered_request.json +0 -15
  116. data/features/fixtures/expected_breadcrumbs/mongo_filtered_result.json +0 -15
  117. data/features/fixtures/expected_breadcrumbs/mongo_success.json +0 -14
  118. data/features/fixtures/expected_breadcrumbs/request.json +0 -13
  119. data/features/fixtures/expected_breadcrumbs/sql_with_bindings.json +0 -12
  120. data/features/fixtures/expected_breadcrumbs/sql_without_bindings.json +0 -11
  121. data/features/fixtures/plain/.dockerignore +0 -2
  122. data/features/fixtures/plain/Dockerfile +0 -11
  123. data/features/fixtures/plain/app/Gemfile +0 -3
  124. data/features/fixtures/plain/app/app.rb +0 -38
  125. data/features/fixtures/plain/app/configuration/api_key.rb +0 -9
  126. data/features/fixtures/plain/app/configuration/proxy.rb +0 -14
  127. data/features/fixtures/plain/app/configuration/send_handled.rb +0 -7
  128. data/features/fixtures/plain/app/configuration/send_unhandled.rb +0 -9
  129. data/features/fixtures/plain/app/delivery/fork_threadpool.rb +0 -27
  130. data/features/fixtures/plain/app/delivery/synchronous.rb +0 -14
  131. data/features/fixtures/plain/app/delivery/threadpool.rb +0 -14
  132. data/features/fixtures/plain/app/exception_data/crash.rb +0 -34
  133. data/features/fixtures/plain/app/exception_data/handled_context.rb +0 -10
  134. data/features/fixtures/plain/app/exception_data/handled_hash.rb +0 -10
  135. data/features/fixtures/plain/app/exception_data/handled_meta_data.rb +0 -10
  136. data/features/fixtures/plain/app/exception_data/handled_user_id.rb +0 -10
  137. data/features/fixtures/plain/app/exception_data/unhandled_context.rb +0 -7
  138. data/features/fixtures/plain/app/exception_data/unhandled_hash.rb +0 -7
  139. data/features/fixtures/plain/app/exception_data/unhandled_meta_data.rb +0 -7
  140. data/features/fixtures/plain/app/exception_data/unhandled_user_id.rb +0 -7
  141. data/features/fixtures/plain/app/filters/additional_filters.rb +0 -11
  142. data/features/fixtures/plain/app/filters/default_filters.rb +0 -15
  143. data/features/fixtures/plain/app/handled/block_metadata.rb +0 -15
  144. data/features/fixtures/plain/app/handled/ignore_exception.rb +0 -12
  145. data/features/fixtures/plain/app/handled/notify_exception.rb +0 -9
  146. data/features/fixtures/plain/app/handled/notify_string.rb +0 -9
  147. data/features/fixtures/plain/app/ignore_classes/handled.rb +0 -8
  148. data/features/fixtures/plain/app/ignore_classes/ignore_error.rb +0 -8
  149. data/features/fixtures/plain/app/ignore_classes/unhandled.rb +0 -4
  150. data/features/fixtures/plain/app/report_modification/add_tab.rb +0 -16
  151. data/features/fixtures/plain/app/report_modification/add_tab_existing.rb +0 -22
  152. data/features/fixtures/plain/app/report_modification/add_tab_override.rb +0 -19
  153. data/features/fixtures/plain/app/report_modification/ignore_report.rb +0 -9
  154. data/features/fixtures/plain/app/report_modification/initiators/handled_before_notify.rb +0 -10
  155. data/features/fixtures/plain/app/report_modification/initiators/handled_block.rb +0 -8
  156. data/features/fixtures/plain/app/report_modification/initiators/handled_on_error.rb +0 -10
  157. data/features/fixtures/plain/app/report_modification/initiators/unhandled_before_notify.rb +0 -11
  158. data/features/fixtures/plain/app/report_modification/initiators/unhandled_on_error.rb +0 -11
  159. data/features/fixtures/plain/app/report_modification/modify_api_key.rb +0 -9
  160. data/features/fixtures/plain/app/report_modification/modify_severity.rb +0 -9
  161. data/features/fixtures/plain/app/report_modification/remove_user_details.rb +0 -14
  162. data/features/fixtures/plain/app/report_modification/set_custom_user_details.rb +0 -16
  163. data/features/fixtures/plain/app/report_modification/set_user_details.rb +0 -13
  164. data/features/fixtures/plain/app/stack_frame_modification/initiators/handled_before_notify.rb +0 -29
  165. data/features/fixtures/plain/app/stack_frame_modification/initiators/handled_block.rb +0 -24
  166. data/features/fixtures/plain/app/stack_frame_modification/initiators/handled_on_error.rb +0 -29
  167. data/features/fixtures/plain/app/stack_frame_modification/initiators/unhandled_before_notify.rb +0 -26
  168. data/features/fixtures/plain/app/stack_frame_modification/initiators/unhandled_on_error.rb +0 -26
  169. data/features/fixtures/plain/app/stack_frame_modification/mark_frames_in_project.rb +0 -13
  170. data/features/fixtures/plain/app/stack_frame_modification/remove_stack_frame.rb +0 -9
  171. data/features/fixtures/plain/app/unhandled/bad_syntax.rb +0 -1
  172. data/features/fixtures/plain/app/unhandled/custom_error.rb +0 -9
  173. data/features/fixtures/plain/app/unhandled/interrupt.rb +0 -6
  174. data/features/fixtures/plain/app/unhandled/load_error.rb +0 -6
  175. data/features/fixtures/plain/app/unhandled/local_jump_error.rb +0 -10
  176. data/features/fixtures/plain/app/unhandled/name_error.rb +0 -6
  177. data/features/fixtures/plain/app/unhandled/no_method_error.rb +0 -6
  178. data/features/fixtures/plain/app/unhandled/runtime_error.rb +0 -6
  179. data/features/fixtures/plain/app/unhandled/syntax_error.rb +0 -6
  180. data/features/fixtures/plain/app/unhandled/system_call_error.rb +0 -6
  181. data/features/fixtures/plain/app/unhandled/system_exit.rb +0 -6
  182. data/features/fixtures/plain/json/delivery_fork.json +0 -4
  183. data/features/fixtures/plain/json/delivery_synchronous.json +0 -4
  184. data/features/fixtures/plain/json/delivery_threadpool.json +0 -4
  185. data/features/fixtures/plain/json/filters_default_metadata_filters.json +0 -9
  186. data/features/fixtures/rack1/.dockerignore +0 -1
  187. data/features/fixtures/rack1/Dockerfile +0 -13
  188. data/features/fixtures/rack1/Gemfile +0 -4
  189. data/features/fixtures/rack1/app.rb +0 -8
  190. data/features/fixtures/rack2/.dockerignore +0 -1
  191. data/features/fixtures/rack2/Dockerfile +0 -13
  192. data/features/fixtures/rack2/Gemfile +0 -4
  193. data/features/fixtures/rack2/app.rb +0 -8
  194. data/features/fixtures/rails3/.dockerignore +0 -1
  195. data/features/fixtures/rails3/Dockerfile +0 -15
  196. data/features/fixtures/rails3/app/.gitignore +0 -15
  197. data/features/fixtures/rails3/app/Gemfile +0 -17
  198. data/features/fixtures/rails3/app/Rakefile +0 -7
  199. data/features/fixtures/rails3/app/app/assets/images/rails.png +0 -0
  200. data/features/fixtures/rails3/app/app/assets/javascripts/application.js +0 -15
  201. data/features/fixtures/rails3/app/app/assets/stylesheets/application.css +0 -13
  202. data/features/fixtures/rails3/app/app/controllers/api_key_controller.rb +0 -20
  203. data/features/fixtures/rails3/app/app/controllers/app_type_controller.rb +0 -20
  204. data/features/fixtures/rails3/app/app/controllers/app_version_controller.rb +0 -25
  205. data/features/fixtures/rails3/app/app/controllers/application_controller.rb +0 -7
  206. data/features/fixtures/rails3/app/app/controllers/auto_notify_controller.rb +0 -31
  207. data/features/fixtures/rails3/app/app/controllers/before_notify_controller.rb +0 -44
  208. data/features/fixtures/rails3/app/app/controllers/breadcrumbs_controller.rb +0 -19
  209. data/features/fixtures/rails3/app/app/controllers/handled_controller.rb +0 -26
  210. data/features/fixtures/rails3/app/app/controllers/ignore_classes_controller.rb +0 -23
  211. data/features/fixtures/rails3/app/app/controllers/metadata_filters_controller.rb +0 -16
  212. data/features/fixtures/rails3/app/app/controllers/project_root_controller.rb +0 -25
  213. data/features/fixtures/rails3/app/app/controllers/release_stage_controller.rb +0 -20
  214. data/features/fixtures/rails3/app/app/controllers/send_code_controller.rb +0 -20
  215. data/features/fixtures/rails3/app/app/controllers/send_environment_controller.rb +0 -12
  216. data/features/fixtures/rails3/app/app/controllers/session_tracking_controller.rb +0 -24
  217. data/features/fixtures/rails3/app/app/controllers/unhandled_controller.rb +0 -11
  218. data/features/fixtures/rails3/app/app/controllers/warden_controller.rb +0 -30
  219. data/features/fixtures/rails3/app/app/helpers/application_helper.rb +0 -2
  220. data/features/fixtures/rails3/app/app/mailers/.gitkeep +0 -0
  221. data/features/fixtures/rails3/app/app/models/.gitkeep +0 -0
  222. data/features/fixtures/rails3/app/app/models/user.rb +0 -6
  223. data/features/fixtures/rails3/app/app/views/layouts/application.html.erb +0 -14
  224. data/features/fixtures/rails3/app/config.ru +0 -4
  225. data/features/fixtures/rails3/app/config/application.rb +0 -67
  226. data/features/fixtures/rails3/app/config/boot.rb +0 -6
  227. data/features/fixtures/rails3/app/config/database.yml +0 -31
  228. data/features/fixtures/rails3/app/config/environment.rb +0 -5
  229. data/features/fixtures/rails3/app/config/environments/development.rb +0 -37
  230. data/features/fixtures/rails3/app/config/environments/production.rb +0 -67
  231. data/features/fixtures/rails3/app/config/environments/rails_env.rb +0 -37
  232. data/features/fixtures/rails3/app/config/initializers/bugsnag.rb +0 -29
  233. data/features/fixtures/rails3/app/config/initializers/secret_token.rb +0 -7
  234. data/features/fixtures/rails3/app/config/initializers/session_store.rb +0 -8
  235. data/features/fixtures/rails3/app/config/initializers/warden.rb +0 -3
  236. data/features/fixtures/rails3/app/config/initializers/wrap_parameters.rb +0 -14
  237. data/features/fixtures/rails3/app/config/locales/en.yml +0 -5
  238. data/features/fixtures/rails3/app/config/routes.rb +0 -19
  239. data/features/fixtures/rails3/app/db/migrate/20180423142727_create_users.rb +0 -45
  240. data/features/fixtures/rails3/app/db/schema.rb +0 -37
  241. data/features/fixtures/rails3/app/db/seeds.rb +0 -7
  242. data/features/fixtures/rails3/app/lib/assets/.gitkeep +0 -0
  243. data/features/fixtures/rails3/app/lib/strategies/token_strategy.rb +0 -12
  244. data/features/fixtures/rails3/app/lib/tasks/.gitkeep +0 -0
  245. data/features/fixtures/rails3/app/log/.gitkeep +0 -0
  246. data/features/fixtures/rails3/app/public/404.html +0 -26
  247. data/features/fixtures/rails3/app/public/422.html +0 -26
  248. data/features/fixtures/rails3/app/public/500.html +0 -25
  249. data/features/fixtures/rails3/app/public/favicon.ico +0 -0
  250. data/features/fixtures/rails3/app/public/index.html +0 -241
  251. data/features/fixtures/rails3/app/public/robots.txt +0 -5
  252. data/features/fixtures/rails3/app/script/rails +0 -6
  253. data/features/fixtures/rails4/.dockerignore +0 -1
  254. data/features/fixtures/rails4/Dockerfile +0 -17
  255. data/features/fixtures/rails4/app/.gitignore +0 -16
  256. data/features/fixtures/rails4/app/Gemfile +0 -46
  257. data/features/fixtures/rails4/app/README.rdoc +0 -28
  258. data/features/fixtures/rails4/app/Rakefile +0 -6
  259. data/features/fixtures/rails4/app/app/assets/images/.keep +0 -0
  260. data/features/fixtures/rails4/app/app/assets/javascripts/application.js +0 -16
  261. data/features/fixtures/rails4/app/app/assets/stylesheets/application.css +0 -13
  262. data/features/fixtures/rails4/app/app/controllers/api_key_controller.rb +0 -20
  263. data/features/fixtures/rails4/app/app/controllers/app_type_controller.rb +0 -20
  264. data/features/fixtures/rails4/app/app/controllers/app_version_controller.rb +0 -25
  265. data/features/fixtures/rails4/app/app/controllers/application_controller.rb +0 -7
  266. data/features/fixtures/rails4/app/app/controllers/auto_notify_controller.rb +0 -31
  267. data/features/fixtures/rails4/app/app/controllers/before_notify_controller.rb +0 -44
  268. data/features/fixtures/rails4/app/app/controllers/breadcrumbs_controller.rb +0 -26
  269. data/features/fixtures/rails4/app/app/controllers/concerns/.keep +0 -0
  270. data/features/fixtures/rails4/app/app/controllers/devise_controller.rb +0 -32
  271. data/features/fixtures/rails4/app/app/controllers/handled_controller.rb +0 -26
  272. data/features/fixtures/rails4/app/app/controllers/ignore_classes_controller.rb +0 -23
  273. data/features/fixtures/rails4/app/app/controllers/metadata_filters_controller.rb +0 -16
  274. data/features/fixtures/rails4/app/app/controllers/mongo_controller.rb +0 -23
  275. data/features/fixtures/rails4/app/app/controllers/project_root_controller.rb +0 -25
  276. data/features/fixtures/rails4/app/app/controllers/release_stage_controller.rb +0 -20
  277. data/features/fixtures/rails4/app/app/controllers/send_code_controller.rb +0 -20
  278. data/features/fixtures/rails4/app/app/controllers/send_environment_controller.rb +0 -12
  279. data/features/fixtures/rails4/app/app/controllers/session_tracking_controller.rb +0 -24
  280. data/features/fixtures/rails4/app/app/controllers/unhandled_controller.rb +0 -11
  281. data/features/fixtures/rails4/app/app/helpers/application_helper.rb +0 -2
  282. data/features/fixtures/rails4/app/app/jobs/application_job.rb +0 -2
  283. data/features/fixtures/rails4/app/app/jobs/notify_job.rb +0 -5
  284. data/features/fixtures/rails4/app/app/mailers/.keep +0 -0
  285. data/features/fixtures/rails4/app/app/models/.keep +0 -0
  286. data/features/fixtures/rails4/app/app/models/concerns/.keep +0 -0
  287. data/features/fixtures/rails4/app/app/models/mongo_model.rb +0 -6
  288. data/features/fixtures/rails4/app/app/models/user.rb +0 -6
  289. data/features/fixtures/rails4/app/app/views/layouts/application.html.erb +0 -14
  290. data/features/fixtures/rails4/app/config.ru +0 -4
  291. data/features/fixtures/rails4/app/config/application.rb +0 -23
  292. data/features/fixtures/rails4/app/config/boot.rb +0 -4
  293. data/features/fixtures/rails4/app/config/database.yml +0 -31
  294. data/features/fixtures/rails4/app/config/environment.rb +0 -5
  295. data/features/fixtures/rails4/app/config/environments/development.rb +0 -31
  296. data/features/fixtures/rails4/app/config/environments/production.rb +0 -81
  297. data/features/fixtures/rails4/app/config/environments/rails_env.rb +0 -30
  298. data/features/fixtures/rails4/app/config/environments/test.rb +0 -31
  299. data/features/fixtures/rails4/app/config/initializers/backtrace_silencers.rb +0 -7
  300. data/features/fixtures/rails4/app/config/initializers/bugsnag.rb +0 -29
  301. data/features/fixtures/rails4/app/config/initializers/devise.rb +0 -283
  302. data/features/fixtures/rails4/app/config/initializers/filter_parameter_logging.rb +0 -5
  303. data/features/fixtures/rails4/app/config/initializers/inflections.rb +0 -16
  304. data/features/fixtures/rails4/app/config/initializers/mime_types.rb +0 -5
  305. data/features/fixtures/rails4/app/config/initializers/secret_token.rb +0 -12
  306. data/features/fixtures/rails4/app/config/initializers/session_store.rb +0 -3
  307. data/features/fixtures/rails4/app/config/initializers/wrap_parameters.rb +0 -14
  308. data/features/fixtures/rails4/app/config/locales/devise.en.yml +0 -64
  309. data/features/fixtures/rails4/app/config/locales/en.yml +0 -23
  310. data/features/fixtures/rails4/app/config/mongoid.yml +0 -22
  311. data/features/fixtures/rails4/app/config/routes.rb +0 -21
  312. data/features/fixtures/rails4/app/db/migrate/20180420160315_devise_create_users.rb +0 -47
  313. data/features/fixtures/rails4/app/db/seeds.rb +0 -7
  314. data/features/fixtures/rails4/app/lib/assets/.keep +0 -0
  315. data/features/fixtures/rails4/app/lib/tasks/.keep +0 -0
  316. data/features/fixtures/rails4/app/log/.keep +0 -0
  317. data/features/fixtures/rails4/app/public/404.html +0 -58
  318. data/features/fixtures/rails4/app/public/422.html +0 -58
  319. data/features/fixtures/rails4/app/public/500.html +0 -57
  320. data/features/fixtures/rails4/app/public/favicon.ico +0 -0
  321. data/features/fixtures/rails4/app/public/robots.txt +0 -5
  322. data/features/fixtures/rails4/app/test/controllers/.keep +0 -0
  323. data/features/fixtures/rails4/app/test/fixtures/.keep +0 -0
  324. data/features/fixtures/rails4/app/test/helpers/.keep +0 -0
  325. data/features/fixtures/rails4/app/test/integration/.keep +0 -0
  326. data/features/fixtures/rails4/app/test/mailers/.keep +0 -0
  327. data/features/fixtures/rails4/app/test/models/.keep +0 -0
  328. data/features/fixtures/rails4/app/test/test_helper.rb +0 -15
  329. data/features/fixtures/rails5/.dockerignore +0 -1
  330. data/features/fixtures/rails5/Dockerfile +0 -17
  331. data/features/fixtures/rails5/app/.gitignore +0 -21
  332. data/features/fixtures/rails5/app/Gemfile +0 -52
  333. data/features/fixtures/rails5/app/README.md +0 -24
  334. data/features/fixtures/rails5/app/Rakefile +0 -6
  335. data/features/fixtures/rails5/app/app/assets/config/manifest.js +0 -3
  336. data/features/fixtures/rails5/app/app/assets/images/.keep +0 -0
  337. data/features/fixtures/rails5/app/app/assets/javascripts/application.js +0 -16
  338. data/features/fixtures/rails5/app/app/assets/javascripts/cable.js +0 -13
  339. data/features/fixtures/rails5/app/app/assets/javascripts/channels/.keep +0 -0
  340. data/features/fixtures/rails5/app/app/assets/stylesheets/application.css +0 -15
  341. data/features/fixtures/rails5/app/app/channels/application_cable/channel.rb +0 -4
  342. data/features/fixtures/rails5/app/app/channels/application_cable/connection.rb +0 -4
  343. data/features/fixtures/rails5/app/app/controllers/api_key_controller.rb +0 -16
  344. data/features/fixtures/rails5/app/app/controllers/app_type_controller.rb +0 -16
  345. data/features/fixtures/rails5/app/app/controllers/app_version_controller.rb +0 -21
  346. data/features/fixtures/rails5/app/app/controllers/application_controller.rb +0 -7
  347. data/features/fixtures/rails5/app/app/controllers/auto_notify_controller.rb +0 -27
  348. data/features/fixtures/rails5/app/app/controllers/before_notify_controller.rb +0 -40
  349. data/features/fixtures/rails5/app/app/controllers/breadcrumbs_controller.rb +0 -24
  350. data/features/fixtures/rails5/app/app/controllers/clearance_controller.rb +0 -33
  351. data/features/fixtures/rails5/app/app/controllers/concerns/.keep +0 -0
  352. data/features/fixtures/rails5/app/app/controllers/handled_controller.rb +0 -22
  353. data/features/fixtures/rails5/app/app/controllers/ignore_classes_controller.rb +0 -19
  354. data/features/fixtures/rails5/app/app/controllers/metadata_filters_controller.rb +0 -12
  355. data/features/fixtures/rails5/app/app/controllers/mongo_controller.rb +0 -22
  356. data/features/fixtures/rails5/app/app/controllers/project_root_controller.rb +0 -21
  357. data/features/fixtures/rails5/app/app/controllers/release_stage_controller.rb +0 -16
  358. data/features/fixtures/rails5/app/app/controllers/send_code_controller.rb +0 -16
  359. data/features/fixtures/rails5/app/app/controllers/send_environment_controller.rb +0 -8
  360. data/features/fixtures/rails5/app/app/controllers/session_tracking_controller.rb +0 -20
  361. data/features/fixtures/rails5/app/app/controllers/unhandled_controller.rb +0 -7
  362. data/features/fixtures/rails5/app/app/helpers/application_helper.rb +0 -2
  363. data/features/fixtures/rails5/app/app/jobs/application_job.rb +0 -2
  364. data/features/fixtures/rails5/app/app/jobs/notify_job.rb +0 -5
  365. data/features/fixtures/rails5/app/app/mailers/application_mailer.rb +0 -4
  366. data/features/fixtures/rails5/app/app/models/application_record.rb +0 -3
  367. data/features/fixtures/rails5/app/app/models/concerns/.keep +0 -0
  368. data/features/fixtures/rails5/app/app/models/mongo_model.rb +0 -6
  369. data/features/fixtures/rails5/app/app/models/user.rb +0 -3
  370. data/features/fixtures/rails5/app/app/views/layouts/application.html.erb +0 -14
  371. data/features/fixtures/rails5/app/app/views/layouts/mailer.html.erb +0 -13
  372. data/features/fixtures/rails5/app/app/views/layouts/mailer.text.erb +0 -1
  373. data/features/fixtures/rails5/app/config.ru +0 -5
  374. data/features/fixtures/rails5/app/config/application.rb +0 -15
  375. data/features/fixtures/rails5/app/config/boot.rb +0 -3
  376. data/features/fixtures/rails5/app/config/cable.yml +0 -9
  377. data/features/fixtures/rails5/app/config/database.yml +0 -29
  378. data/features/fixtures/rails5/app/config/environment.rb +0 -5
  379. data/features/fixtures/rails5/app/config/environments/development.rb +0 -55
  380. data/features/fixtures/rails5/app/config/environments/production.rb +0 -87
  381. data/features/fixtures/rails5/app/config/environments/rails_env.rb +0 -55
  382. data/features/fixtures/rails5/app/config/environments/test.rb +0 -55
  383. data/features/fixtures/rails5/app/config/initializers/assets.rb +0 -11
  384. data/features/fixtures/rails5/app/config/initializers/backtrace_silencers.rb +0 -7
  385. data/features/fixtures/rails5/app/config/initializers/bugsnag.rb +0 -29
  386. data/features/fixtures/rails5/app/config/initializers/clearance.rb +0 -5
  387. data/features/fixtures/rails5/app/config/initializers/cookies_serializer.rb +0 -5
  388. data/features/fixtures/rails5/app/config/initializers/filter_parameter_logging.rb +0 -5
  389. data/features/fixtures/rails5/app/config/initializers/inflections.rb +0 -16
  390. data/features/fixtures/rails5/app/config/initializers/mime_types.rb +0 -4
  391. data/features/fixtures/rails5/app/config/initializers/new_framework_defaults.rb +0 -24
  392. data/features/fixtures/rails5/app/config/initializers/session_store.rb +0 -3
  393. data/features/fixtures/rails5/app/config/initializers/wrap_parameters.rb +0 -14
  394. data/features/fixtures/rails5/app/config/locales/devise.en.yml +0 -64
  395. data/features/fixtures/rails5/app/config/locales/en.yml +0 -23
  396. data/features/fixtures/rails5/app/config/mongoid.yml +0 -23
  397. data/features/fixtures/rails5/app/config/puma.rb +0 -47
  398. data/features/fixtures/rails5/app/config/routes.rb +0 -62
  399. data/features/fixtures/rails5/app/config/secrets.yml +0 -25
  400. data/features/fixtures/rails5/app/config/spring.rb +0 -6
  401. data/features/fixtures/rails5/app/db/migrate/20180426095545_create_users.rb +0 -17
  402. data/features/fixtures/rails5/app/db/schema.rb +0 -29
  403. data/features/fixtures/rails5/app/db/seeds.rb +0 -7
  404. data/features/fixtures/rails5/app/lib/assets/.keep +0 -0
  405. data/features/fixtures/rails5/app/lib/tasks/.keep +0 -0
  406. data/features/fixtures/rails5/app/log/.keep +0 -0
  407. data/features/fixtures/rails5/app/public/404.html +0 -67
  408. data/features/fixtures/rails5/app/public/422.html +0 -67
  409. data/features/fixtures/rails5/app/public/500.html +0 -66
  410. data/features/fixtures/rails5/app/public/apple-touch-icon-precomposed.png +0 -0
  411. data/features/fixtures/rails5/app/public/apple-touch-icon.png +0 -0
  412. data/features/fixtures/rails5/app/public/favicon.ico +0 -0
  413. data/features/fixtures/rails5/app/public/robots.txt +0 -5
  414. data/features/fixtures/rails5/app/test/controllers/.keep +0 -0
  415. data/features/fixtures/rails5/app/test/fixtures/.keep +0 -0
  416. data/features/fixtures/rails5/app/test/fixtures/files/.keep +0 -0
  417. data/features/fixtures/rails5/app/test/helpers/.keep +0 -0
  418. data/features/fixtures/rails5/app/test/integration/.keep +0 -0
  419. data/features/fixtures/rails5/app/test/mailers/.keep +0 -0
  420. data/features/fixtures/rails5/app/test/models/.keep +0 -0
  421. data/features/fixtures/rails5/app/test/test_helper.rb +0 -10
  422. data/features/fixtures/rails5/app/tmp/.keep +0 -0
  423. data/features/fixtures/rails6/.dockerignore +0 -1
  424. data/features/fixtures/rails6/Dockerfile +0 -26
  425. data/features/fixtures/rails6/app/.browserslistrc +0 -1
  426. data/features/fixtures/rails6/app/.gitignore +0 -35
  427. data/features/fixtures/rails6/app/.ruby-version +0 -1
  428. data/features/fixtures/rails6/app/Gemfile +0 -58
  429. data/features/fixtures/rails6/app/README.md +0 -24
  430. data/features/fixtures/rails6/app/Rakefile +0 -6
  431. data/features/fixtures/rails6/app/app/assets/config/manifest.js +0 -2
  432. data/features/fixtures/rails6/app/app/assets/images/.keep +0 -0
  433. data/features/fixtures/rails6/app/app/assets/stylesheets/application.css +0 -15
  434. data/features/fixtures/rails6/app/app/channels/application_cable/channel.rb +0 -4
  435. data/features/fixtures/rails6/app/app/channels/application_cable/connection.rb +0 -4
  436. data/features/fixtures/rails6/app/app/controllers/api_key_controller.rb +0 -16
  437. data/features/fixtures/rails6/app/app/controllers/app_type_controller.rb +0 -16
  438. data/features/fixtures/rails6/app/app/controllers/app_version_controller.rb +0 -21
  439. data/features/fixtures/rails6/app/app/controllers/application_controller.rb +0 -7
  440. data/features/fixtures/rails6/app/app/controllers/auto_notify_controller.rb +0 -27
  441. data/features/fixtures/rails6/app/app/controllers/before_notify_controller.rb +0 -40
  442. data/features/fixtures/rails6/app/app/controllers/breadcrumbs_controller.rb +0 -24
  443. data/features/fixtures/rails6/app/app/controllers/clearance_controller.rb +0 -33
  444. data/features/fixtures/rails6/app/app/controllers/concerns/.keep +0 -0
  445. data/features/fixtures/rails6/app/app/controllers/handled_controller.rb +0 -22
  446. data/features/fixtures/rails6/app/app/controllers/ignore_classes_controller.rb +0 -19
  447. data/features/fixtures/rails6/app/app/controllers/metadata_filters_controller.rb +0 -12
  448. data/features/fixtures/rails6/app/app/controllers/mongo_controller.rb +0 -22
  449. data/features/fixtures/rails6/app/app/controllers/project_root_controller.rb +0 -21
  450. data/features/fixtures/rails6/app/app/controllers/release_stage_controller.rb +0 -16
  451. data/features/fixtures/rails6/app/app/controllers/send_code_controller.rb +0 -16
  452. data/features/fixtures/rails6/app/app/controllers/send_environment_controller.rb +0 -8
  453. data/features/fixtures/rails6/app/app/controllers/session_tracking_controller.rb +0 -20
  454. data/features/fixtures/rails6/app/app/controllers/unhandled_controller.rb +0 -7
  455. data/features/fixtures/rails6/app/app/helpers/application_helper.rb +0 -2
  456. data/features/fixtures/rails6/app/app/javascript/channels/consumer.js +0 -6
  457. data/features/fixtures/rails6/app/app/javascript/channels/index.js +0 -5
  458. data/features/fixtures/rails6/app/app/javascript/packs/application.js +0 -9
  459. data/features/fixtures/rails6/app/app/jobs/application_job.rb +0 -7
  460. data/features/fixtures/rails6/app/app/jobs/notify_job.rb +0 -5
  461. data/features/fixtures/rails6/app/app/mailers/application_mailer.rb +0 -4
  462. data/features/fixtures/rails6/app/app/models/application_record.rb +0 -3
  463. data/features/fixtures/rails6/app/app/models/concerns/.keep +0 -0
  464. data/features/fixtures/rails6/app/app/models/mongo_model.rb +0 -6
  465. data/features/fixtures/rails6/app/app/models/user.rb +0 -3
  466. data/features/fixtures/rails6/app/app/views/layouts/application.html.erb +0 -15
  467. data/features/fixtures/rails6/app/app/views/layouts/mailer.html.erb +0 -13
  468. data/features/fixtures/rails6/app/app/views/layouts/mailer.text.erb +0 -1
  469. data/features/fixtures/rails6/app/babel.config.js +0 -70
  470. data/features/fixtures/rails6/app/config.ru +0 -5
  471. data/features/fixtures/rails6/app/config/application.rb +0 -19
  472. data/features/fixtures/rails6/app/config/boot.rb +0 -4
  473. data/features/fixtures/rails6/app/config/cable.yml +0 -13
  474. data/features/fixtures/rails6/app/config/credentials.yml.enc +0 -1
  475. data/features/fixtures/rails6/app/config/database.yml +0 -29
  476. data/features/fixtures/rails6/app/config/environment.rb +0 -5
  477. data/features/fixtures/rails6/app/config/environments/development.rb +0 -64
  478. data/features/fixtures/rails6/app/config/environments/production.rb +0 -113
  479. data/features/fixtures/rails6/app/config/environments/rails_env.rb +0 -56
  480. data/features/fixtures/rails6/app/config/environments/test.rb +0 -48
  481. data/features/fixtures/rails6/app/config/initializers/application_controller_renderer.rb +0 -8
  482. data/features/fixtures/rails6/app/config/initializers/assets.rb +0 -14
  483. data/features/fixtures/rails6/app/config/initializers/backtrace_silencers.rb +0 -7
  484. data/features/fixtures/rails6/app/config/initializers/bugsnag.rb +0 -29
  485. data/features/fixtures/rails6/app/config/initializers/content_security_policy.rb +0 -27
  486. data/features/fixtures/rails6/app/config/initializers/cookies_serializer.rb +0 -5
  487. data/features/fixtures/rails6/app/config/initializers/filter_parameter_logging.rb +0 -5
  488. data/features/fixtures/rails6/app/config/initializers/inflections.rb +0 -16
  489. data/features/fixtures/rails6/app/config/initializers/mime_types.rb +0 -4
  490. data/features/fixtures/rails6/app/config/initializers/wrap_parameters.rb +0 -14
  491. data/features/fixtures/rails6/app/config/locales/en.yml +0 -33
  492. data/features/fixtures/rails6/app/config/mongoid.yml +0 -23
  493. data/features/fixtures/rails6/app/config/puma.rb +0 -35
  494. data/features/fixtures/rails6/app/config/routes.rb +0 -62
  495. data/features/fixtures/rails6/app/config/secrets.yml +0 -25
  496. data/features/fixtures/rails6/app/config/spring.rb +0 -6
  497. data/features/fixtures/rails6/app/config/storage.yml +0 -34
  498. data/features/fixtures/rails6/app/config/webpack/development.js +0 -5
  499. data/features/fixtures/rails6/app/config/webpack/environment.js +0 -3
  500. data/features/fixtures/rails6/app/config/webpack/production.js +0 -5
  501. data/features/fixtures/rails6/app/config/webpack/rails_env.js +0 -5
  502. data/features/fixtures/rails6/app/config/webpack/test.js +0 -5
  503. data/features/fixtures/rails6/app/config/webpacker.yml +0 -121
  504. data/features/fixtures/rails6/app/db/migrate/20180426095545_create_users.rb +0 -17
  505. data/features/fixtures/rails6/app/db/schema.rb +0 -29
  506. data/features/fixtures/rails6/app/db/seeds.rb +0 -7
  507. data/features/fixtures/rails6/app/lib/assets/.keep +0 -0
  508. data/features/fixtures/rails6/app/lib/tasks/.keep +0 -0
  509. data/features/fixtures/rails6/app/log/.keep +0 -0
  510. data/features/fixtures/rails6/app/package.json +0 -15
  511. data/features/fixtures/rails6/app/postcss.config.js +0 -12
  512. data/features/fixtures/rails6/app/public/404.html +0 -67
  513. data/features/fixtures/rails6/app/public/422.html +0 -67
  514. data/features/fixtures/rails6/app/public/500.html +0 -66
  515. data/features/fixtures/rails6/app/public/apple-touch-icon-precomposed.png +0 -0
  516. data/features/fixtures/rails6/app/public/apple-touch-icon.png +0 -0
  517. data/features/fixtures/rails6/app/public/favicon.ico +0 -0
  518. data/features/fixtures/rails6/app/public/robots.txt +0 -1
  519. data/features/fixtures/rails6/app/storage/.keep +0 -0
  520. data/features/fixtures/rails6/app/test/application_system_test_case.rb +0 -5
  521. data/features/fixtures/rails6/app/test/channels/application_cable/connection_test.rb +0 -11
  522. data/features/fixtures/rails6/app/test/controllers/.keep +0 -0
  523. data/features/fixtures/rails6/app/test/fixtures/.keep +0 -0
  524. data/features/fixtures/rails6/app/test/fixtures/files/.keep +0 -0
  525. data/features/fixtures/rails6/app/test/helpers/.keep +0 -0
  526. data/features/fixtures/rails6/app/test/integration/.keep +0 -0
  527. data/features/fixtures/rails6/app/test/mailers/.keep +0 -0
  528. data/features/fixtures/rails6/app/test/models/.keep +0 -0
  529. data/features/fixtures/rails6/app/test/system/.keep +0 -0
  530. data/features/fixtures/rails6/app/test/test_helper.rb +0 -13
  531. data/features/fixtures/rails6/app/tmp/.keep +0 -0
  532. data/features/fixtures/rails6/app/yarn.lock +0 -6082
  533. data/features/fixtures/resque/.dockerignore +0 -1
  534. data/features/fixtures/resque/Dockerfile +0 -14
  535. data/features/fixtures/resque/Gemfile +0 -6
  536. data/features/fixtures/resque/Rakefile +0 -4
  537. data/features/fixtures/resque/app.rb +0 -12
  538. data/features/fixtures/sidekiq/.dockerignore +0 -2
  539. data/features/fixtures/sidekiq/Dockerfile +0 -17
  540. data/features/fixtures/sidekiq/app/Gemfile +0 -7
  541. data/features/fixtures/sidekiq/app/Rakefile.rb +0 -14
  542. data/features/fixtures/sidekiq/app/app.rb +0 -35
  543. data/features/fixtures/sidekiq/app/initializers/HandledError.rb +0 -3
  544. data/features/fixtures/sidekiq/app/initializers/UnhandledError.rb +0 -3
  545. data/features/fixtures/sidekiq/payloads/handled_metadata_ca_false.json +0 -11
  546. data/features/fixtures/sidekiq/payloads/handled_metadata_ca_true.json +0 -12
  547. data/features/fixtures/sidekiq/payloads/unhandled_metadata_ca_false.json +0 -11
  548. data/features/fixtures/sidekiq/payloads/unhandled_metadata_ca_true.json +0 -12
  549. data/features/fixtures/sinatra1/.dockerignore +0 -1
  550. data/features/fixtures/sinatra1/Dockerfile +0 -13
  551. data/features/fixtures/sinatra1/Gemfile +0 -4
  552. data/features/fixtures/sinatra1/app.rb +0 -9
  553. data/features/fixtures/sinatra2/.dockerignore +0 -1
  554. data/features/fixtures/sinatra2/Dockerfile +0 -13
  555. data/features/fixtures/sinatra2/Gemfile +0 -4
  556. data/features/fixtures/sinatra2/app.rb +0 -9
  557. data/features/plain_features/add_tab.feature +0 -55
  558. data/features/plain_features/app_type.feature +0 -8
  559. data/features/plain_features/app_version.feature +0 -8
  560. data/features/plain_features/auto_notify.feature +0 -7
  561. data/features/plain_features/delivery.feature +0 -20
  562. data/features/plain_features/exception_data.feature +0 -50
  563. data/features/plain_features/filters.feature +0 -14
  564. data/features/plain_features/handled_errors.feature +0 -42
  565. data/features/plain_features/ignore_classes.feature +0 -11
  566. data/features/plain_features/ignore_report.feature +0 -14
  567. data/features/plain_features/proxies.feature +0 -25
  568. data/features/plain_features/release_stages.feature +0 -20
  569. data/features/plain_features/report_api_key.feature +0 -16
  570. data/features/plain_features/report_severity.feature +0 -17
  571. data/features/plain_features/report_stack_frames.feature +0 -53
  572. data/features/plain_features/report_user.feature +0 -51
  573. data/features/plain_features/unhandled_errors.feature +0 -33
  574. data/features/rails_features/api_key.feature +0 -15
  575. data/features/rails_features/app_type.feature +0 -24
  576. data/features/rails_features/app_version.feature +0 -26
  577. data/features/rails_features/auto_capture_sessions.feature +0 -34
  578. data/features/rails_features/auto_notify.feature +0 -41
  579. data/features/rails_features/before_notify.feature +0 -44
  580. data/features/rails_features/breadcrumbs.feature +0 -43
  581. data/features/rails_features/handled.feature +0 -42
  582. data/features/rails_features/ignore_classes.feature +0 -14
  583. data/features/rails_features/meta_data_filters.feature +0 -16
  584. data/features/rails_features/mongo_breadcrumbs.feature +0 -26
  585. data/features/rails_features/on_error.feature +0 -29
  586. data/features/rails_features/project_root.feature +0 -35
  587. data/features/rails_features/release_stage.feature +0 -27
  588. data/features/rails_features/send_code.feature +0 -18
  589. data/features/rails_features/send_environment.feature +0 -13
  590. data/features/rails_features/unhandled.feature +0 -16
  591. data/features/rails_features/user_info.feature +0 -52
  592. data/features/sidekiq.feature +0 -30
  593. data/features/steps/ruby_notifier_steps.rb +0 -75
  594. data/features/support/env.rb +0 -23
  595. data/issue_template.md +0 -48
  596. data/spec/breadcrumbs/breadcrumb_spec.rb +0 -93
  597. data/spec/breadcrumbs/validator_spec.rb +0 -176
  598. data/spec/bugsnag_spec.rb +0 -366
  599. data/spec/cleaner_spec.rb +0 -350
  600. data/spec/code_extractor_spec.rb +0 -129
  601. data/spec/configuration_spec.rb +0 -445
  602. data/spec/fixtures/apps/rails-initializer-config/Gemfile +0 -9
  603. data/spec/fixtures/apps/rails-initializer-config/config.ru +0 -16
  604. data/spec/fixtures/apps/rails-initializer-config/config/initializers/bugsnag.rb +0 -3
  605. data/spec/fixtures/apps/rails-invalid-initializer-config/Gemfile +0 -9
  606. data/spec/fixtures/apps/rails-invalid-initializer-config/config.ru +0 -16
  607. data/spec/fixtures/apps/rails-invalid-initializer-config/config/initializers/bugsnag.rb +0 -3
  608. data/spec/fixtures/apps/rails-no-config/Gemfile +0 -9
  609. data/spec/fixtures/apps/rails-no-config/config.ru +0 -16
  610. data/spec/fixtures/apps/scripts/Gemfile +0 -3
  611. data/spec/fixtures/apps/scripts/configure_invalid_key.rb +0 -5
  612. data/spec/fixtures/apps/scripts/configure_key.rb +0 -5
  613. data/spec/fixtures/apps/scripts/no_config.rb +0 -3
  614. data/spec/fixtures/crashes/end_of_file.rb +0 -9
  615. data/spec/fixtures/crashes/file1.rb +0 -29
  616. data/spec/fixtures/crashes/file2.rb +0 -25
  617. data/spec/fixtures/crashes/file_with_long_lines.rb +0 -7
  618. data/spec/fixtures/crashes/functions.rb +0 -29
  619. data/spec/fixtures/crashes/short_file.rb +0 -3
  620. data/spec/fixtures/crashes/start_of_file.rb +0 -9
  621. data/spec/fixtures/middleware/internal_info_setter.rb +0 -11
  622. data/spec/fixtures/middleware/public_info_setter.rb +0 -11
  623. data/spec/fixtures/tasks/Rakefile +0 -26
  624. data/spec/helper_spec.rb +0 -131
  625. data/spec/integration_spec.rb +0 -107
  626. data/spec/integrations/clearance_user_spec.rb +0 -38
  627. data/spec/integrations/logger_spec.rb +0 -134
  628. data/spec/integrations/mailman_spec.rb +0 -83
  629. data/spec/integrations/mongo_spec.rb +0 -262
  630. data/spec/integrations/que_spec.rb +0 -94
  631. data/spec/integrations/rack_spec.rb +0 -232
  632. data/spec/integrations/rails3_request_spec.rb +0 -67
  633. data/spec/integrations/rake_spec.rb +0 -71
  634. data/spec/integrations/resque_spec.rb +0 -99
  635. data/spec/integrations/shoryuken_spec.rb +0 -70
  636. data/spec/integrations/sidekiq_spec.rb +0 -137
  637. data/spec/integrations/warden_user_spec.rb +0 -41
  638. data/spec/middleware/exception_meta_data_spec.rb +0 -104
  639. data/spec/middleware_spec.rb +0 -254
  640. data/spec/middleware_stack_spec.rb +0 -151
  641. data/spec/on_error_spec.rb +0 -332
  642. data/spec/report_spec.rb +0 -1583
  643. data/spec/session_tracker_spec.rb +0 -156
  644. data/spec/spec_helper.rb +0 -99
  645. data/spec/stacktrace_spec.rb +0 -443
  646. data/spec/utility/circular_buffer_spec.rb +0 -98
@@ -1,1583 +0,0 @@
1
- # encoding: utf-8
2
- require_relative './spec_helper'
3
- require 'securerandom'
4
- require 'ostruct'
5
-
6
- module ActiveRecord; class RecordNotFound < RuntimeError; end; end
7
- class NestedException < StandardError; attr_accessor :original_exception; end
8
- class BugsnagTestExceptionWithMetaData < Exception; include Bugsnag::MetaData; end
9
- class BugsnagSubclassTestException < BugsnagTestException; end
10
-
11
- class Ruby21Exception < RuntimeError
12
- attr_accessor :cause
13
- def self.raise!(msg)
14
- e = new(msg)
15
- e.cause = $!
16
- raise e
17
- end
18
- end
19
-
20
- class JRubyException
21
- def self.raise!
22
- new.gloops
23
- end
24
-
25
- def gloops
26
- java.lang.System.out.printf(nil)
27
- end
28
- end
29
-
30
- # rubocop:disable Metrics/BlockLength
31
- describe Bugsnag::Report do
32
- it "should contain an api_key if one is set" do
33
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
34
-
35
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
36
- expect(headers["Bugsnag-Api-Key"]).to eq("c9d60ae4c7e70c4b6c4ebd3e8056d2b8")
37
- expect(payload["apiKey"]).to eq("c9d60ae4c7e70c4b6c4ebd3e8056d2b8")
38
- }
39
- end
40
-
41
- it "does not notify if api_key is not set" do
42
- Bugsnag.configuration.api_key = nil
43
-
44
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
45
-
46
- expect(Bugsnag).not_to have_sent_notification
47
- end
48
-
49
- it "does not notify if api_key is empty" do
50
- Bugsnag.configuration.api_key = ""
51
-
52
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
53
-
54
- expect(Bugsnag).not_to have_sent_notification
55
- end
56
-
57
- it "lets you override the api_key" do
58
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
59
- report.api_key = "9d84383f9be2ca94902e45c756a9979d"
60
- end
61
-
62
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
63
- expect(headers["Bugsnag-Api-Key"]).to eq("9d84383f9be2ca94902e45c756a9979d")
64
- }
65
- end
66
-
67
- it "lets you override the groupingHash" do
68
-
69
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
70
- report.grouping_hash = "this is my grouping hash"
71
- end
72
-
73
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
74
- event = get_event_from_payload(payload)
75
- expect(event["groupingHash"]).to eq("this is my grouping hash")
76
- }
77
- end
78
-
79
- it "uses the env variable apiKey" do
80
- ENV["BUGSNAG_API_KEY"] = "c9d60ae4c7e70c4b6c4ebd3e8056d2b9"
81
-
82
- Bugsnag.instance_variable_set(:@configuration, Bugsnag::Configuration.new)
83
- Bugsnag.configure do |config|
84
- config.release_stage = "production"
85
- config.delivery_method = :synchronous
86
- end
87
-
88
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
89
-
90
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
91
- expect(headers["Bugsnag-Api-Key"]).to eq("c9d60ae4c7e70c4b6c4ebd3e8056d2b9")
92
- }
93
- end
94
-
95
- it "has the right exception class" do
96
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
97
-
98
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
99
- exception = get_exception_from_payload(payload)
100
- expect(exception["errorClass"]).to eq("BugsnagTestException")
101
- }
102
- end
103
-
104
- it "has the right exception message" do
105
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
106
-
107
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
108
- exception = get_exception_from_payload(payload)
109
- expect(exception["message"]).to eq("It crashed")
110
- }
111
- end
112
-
113
- it "has a valid stacktrace" do
114
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
115
-
116
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
117
- exception = get_exception_from_payload(payload)
118
- expect(exception["stacktrace"].length).to be > 0
119
- }
120
- end
121
-
122
- it "uses correct unhandled defaults" do
123
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
124
-
125
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
126
- event = get_event_from_payload(payload)
127
- expect(event["unhandled"]).to be false
128
- expect(event["severity"]).to eq("warning")
129
- expect(event["severityReason"]).to eq({
130
- "type" => "handledException"
131
- })
132
- }
133
- end
134
-
135
- it "sets correct severityReason if severity is modified in a block" do
136
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |notification|
137
- notification.severity = "info"
138
- end
139
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
140
- event = get_event_from_payload(payload)
141
- expect(event["unhandled"]).to be false
142
- expect(event["severity"]).to eq("info")
143
- expect(event["severityReason"]).to eq({
144
- "type" => "userCallbackSetSeverity"
145
- })
146
- }
147
- end
148
-
149
- it "sets correct severity and reason for specific error classes" do
150
- original_ignore_classes = Bugsnag.configuration.ignore_classes
151
-
152
- begin
153
- # The default ignore classes includes SignalException, so we need to
154
- # temporarily set it to something else.
155
- Bugsnag.configuration.ignore_classes = Set[SystemExit]
156
-
157
- Bugsnag.notify(SignalException.new("TERM"))
158
-
159
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
160
- event = get_event_from_payload(payload)
161
- expect(event["unhandled"]).to be false
162
- expect(event["severity"]).to eq("info")
163
- expect(event["severityReason"]).to eq({
164
- "type" => "errorClass",
165
- "attributes" => {
166
- "errorClass" => "SignalException"
167
- }
168
- })
169
- }
170
- ensure
171
- Bugsnag.configuration.ignore_classes = original_ignore_classes
172
- end
173
- end
174
-
175
- # TODO: nested context
176
-
177
- it "accepts tabs in overrides and adds them to metaData" do
178
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
179
- report.meta_data.merge!({
180
- some_tab: {
181
- info: "here",
182
- data: "also here"
183
- }
184
- })
185
- end
186
-
187
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
188
- event = get_event_from_payload(payload)
189
- expect(event["metaData"]["some_tab"]).to eq(
190
- "info" => "here",
191
- "data" => "also here"
192
- )
193
- }
194
- end
195
-
196
- it "accepts meta data from an exception that mixes in Bugsnag::MetaData" do
197
- exception = BugsnagTestExceptionWithMetaData.new("It crashed")
198
- exception.bugsnag_meta_data = {
199
- some_tab: {
200
- info: "here",
201
- data: "also here"
202
- }
203
- }
204
-
205
- Bugsnag.notify(exception)
206
-
207
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
208
- event = get_event_from_payload(payload)
209
- expect(event["metaData"]["some_tab"]).to eq(
210
- "info" => "here",
211
- "data" => "also here"
212
- )
213
- }
214
- end
215
-
216
- it "removes tabs" do
217
- exception = BugsnagTestExceptionWithMetaData.new("It crashed")
218
- exception.bugsnag_meta_data = {
219
- :some_tab => {
220
- :info => "here",
221
- :data => "also here"
222
- }
223
- }
224
-
225
- Bugsnag.notify(exception) do |report|
226
- report.remove_tab(:some_tab)
227
- end
228
-
229
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
230
- event = get_event_from_payload(payload)
231
- expect(event["metaData"]["some_tab"]).to be_nil
232
- }
233
- end
234
-
235
- it "ignores removing nil tabs" do
236
- exception = BugsnagTestExceptionWithMetaData.new("It crashed")
237
- exception.bugsnag_meta_data = {
238
- :some_tab => {
239
- :info => "here",
240
- :data => "also here"
241
- }
242
- }
243
-
244
- Bugsnag.notify(exception) do |report|
245
- report.remove_tab(nil)
246
- end
247
-
248
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
249
- event = get_event_from_payload(payload)
250
- expect(event["metaData"]["some_tab"]).to eq(
251
- "info" => "here",
252
- "data" => "also here"
253
- )
254
- }
255
- end
256
-
257
- it "Creates a custom tab for metadata which is not a Hash" do
258
- exception = Exception.new("It crashed")
259
-
260
- Bugsnag.notify(exception) do |report|
261
- report.add_tab(:some_tab, "added")
262
- end
263
-
264
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
265
- event = get_event_from_payload(payload)
266
- expect(event["metaData"]["custom"]).to eq(
267
- "some_tab" => "added",
268
- )
269
- }
270
- end
271
-
272
- it "accepts meta data from an exception that mixes in Bugsnag::MetaData, but override using the overrides" do
273
- exception = BugsnagTestExceptionWithMetaData.new("It crashed")
274
- exception.bugsnag_meta_data = {
275
- :some_tab => {
276
- :info => "here",
277
- :data => "also here"
278
- }
279
- }
280
-
281
- Bugsnag.notify(exception) do |report|
282
- report.add_tab(:some_tab, {:info => "overridden"})
283
- end
284
-
285
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
286
- event = get_event_from_payload(payload)
287
- expect(event["metaData"]["some_tab"]).to eq(
288
- "info" => "overridden",
289
- "data" => "also here"
290
- )
291
- }
292
- end
293
-
294
- it "accepts user_id from an exception that mixes in Bugsnag::MetaData" do
295
- exception = BugsnagTestExceptionWithMetaData.new("It crashed")
296
- exception.bugsnag_user_id = "exception_user_id"
297
-
298
- Bugsnag.notify(exception)
299
-
300
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
301
- event = get_event_from_payload(payload)
302
- expect(event["user"]["id"]).to eq("exception_user_id")
303
- }
304
- end
305
-
306
- it "accepts user_id from an exception that mixes in Bugsnag::MetaData, but override using the overrides" do
307
- exception = BugsnagTestExceptionWithMetaData.new("It crashed")
308
- exception.bugsnag_user_id = "exception_user_id"
309
-
310
- Bugsnag.notify(exception) do |report|
311
- report.user.merge!({:id => "override_user_id"})
312
- end
313
-
314
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
315
- event = get_event_from_payload(payload)
316
- expect(event["user"]["id"]).to eq("override_user_id")
317
- }
318
- end
319
-
320
- it "accepts context from an exception that mixes in Bugsnag::MetaData" do
321
- exception = BugsnagTestExceptionWithMetaData.new("It crashed")
322
- exception.bugsnag_context = "exception_context"
323
-
324
- Bugsnag.notify(exception)
325
-
326
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
327
- event = get_event_from_payload(payload)
328
- expect(event["context"]).to eq("exception_context")
329
- }
330
- end
331
-
332
- it "accepts grouping_hash from an exception that mixes in Bugsnag::MetaData" do
333
- exception = BugsnagTestExceptionWithMetaData.new("It crashed")
334
- exception.bugsnag_grouping_hash = "exception_hash"
335
-
336
- Bugsnag.notify(exception)
337
-
338
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
339
- event = get_event_from_payload(payload)
340
- expect(event["groupingHash"]).to eq("exception_hash")
341
- }
342
- end
343
-
344
- it "accept contexts from an exception that mixes in Bugsnag::MetaData, but override using the overrides" do
345
-
346
- exception = BugsnagTestExceptionWithMetaData.new("It crashed")
347
- exception.bugsnag_context = "exception_context"
348
-
349
- Bugsnag.notify(exception) do |report|
350
- report.context = "override_context"
351
- end
352
-
353
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
354
- event = get_event_from_payload(payload)
355
- expect(event["context"]).to eq("override_context")
356
- }
357
- end
358
-
359
- it "accepts meta_data in overrides (for backwards compatibility) and merge it into metaData" do
360
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
361
- report.meta_data.merge!({
362
- some_tab: {
363
- info: "here",
364
- data: "also here"
365
- }
366
- })
367
- end
368
-
369
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
370
- event = get_event_from_payload(payload)
371
- expect(event["metaData"]["some_tab"]).to eq(
372
- "info" => "here",
373
- "data" => "also here"
374
- )
375
- }
376
- end
377
-
378
- it "truncates large meta_data before sending" do
379
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
380
- report.meta_data.merge!({
381
- some_tab: {
382
- giant: SecureRandom.hex(1_000_000/2),
383
- mega: SecureRandom.hex(1_000_000/2)
384
- }
385
- })
386
- end
387
-
388
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
389
- # Truncated body should be no bigger than
390
- # 2 truncated hashes (4096*2) + rest of payload (20000)
391
- expect(::JSON.dump(payload).length).to be < 4096*2 + 20000
392
- }
393
- end
394
-
395
- it "truncates large messages before sending" do
396
- Bugsnag.notify(BugsnagTestException.new(SecureRandom.hex(250_000))) do |report|
397
- report.meta_data.merge!({
398
- some_tab: {
399
- giant: SecureRandom.hex(500_000/2),
400
- mega: SecureRandom.hex(500_000/2)
401
- }
402
- })
403
- end
404
-
405
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
406
- expect(::JSON.dump(payload).length).to be < Bugsnag::Helpers::MAX_PAYLOAD_LENGTH
407
- }
408
- end
409
-
410
- it "truncate large stacktraces before sending" do
411
- ex = BugsnagTestException.new("It crashed")
412
- stacktrace = []
413
- 20000.times {|i| stacktrace.push("/Some/path/rspec/example.rb:113:in `instance_eval'")}
414
- ex.set_backtrace(stacktrace)
415
- Bugsnag.notify(ex)
416
-
417
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
418
- # Truncated body should be no bigger than
419
- # 400 stacktrace lines * approx 60 chars per line + rest of payload (20000)
420
- expect(::JSON.dump(payload).length).to be < Bugsnag::Helpers::MAX_PAYLOAD_LENGTH
421
- }
422
- end
423
-
424
- it "accepts a severity in overrides" do
425
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
426
- report.severity = "info"
427
- end
428
-
429
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
430
- event = get_event_from_payload(payload)
431
- expect(event["severity"]).to eq("info")
432
- }
433
-
434
- end
435
-
436
- it "defaults to warning severity" do
437
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
438
-
439
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
440
- event = get_event_from_payload(payload)
441
- expect(event["severity"]).to eq("warning")
442
- }
443
- end
444
-
445
- it "accepts a context in overrides" do
446
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
447
- report.context = 'test_context'
448
- end
449
-
450
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
451
- event = get_event_from_payload(payload)
452
- expect(event["context"]).to eq("test_context")
453
- }
454
- end
455
-
456
- it "accepts a user_id in overrides" do
457
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
458
- report.user = {id: 'test_user'}
459
- end
460
-
461
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
462
- event = get_event_from_payload(payload)
463
- expect(event["user"]["id"]).to eq("test_user")
464
- }
465
- end
466
-
467
- it "does not send an automatic notification if auto_notify is false" do
468
- Bugsnag.configure do |config|
469
- config.auto_notify = false
470
- end
471
-
472
- Bugsnag.notify(BugsnagTestException.new("It crashed"), true)
473
-
474
- expect(Bugsnag).not_to have_sent_notification
475
- end
476
-
477
- it "contains a release_stage" do
478
- Bugsnag.configure do |config|
479
- config.release_stage = "production"
480
- end
481
-
482
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
483
-
484
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
485
- event = get_event_from_payload(payload)
486
- expect(event["app"]["releaseStage"]).to eq("production")
487
- }
488
- end
489
-
490
- it "respects the notify_release_stages setting by not sending in development" do
491
- Bugsnag.configuration.notify_release_stages = ["production"]
492
- Bugsnag.configuration.release_stage = "development"
493
-
494
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
495
-
496
- expect(Bugsnag).not_to have_sent_notification
497
- end
498
-
499
- it "respects the notify_release_stages setting when set" do
500
- Bugsnag.configuration.release_stage = "development"
501
- Bugsnag.configuration.notify_release_stages = ["development"]
502
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
503
-
504
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
505
- event = get_event_from_payload(payload)
506
- expect(event["exceptions"].length).to eq(1)
507
- }
508
- end
509
-
510
- it "uses the https://notify.bugsnag.com endpoint by default" do
511
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
512
-
513
- expect(WebMock).to have_requested(:post, "https://notify.bugsnag.com")
514
- end
515
-
516
- it "does not mark the top-most stacktrace line as inProject if out of project" do
517
- Bugsnag.configuration.project_root = "/Random/location/here"
518
-
519
- begin
520
- "Test".prepnd "T"
521
- rescue Exception => e
522
- Bugsnag.notify(e)
523
- end
524
-
525
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
526
- exception = get_exception_from_payload(payload)
527
- expect(exception["stacktrace"].size).to be >= 1
528
- expect(exception["stacktrace"].first["inProject"]).to be_nil
529
- }
530
- end
531
-
532
- it "marks the top-most stacktrace line as inProject if necessary" do
533
- Bugsnag.configuration.project_root = File.expand_path File.dirname(__FILE__)
534
-
535
- begin
536
- "Test".prepnd "T"
537
- rescue Exception => e
538
- Bugsnag.notify(e)
539
- end
540
-
541
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
542
- exception = get_exception_from_payload(payload)
543
- expect(exception["stacktrace"].size).to be >= 1
544
- expect(exception["stacktrace"][0]["inProject"]).to eq(true)
545
- }
546
- end
547
-
548
- it 'marks vendored stack frames as out-of-project' do
549
- project_root = File.expand_path File.dirname(__FILE__)
550
- Bugsnag.configuration.project_root = project_root
551
-
552
- ex = Exception.new('Division by zero')
553
- allow(ex).to receive (:backtrace) {[
554
- File.join(project_root, "vendor/strutils/lib/string.rb:508:in `splice'"),
555
- File.join(project_root, "vendors/strutils/lib/string.rb:508:in `splice'"),
556
- File.join(project_root, "lib/helpers/string.rb:32:in `splice'"),
557
- File.join(project_root, "lib/vendor/lib/article.rb:158:in `initialize'"),
558
- File.join(project_root, "lib/prog.rb:158:in `read_articles'"),
559
- File.join(project_root, ".bundle/strutils/lib.string.rb:508:in `splice'"),
560
- File.join(project_root, "abundle/article.rb:158:in `initialize'"),
561
- File.join(project_root, ".bundles/strutils/lib.string.rb:508:in `splice'"),
562
- File.join(project_root, "lib/.bundle/article.rb:158:in `initialize'"),
563
- "app.rb:10:in `main'",
564
- "(pry):3:in `__pry__'"
565
- ]}
566
- Bugsnag.notify(ex)
567
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
568
- exception = get_exception_from_payload(payload)
569
-
570
- expect(exception["stacktrace"][0]["inProject"]).to be_nil
571
- expect(exception["stacktrace"][1]["inProject"]).to be true
572
- expect(exception["stacktrace"][2]["inProject"]).to be true
573
- expect(exception["stacktrace"][3]["inProject"]).to be true
574
- expect(exception["stacktrace"][4]["inProject"]).to be true
575
- expect(exception["stacktrace"][5]["inProject"]).to be_nil
576
- expect(exception["stacktrace"][6]["inProject"]).to be true
577
- expect(exception["stacktrace"][7]["inProject"]).to be true
578
- expect(exception["stacktrace"][8]["inProject"]).to be true
579
- expect(exception["stacktrace"][9]["inProject"]).to be_nil
580
- expect(exception["stacktrace"][10]["inProject"]).to be_nil
581
- }
582
- end
583
-
584
- it "adds app_version to the payload if it is set" do
585
- Bugsnag.configuration.app_version = "1.1.1"
586
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
587
-
588
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
589
- event = get_event_from_payload(payload)
590
- expect(event["app"]["version"]).to eq("1.1.1")
591
- }
592
- end
593
-
594
- it "filters params from all payload hashes if they are set in default meta_data_filters" do
595
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
596
- report.meta_data.merge!({
597
- :request => {
598
- :params => {
599
- :password => "1234",
600
- :other_password => "12345",
601
- :other_data => "123456"
602
- },
603
- :cookie => "1234567890",
604
- :authorization => "token",
605
- :user_authorization => "token",
606
- :secret_key => "key",
607
- :user_secret => "key"
608
- }
609
- })
610
- report.meta_data.merge!({
611
- :session => {
612
- :"warden.user.user.key" => "1234",
613
- :"warden.user.foobar.key" => "1234",
614
- :"warden.user.test" => "1234"
615
- }
616
- })
617
- end
618
-
619
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
620
- event = get_event_from_payload(payload)
621
- expect(event["metaData"]).not_to be_nil
622
- expect(event["metaData"]["request"]).not_to be_nil
623
- expect(event["metaData"]["request"]["params"]).not_to be_nil
624
- expect(event["metaData"]["request"]["params"]["password"]).to eq("[FILTERED]")
625
- expect(event["metaData"]["request"]["params"]["other_password"]).to eq("[FILTERED]")
626
- expect(event["metaData"]["request"]["params"]["other_data"]).to eq("123456")
627
- expect(event["metaData"]["request"]["cookie"]).to eq("[FILTERED]")
628
- expect(event["metaData"]["request"]["authorization"]).to eq("[FILTERED]")
629
- expect(event["metaData"]["request"]["user_authorization"]).to eq("[FILTERED]")
630
- expect(event["metaData"]["request"]["secret_key"]).to eq("[FILTERED]")
631
- expect(event["metaData"]["request"]["user_secret"]).to eq("[FILTERED]")
632
- expect(event["metaData"]["session"]).not_to be_nil
633
- expect(event["metaData"]["session"]["warden.user.user.key"]).to eq("[FILTERED]")
634
- expect(event["metaData"]["session"]["warden.user.foobar.key"]).to eq("[FILTERED]")
635
- expect(event["metaData"]["session"]["warden.user.test"]).to eq("1234")
636
- }
637
- end
638
-
639
- it "filters params from all payload hashes if they are added to meta_data_filters" do
640
- Bugsnag.configuration.meta_data_filters << "other_data"
641
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
642
- report.meta_data.merge!({:request => {:params => {:password => "1234", :other_password => "123456", :other_data => "123456"}}})
643
- end
644
-
645
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
646
- event = get_event_from_payload(payload)
647
- expect(event["metaData"]).not_to be_nil
648
- expect(event["metaData"]["request"]).not_to be_nil
649
- expect(event["metaData"]["request"]["params"]).not_to be_nil
650
- expect(event["metaData"]["request"]["params"]["password"]).to eq("[FILTERED]")
651
- expect(event["metaData"]["request"]["params"]["other_password"]).to eq("[FILTERED]")
652
- expect(event["metaData"]["request"]["params"]["other_data"]).to eq("[FILTERED]")
653
- }
654
- end
655
-
656
- it "filters params from all payload hashes if they are added to meta_data_filters as regex" do
657
- Bugsnag.configuration.meta_data_filters << /other_data/
658
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
659
- report.meta_data.merge!({:request => {:params => {:password => "1234", :other_password => "123456", :other_data => "123456"}}})
660
- end
661
-
662
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
663
- event = get_event_from_payload(payload)
664
- expect(event["metaData"]).not_to be_nil
665
- expect(event["metaData"]["request"]).not_to be_nil
666
- expect(event["metaData"]["request"]["params"]).not_to be_nil
667
- expect(event["metaData"]["request"]["params"]["password"]).to eq("[FILTERED]")
668
- expect(event["metaData"]["request"]["params"]["other_password"]).to eq("[FILTERED]")
669
- expect(event["metaData"]["request"]["params"]["other_data"]).to eq("[FILTERED]")
670
- }
671
- end
672
-
673
- it "filters params from all payload hashes if they are added to meta_data_filters as partial regex" do
674
- Bugsnag.configuration.meta_data_filters << /r_data/
675
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
676
- report.meta_data.merge!({:request => {:params => {:password => "1234", :other_password => "123456", :other_data => "123456"}}})
677
- end
678
-
679
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
680
- event = get_event_from_payload(payload)
681
- expect(event["metaData"]).not_to be_nil
682
- expect(event["metaData"]["request"]).not_to be_nil
683
- expect(event["metaData"]["request"]["params"]).not_to be_nil
684
- expect(event["metaData"]["request"]["params"]["password"]).to eq("[FILTERED]")
685
- expect(event["metaData"]["request"]["params"]["other_password"]).to eq("[FILTERED]")
686
- expect(event["metaData"]["request"]["params"]["other_data"]).to eq("[FILTERED]")
687
- }
688
- end
689
-
690
- it "does not filter params from payload hashes if their values are nil" do
691
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
692
- report.meta_data.merge!({:request => {:params => {:nil_param => nil}}})
693
- end
694
-
695
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
696
- event = get_event_from_payload(payload)
697
- expect(event["metaData"]).not_to be_nil
698
- expect(event["metaData"]["request"]).not_to be_nil
699
- expect(event["metaData"]["request"]["params"]).not_to be_nil
700
- expect(event["metaData"]["request"]["params"]).to have_key("nil_param")
701
- }
702
- end
703
-
704
- it "does not apply filters outside of report.meta_data" do
705
- Bugsnag.configuration.meta_data_filters << "data"
706
-
707
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
708
- report.meta_data = {
709
- xyz: "abc",
710
- data: "123456"
711
- }
712
-
713
- report.user = {
714
- id: 123,
715
- data: "hello"
716
- }
717
- end
718
-
719
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
720
- event = get_event_from_payload(payload)
721
-
722
- expect(event["metaData"]).not_to be_nil
723
- expect(event["metaData"]["xyz"]).to eq("abc")
724
- expect(event["metaData"]["data"]).to eq("[FILTERED]")
725
-
726
- expect(event["user"]).not_to be_nil
727
- expect(event["user"]["data"]).to eq("hello")
728
- }
729
- end
730
-
731
- it "does not notify if report ignored" do
732
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
733
- report.ignore!
734
- end
735
-
736
- expect(Bugsnag).not_to have_sent_notification
737
- end
738
-
739
- context "ignore_classes" do
740
- context "as a constant" do
741
- it "ignores exception when its class is ignored" do
742
- Bugsnag.configuration.ignore_classes << BugsnagTestException
743
-
744
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
745
-
746
- expect(Bugsnag).not_to have_sent_notification
747
- end
748
-
749
- it "ignores exception when its ancestor is ignored" do
750
- Bugsnag.configuration.ignore_classes << BugsnagTestException
751
-
752
- Bugsnag.notify(BugsnagSubclassTestException.new("It crashed"))
753
-
754
- expect(Bugsnag).not_to have_sent_notification
755
- end
756
-
757
- it "ignores exception when the original exception is ignored" do
758
- Bugsnag.configuration.ignore_classes << BugsnagTestException
759
-
760
- ex = NestedException.new("Self-referential exception")
761
- ex.original_exception = BugsnagTestException.new("It crashed")
762
-
763
- Bugsnag.notify(ex)
764
-
765
- expect(Bugsnag).not_to have_sent_notification
766
- end
767
- end
768
-
769
- context "as a proc" do
770
- it "ignores exception when the proc returns true" do
771
- Bugsnag.configuration.ignore_classes << ->(exception) { true }
772
-
773
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
774
-
775
- expect(Bugsnag).not_to have_sent_notification
776
- end
777
-
778
- it "does not ignore exception when proc returns false" do
779
- Bugsnag.configuration.ignore_classes << ->(exception) { false }
780
-
781
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
782
-
783
- expect(Bugsnag).to have_sent_notification { |payload, headers|
784
- exception = get_exception_from_payload(payload)
785
-
786
- expect(exception["errorClass"]).to eq("BugsnagTestException")
787
- expect(exception["message"]).to eq("It crashed")
788
- }
789
- end
790
- end
791
- end
792
-
793
- context "discard_classes" do
794
- context "as a string" do
795
- it "discards exception when its class should be discarded" do
796
- Bugsnag.configuration.discard_classes << "BugsnagTestException"
797
-
798
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
799
-
800
- expect(Bugsnag).not_to have_sent_notification
801
- end
802
-
803
- it "discards exception when the original exception should be discarded" do
804
- Bugsnag.configuration.discard_classes << "BugsnagTestException"
805
-
806
- ex = NestedException.new("Self-referential exception")
807
- ex.original_exception = BugsnagTestException.new("It crashed")
808
-
809
- Bugsnag.notify(ex)
810
-
811
- expect(Bugsnag).not_to have_sent_notification
812
- end
813
-
814
- it "does not discard exception with a typo" do
815
- Bugsnag.configuration.discard_classes << "BugsnagToastException"
816
-
817
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
818
-
819
- expect(Bugsnag).to have_sent_notification { |payload, headers|
820
- exception = get_exception_from_payload(payload)
821
-
822
- expect(exception["errorClass"]).to eq("BugsnagTestException")
823
- expect(exception["message"]).to eq("It crashed")
824
- }
825
- end
826
-
827
- it "does not discard exception when its ancestor is discarded" do
828
- Bugsnag.configuration.discard_classes << "BugsnagTestException"
829
-
830
- Bugsnag.notify(BugsnagSubclassTestException.new("It crashed"))
831
-
832
- expect(Bugsnag).to have_sent_notification { |payload, headers|
833
- exception = get_exception_from_payload(payload)
834
-
835
- expect(exception["errorClass"]).to eq("BugsnagSubclassTestException")
836
- expect(exception["message"]).to eq("It crashed")
837
- }
838
- end
839
- end
840
-
841
- context "as a regexp" do
842
- it "discards exception when its class should be discarded" do
843
- Bugsnag.configuration.discard_classes << /^BugsnagTest.*/
844
-
845
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
846
-
847
- expect(Bugsnag).not_to have_sent_notification
848
- end
849
-
850
- it "discards exception when the original exception should be discarded" do
851
- Bugsnag.configuration.discard_classes << /^BugsnagTest.*/
852
-
853
- ex = NestedException.new("Self-referential exception")
854
- ex.original_exception = BugsnagTestException.new("It crashed")
855
-
856
- Bugsnag.notify(ex)
857
-
858
- expect(Bugsnag).not_to have_sent_notification
859
- end
860
-
861
- it "does not discard exception when regexp does not match" do
862
- Bugsnag.configuration.discard_classes << /^NotBugsnag.*/
863
-
864
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
865
-
866
- expect(Bugsnag).to have_sent_notification { |payload, headers|
867
- exception = get_exception_from_payload(payload)
868
-
869
- expect(exception["errorClass"]).to eq("BugsnagTestException")
870
- expect(exception["message"]).to eq("It crashed")
871
- }
872
- end
873
-
874
- it "does not discard exception when its ancestor is discarded" do
875
- Bugsnag.configuration.discard_classes << /^BugsnagTest.*/
876
-
877
- Bugsnag.notify(BugsnagSubclassTestException.new("It crashed"))
878
-
879
- expect(Bugsnag).to have_sent_notification { |payload, headers|
880
- exception = get_exception_from_payload(payload)
881
-
882
- expect(exception["errorClass"]).to eq("BugsnagSubclassTestException")
883
- expect(exception["message"]).to eq("It crashed")
884
- }
885
- end
886
- end
887
- end
888
-
889
- it "sends the cause of the exception" do
890
- begin
891
- begin
892
- raise "jiminey"
893
- rescue
894
- Ruby21Exception.raise! "cricket"
895
- end
896
- rescue
897
- Bugsnag.notify $!
898
- end
899
-
900
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
901
- event = get_event_from_payload(payload)
902
- expect(event["exceptions"].size).to eq(2)
903
- }
904
- end
905
-
906
- it "does not unwrap the same exception twice" do
907
- ex = NestedException.new("Self-referential exception")
908
- ex.original_exception = ex
909
-
910
- Bugsnag.notify(ex)
911
-
912
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
913
- event = get_event_from_payload(payload)
914
- expect(event["exceptions"].size).to eq(1)
915
- }
916
- end
917
-
918
- it "does not unwrap more than 5 exceptions" do
919
-
920
- first_ex = ex = NestedException.new("Deep exception")
921
- 10.times do |idx|
922
- ex = ex.original_exception = NestedException.new("Deep exception #{idx}")
923
- end
924
-
925
- Bugsnag.notify(first_ex)
926
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
927
- event = get_event_from_payload(payload)
928
- expect(event["exceptions"].size).to eq(5)
929
- }
930
- end
931
-
932
- it "calls to_exception on i18n error objects" do
933
- Bugsnag.notify(OpenStruct.new(:to_exception => BugsnagTestException.new("message")))
934
-
935
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
936
- exception = get_exception_from_payload(payload)
937
- expect(exception["errorClass"]).to eq("BugsnagTestException")
938
- expect(exception["message"]).to eq("message")
939
- }
940
- end
941
-
942
- it "generates runtimeerror for non exceptions" do
943
- notify_test_exception
944
-
945
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
946
- exception = get_exception_from_payload(payload)
947
- expect(exception["errorClass"]).to eq("RuntimeError")
948
- expect(exception["message"]).to eq("test message")
949
- }
950
- end
951
-
952
- it "supports unix-style paths in backtraces" do
953
- ex = BugsnagTestException.new("It crashed")
954
- ex.set_backtrace([
955
- "/Users/james/app/spec/notification_spec.rb:419",
956
- "/Some/path/rspec/example.rb:113:in `instance_eval'"
957
- ])
958
-
959
- Bugsnag.notify(ex)
960
-
961
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
962
- exception = get_exception_from_payload(payload)
963
- expect(exception["stacktrace"].length).to eq(2)
964
-
965
- line = exception["stacktrace"][0]
966
- expect(line["file"]).to eq("/Users/james/app/spec/notification_spec.rb")
967
- expect(line["lineNumber"]).to eq(419)
968
- expect(line["method"]).to be nil
969
-
970
- line = exception["stacktrace"][1]
971
- expect(line["file"]).to eq("/Some/path/rspec/example.rb")
972
- expect(line["lineNumber"]).to eq(113)
973
- expect(line["method"]).to eq("instance_eval")
974
- }
975
- end
976
-
977
- it "supports windows-style paths in backtraces" do
978
- ex = BugsnagTestException.new("It crashed")
979
- ex.set_backtrace([
980
- "C:/projects/test/app/controllers/users_controller.rb:13:in `index'",
981
- "C:/ruby/1.9.1/gems/actionpack-2.3.10/filters.rb:638:in `block in run_before_filters'"
982
- ])
983
-
984
- Bugsnag.notify(ex)
985
-
986
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
987
- exception = get_exception_from_payload(payload)
988
- expect(exception["stacktrace"].length).to eq(2)
989
-
990
- line = exception["stacktrace"][0]
991
- expect(line["file"]).to eq("C:/projects/test/app/controllers/users_controller.rb")
992
- expect(line["lineNumber"]).to eq(13)
993
- expect(line["method"]).to eq("index")
994
-
995
- line = exception["stacktrace"][1]
996
- expect(line["file"]).to eq("C:/ruby/1.9.1/gems/actionpack-2.3.10/filters.rb")
997
- expect(line["lineNumber"]).to eq(638)
998
- expect(line["method"]).to eq("block in run_before_filters")
999
- }
1000
- end
1001
-
1002
- it "should fix invalid utf8" do
1003
- invalid_data = "fl\xc3ff"
1004
- invalid_data.force_encoding('BINARY') if invalid_data.respond_to?(:force_encoding)
1005
-
1006
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
1007
- report.meta_data.merge!({fluff: {fluff: invalid_data}})
1008
- end
1009
-
1010
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
1011
- event = get_event_from_payload(payload)
1012
- if defined?(Encoding::UTF_8)
1013
- expect(event['metaData']['fluff']['fluff']).to match(/fl�ff/)
1014
- else
1015
- expect(event['metaData']['fluff']['fluff']).to match(/flff/)
1016
- end
1017
- }
1018
- end
1019
-
1020
- if RUBY_VERSION < '2.3.0'
1021
- it "should handle utf8 encoding errors in exceptions_list" do
1022
- invalid_data = "\"foo\xEBbar\""
1023
- invalid_data = invalid_data.force_encoding("utf-8") if invalid_data.respond_to?(:force_encoding)
1024
-
1025
- begin
1026
- JSON.parse(invalid_data)
1027
- rescue
1028
- Bugsnag.notify $!
1029
- end
1030
-
1031
- expect(Bugsnag).to have_sent_notification { |payload, headers|
1032
- if defined?(Encoding::UTF_8)
1033
- expect(payload.to_json).to match(/foo�bar/)
1034
- else
1035
- expect(payload.to_json).to match(/foobar/)
1036
- end
1037
- }
1038
- end
1039
- end
1040
-
1041
- it "should handle utf8 encoding errors in notification context" do
1042
- invalid_data = "\"foo\xEBbar\""
1043
- invalid_data = invalid_data.force_encoding("utf-8") if invalid_data.respond_to?(:force_encoding)
1044
-
1045
- begin
1046
- raise
1047
- rescue
1048
- Bugsnag.notify($!) do |report|
1049
- report.context = invalid_data
1050
- end
1051
- end
1052
-
1053
- expect(Bugsnag).to have_sent_notification { |payload, headers|
1054
- if defined?(Encoding::UTF_8)
1055
- expect(payload.to_json).to match(/foo�bar/)
1056
- else
1057
- expect(payload.to_json).to match(/foobar/)
1058
- end
1059
- }
1060
- end
1061
-
1062
- it "should handle utf8 encoding errors in notification app fields" do
1063
- invalid_data = "\"foo\xEBbar\""
1064
- invalid_data = invalid_data.force_encoding("utf-8") if invalid_data.respond_to?(:force_encoding)
1065
-
1066
- Bugsnag.configuration.app_version = invalid_data
1067
- Bugsnag.configuration.release_stage = invalid_data
1068
- Bugsnag.configuration.app_type = invalid_data
1069
-
1070
- begin
1071
- raise
1072
- rescue
1073
- Bugsnag.notify $!
1074
- end
1075
-
1076
- expect(Bugsnag).to have_sent_notification { |payload, headers|
1077
- if defined?(Encoding::UTF_8)
1078
- expect(payload.to_json).to match(/foo�bar/)
1079
- else
1080
- expect(payload.to_json).to match(/foobar/)
1081
- end
1082
- }
1083
- end
1084
-
1085
- it "should handle utf8 encoding errors in grouping_hash" do
1086
- invalid_data = "\"foo\xEBbar\""
1087
- invalid_data = invalid_data.force_encoding("utf-8") if invalid_data.respond_to?(:force_encoding)
1088
-
1089
- Bugsnag.before_notify_callbacks << lambda do |notif|
1090
- notif.grouping_hash = invalid_data
1091
- end
1092
-
1093
- begin
1094
- raise
1095
- rescue
1096
- Bugsnag.notify $!
1097
- end
1098
-
1099
- expect(Bugsnag).to have_sent_notification { |payload, headers|
1100
- if defined?(Encoding::UTF_8)
1101
- expect(payload.to_json).to match(/foo�bar/)
1102
- else
1103
- expect(payload.to_json).to match(/foobar/)
1104
- end
1105
- }
1106
- end
1107
-
1108
- it "should handle utf8 encoding errors in notification user fields" do
1109
- invalid_data = "\"foo\xEBbar\""
1110
- invalid_data = invalid_data.force_encoding("utf-8") if invalid_data.respond_to?(:force_encoding)
1111
-
1112
- Bugsnag.before_notify_callbacks << lambda do |notif|
1113
- notif.user = {
1114
- :email => "#{invalid_data}@foo.com",
1115
- :name => invalid_data
1116
- }
1117
- end
1118
-
1119
- begin
1120
- raise
1121
- rescue
1122
- Bugsnag.notify $!
1123
- end
1124
-
1125
- expect(Bugsnag).to have_sent_notification { |payload, headers|
1126
- if defined?(Encoding::UTF_8)
1127
- expect(payload.to_json).to match(/foo�bar/)
1128
- else
1129
- expect(payload.to_json).to match(/foobar/)
1130
- end
1131
- }
1132
- end
1133
-
1134
- it "should handle recursive metadata" do
1135
- a = [1, 2, 3]
1136
- b = [2, a]
1137
- a << b
1138
- c = [1, 2, 3]
1139
-
1140
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
1141
- report.add_tab(:some_tab, {
1142
- a: a,
1143
- b: b,
1144
- c: c
1145
- })
1146
- end
1147
-
1148
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
1149
- event = get_event_from_payload(payload)
1150
- expect(event["metaData"]["some_tab"]).to eq({
1151
- "a" => [1, 2, 3, [2, "[RECURSION]"]],
1152
- "b" => [2, "[RECURSION]"],
1153
- "c" => [1, 2, 3]
1154
- })
1155
- }
1156
- end
1157
-
1158
- it "does not detect two equal objects as recursion" do
1159
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
1160
- report.add_tab(:some_tab, {
1161
- data: [1, [1, 2], [1, 2], "a"]
1162
- })
1163
- end
1164
-
1165
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
1166
- event = get_event_from_payload(payload)
1167
- expect(event["metaData"]["some_tab"]).to eq({
1168
- "data" => [1, [1, 2], [1, 2], "a"]
1169
- })
1170
- }
1171
- end
1172
-
1173
- context "an object that throws if `to_s` is called" do
1174
- class StringRaiser
1175
- def to_s
1176
- raise 'Oh no you do not!'
1177
- end
1178
- end
1179
-
1180
- it "uses the string '[RAISED]' instead" do
1181
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
1182
- report.add_tab(:some_tab, {
1183
- data: [1, 2, StringRaiser.new]
1184
- })
1185
- end
1186
-
1187
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
1188
- event = get_event_from_payload(payload)
1189
- expect(event["metaData"]["some_tab"]).to eq({
1190
- "data" => [1, 2, "[RAISED]"]
1191
- })
1192
- }
1193
- end
1194
-
1195
- it "replaces hash key with '[RAISED]'" do
1196
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
1197
- report.add_tab(:some_tab, {
1198
- StringRaiser.new => 1
1199
- })
1200
- end
1201
-
1202
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
1203
- event = get_event_from_payload(payload)
1204
- expect(event["metaData"]["some_tab"]).to eq({
1205
- "[RAISED]" => "[FILTERED]"
1206
- })
1207
- }
1208
- end
1209
-
1210
- it "uses a single '[RAISED]'key when multiple keys raise" do
1211
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
1212
- report.add_tab(:some_tab, {
1213
- StringRaiser.new => 1,
1214
- StringRaiser.new => 2
1215
- })
1216
- end
1217
-
1218
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
1219
- event = get_event_from_payload(payload)
1220
- expect(event["metaData"]["some_tab"]).to eq({
1221
- "[RAISED]" => "[FILTERED]"
1222
- })
1223
- }
1224
- end
1225
- end
1226
-
1227
- context "an object that infinitely recurse if `to_s` is called" do
1228
- is_jruby = defined?(RUBY_ENGINE) && RUBY_ENGINE == 'jruby'
1229
-
1230
- class StringRecurser
1231
- def to_s
1232
- to_s
1233
- end
1234
- end
1235
-
1236
- it "uses the string '[RECURSION]' instead" do
1237
- skip "JRuby doesn't allow recovery from SystemStackErrors" if is_jruby
1238
-
1239
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
1240
- report.add_tab(:some_tab, {
1241
- data: [1, 2, StringRecurser.new]
1242
- })
1243
- end
1244
-
1245
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
1246
- event = get_event_from_payload(payload)
1247
- expect(event["metaData"]["some_tab"]).to eq({
1248
- "data" => [1, 2, "[RECURSION]"]
1249
- })
1250
- }
1251
- end
1252
-
1253
- it "replaces hash key with '[RECURSION]'" do
1254
- skip "JRuby doesn't allow recovery from SystemStackErrors" if is_jruby
1255
-
1256
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
1257
- report.add_tab(:some_tab, {
1258
- StringRecurser.new => 1
1259
- })
1260
- end
1261
-
1262
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
1263
- event = get_event_from_payload(payload)
1264
- expect(event["metaData"]["some_tab"]).to eq({
1265
- "[RECURSION]" => "[FILTERED]"
1266
- })
1267
- }
1268
- end
1269
-
1270
- it "uses a single '[RECURSION]'key when multiple keys recurse" do
1271
- skip "JRuby doesn't allow recovery from SystemStackErrors" if is_jruby
1272
-
1273
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
1274
- report.add_tab(:some_tab, {
1275
- StringRecurser.new => 1,
1276
- StringRecurser.new => 2
1277
- })
1278
- end
1279
-
1280
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
1281
- event = get_event_from_payload(payload)
1282
- expect(event["metaData"]["some_tab"]).to eq({
1283
- "[RECURSION]" => "[FILTERED]"
1284
- })
1285
- }
1286
- end
1287
- end
1288
-
1289
- it 'should handle exceptions with empty backtrace' do
1290
- begin
1291
- err = RuntimeError.new
1292
- err.set_backtrace([])
1293
- raise err
1294
- rescue
1295
- Bugsnag.notify $!
1296
- end
1297
-
1298
- expect(Bugsnag).to have_sent_notification { |payload, headers|
1299
- exception = get_exception_from_payload(payload)
1300
- expect(exception['stacktrace'].size).to be > 0
1301
- }
1302
- end
1303
-
1304
- it 'should use defaults when notify is called' do
1305
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
1306
-
1307
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
1308
- event = payload["events"][0]
1309
- expect(event["unhandled"]).to be false
1310
- expect(event["severityReason"]).to eq({"type" => "handledException"})
1311
- }
1312
- end
1313
-
1314
- it 'should attach severity reason through a block when auto_notify is true' do
1315
- Bugsnag.notify(BugsnagTestException.new("It crashed"), true) do |report|
1316
- report.severity_reason = {
1317
- :type => "middleware_handler",
1318
- :attributes => {
1319
- :name => "middleware_test"
1320
- }
1321
- }
1322
- end
1323
-
1324
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
1325
- event = payload["events"][0]
1326
- expect(event["severityReason"]).to eq(
1327
- {
1328
- "type" => "middleware_handler",
1329
- "attributes" => {
1330
- "name" => "middleware_test"
1331
- }
1332
- }
1333
- )
1334
- expect(event["unhandled"]).to be true
1335
- }
1336
- end
1337
-
1338
- it 'should not attach severity reason from callback when auto_notify is false' do
1339
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
1340
- report.severity_reason = {
1341
- :type => "middleware_handler",
1342
- :attributes => {
1343
- :name => "middleware_test"
1344
- }
1345
- }
1346
- end
1347
-
1348
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
1349
- event = payload["events"][0]
1350
- expect(event["unhandled"]).to be false
1351
- expect(event["severityReason"]).to eq({"type" => "handledException"})
1352
- }
1353
- end
1354
-
1355
- it 'does not notify if skip_bugsnag is true' do
1356
- exception = BugsnagTestException.new("It crashed")
1357
- exception.skip_bugsnag = true
1358
- Bugsnag.notify(exception)
1359
- expect(Bugsnag).not_to have_sent_notification
1360
- end
1361
-
1362
- it 'uses an appropriate message if nil is notified' do
1363
- Bugsnag.notify(nil)
1364
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
1365
- event = payload["events"][0]
1366
- exception = event["exceptions"][0]
1367
- expect(exception["errorClass"]).to eq("RuntimeError")
1368
- expect(exception["message"]).to eq("'nil' was notified as an exception")
1369
- }
1370
- end
1371
-
1372
- it "includes bugsnag lines marked out of project" do
1373
- notify_test_exception
1374
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
1375
- exception = get_exception_from_payload(payload)
1376
-
1377
- bugsnag_count = 0
1378
-
1379
- exception["stacktrace"].each do |frame|
1380
- if /.*lib\/bugsnag.*\.rb/.match(frame["file"])
1381
- bugsnag_count += 1
1382
- expect(frame["inProject"]).to be_nil
1383
- end
1384
- end
1385
-
1386
- # 6 is used here as the called bugsnag frames for a `notify` call should be:
1387
- # - Bugsnag.notify
1388
- # - Report.new
1389
- # - Report.initialize
1390
- # - Report.generate_exceptions_list
1391
- # - Report.generate_exceptions_list | raw_exceptions.map
1392
- # - Report.generate_exceptions_list | raw_exceptions.map | block
1393
- # However, JRUBY does not include the `Report.new` frame, resulting in 5 bugsnag frames
1394
- if defined?(JRUBY_VERSION)
1395
- frame_count = 5
1396
- else
1397
- frame_count = 6
1398
- end
1399
-
1400
- expect(bugsnag_count).to equal frame_count
1401
- }
1402
- end
1403
-
1404
- describe "breadcrumbs" do
1405
- let(:timestamp_regex) { /^\d{4}\-\d{2}\-\d{2}T\d{2}:\d{2}:[\d\.]+Z$/ }
1406
-
1407
- it "includes left breadcrumbs" do
1408
- Bugsnag.leave_breadcrumb("Test breadcrumb")
1409
- notify_test_exception
1410
- expect(Bugsnag).to have_sent_notification { |payload, headers|
1411
- event = get_event_from_payload(payload)
1412
- expect(event["breadcrumbs"].size).to eq(1)
1413
- expect(event["breadcrumbs"].first).to match({
1414
- "name" => "Test breadcrumb",
1415
- "type" => "manual",
1416
- "metaData" => {},
1417
- "timestamp" => match(timestamp_regex)
1418
- })
1419
- }
1420
- end
1421
-
1422
- it "filters left breadcrumbs" do
1423
- Bugsnag.leave_breadcrumb("Test breadcrumb", {
1424
- :forbidden_key => false,
1425
- :allowed_key => true
1426
- })
1427
- Bugsnag.configuration.meta_data_filters << "forbidden"
1428
- notify_test_exception
1429
- expect(Bugsnag).to have_sent_notification { |payload, headers|
1430
- event = get_event_from_payload(payload)
1431
- expect(event["breadcrumbs"].size).to eq(1)
1432
- expect(event["breadcrumbs"].first).to match({
1433
- "name" => "Test breadcrumb",
1434
- "type" => "manual",
1435
- "metaData" => {
1436
- "forbidden_key" => "[FILTERED]",
1437
- "allowed_key" => true
1438
- },
1439
- "timestamp" => match(timestamp_regex)
1440
- })
1441
- }
1442
- end
1443
-
1444
- it "defaults to an empty array" do
1445
- notify_test_exception
1446
- expect(Bugsnag).to have_sent_notification { |payload, headers|
1447
- event = get_event_from_payload(payload)
1448
- expect(event["breadcrumbs"].size).to eq(0)
1449
- }
1450
- end
1451
-
1452
- it "allows breadcrumbs to be editted in callbacks" do
1453
- Bugsnag.leave_breadcrumb("Test breadcrumb")
1454
- Bugsnag.before_notify_callbacks << Proc.new { |report|
1455
- breadcrumb = report.breadcrumbs.first
1456
- breadcrumb.meta_data = {:a => 1, :b => 2}
1457
- }
1458
- notify_test_exception
1459
- expect(Bugsnag).to have_sent_notification { |payload, headers|
1460
- event = get_event_from_payload(payload)
1461
- expect(event["breadcrumbs"].size).to eq(1)
1462
- expect(event["breadcrumbs"].first).to match({
1463
- "name" => "Test breadcrumb",
1464
- "type" => "manual",
1465
- "metaData" => {"a" => 1, "b" => 2},
1466
- "timestamp" => match(timestamp_regex)
1467
- })
1468
- }
1469
- end
1470
- end
1471
-
1472
- describe "#summary" do
1473
- it "provides a hash of the name, message, and severity" do
1474
- begin
1475
- 1/0
1476
- rescue ZeroDivisionError => e
1477
- report = Bugsnag::Report.new(e, Bugsnag.configuration)
1478
-
1479
- expect(report.summary).to eq({
1480
- :error_class => "ZeroDivisionError",
1481
- :message => "divided by 0",
1482
- :severity => "warning"
1483
- })
1484
- end
1485
- end
1486
-
1487
- it "handles strings" do
1488
- report = Bugsnag::Report.new("test string", Bugsnag.configuration)
1489
-
1490
- expect(report.summary).to eq({
1491
- :error_class => "RuntimeError",
1492
- :message => "test string",
1493
- :severity => "warning"
1494
- })
1495
- end
1496
-
1497
- it "handles error edge cases" do
1498
- report = Bugsnag::Report.new(Timeout::Error, Bugsnag.configuration)
1499
-
1500
- expect(report.summary).to eq({
1501
- :error_class => "Timeout::Error",
1502
- :message => "Timeout::Error",
1503
- :severity => "warning"
1504
- })
1505
- end
1506
-
1507
- it "handles empty exceptions" do
1508
- begin
1509
- 1/0
1510
- rescue ZeroDivisionError => e
1511
- report = Bugsnag::Report.new(e, Bugsnag.configuration)
1512
-
1513
- report.exceptions = []
1514
-
1515
- expect(report.summary).to eq({
1516
- :error_class => "Unknown",
1517
- :severity => "warning"
1518
- })
1519
- end
1520
- end
1521
-
1522
- it "handles removed exceptions" do
1523
- begin
1524
- 1/0
1525
- rescue ZeroDivisionError => e
1526
- report = Bugsnag::Report.new(e, Bugsnag.configuration)
1527
-
1528
- report.exceptions = nil
1529
-
1530
- expect(report.summary).to eq({
1531
- :error_class => "Unknown",
1532
- :severity => "warning"
1533
- })
1534
- end
1535
- end
1536
-
1537
- it "handles exceptions being replaced" do
1538
- begin
1539
- 1/0
1540
- rescue ZeroDivisionError => e
1541
- report = Bugsnag::Report.new(e, Bugsnag.configuration)
1542
-
1543
- report.exceptions = "no one should ever do this"
1544
-
1545
- expect(report.summary).to eq({
1546
- :error_class => "Unknown",
1547
- :severity => "warning"
1548
- })
1549
- end
1550
- end
1551
- end
1552
-
1553
- if defined?(JRUBY_VERSION)
1554
-
1555
- it "works with java.lang.Throwables" do
1556
- begin
1557
- JRubyException.raise!
1558
- rescue
1559
- Bugsnag.notify $!
1560
- end
1561
-
1562
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
1563
- exception = get_exception_from_payload(payload)
1564
- expect(exception["errorClass"]).to eq('Java::JavaLang::NullPointerException')
1565
- expect(exception["message"]).to eq("")
1566
- expect(exception["stacktrace"].size).to be > 0
1567
- }
1568
- end
1569
- end
1570
-
1571
- it 'includes device data when notify is called' do
1572
- Bugsnag.configuration.hostname = 'test-host'
1573
- Bugsnag.configuration.runtime_versions["ruby"] = '9.9.9'
1574
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
1575
-
1576
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
1577
- event = payload["events"][0]
1578
- expect(event["device"]["hostname"]).to eq('test-host')
1579
- expect(event["device"]["runtimeVersions"]["ruby"]).to eq('9.9.9')
1580
- }
1581
- end
1582
- end
1583
- # rubocop:enable Metrics/BlockLength