bugsnag 6.14.0 → 6.19.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/.yardopts +11 -0
  3. data/CHANGELOG.md +74 -0
  4. data/VERSION +1 -1
  5. data/bugsnag.gemspec +1 -1
  6. data/lib/bugsnag.rb +116 -17
  7. data/lib/bugsnag/breadcrumbs/breadcrumb.rb +1 -1
  8. data/lib/bugsnag/breadcrumbs/validator.rb +0 -22
  9. data/lib/bugsnag/code_extractor.rb +137 -0
  10. data/lib/bugsnag/configuration.rb +209 -24
  11. data/lib/bugsnag/delivery/synchronous.rb +1 -1
  12. data/lib/bugsnag/delivery/thread_queue.rb +18 -3
  13. data/lib/bugsnag/helpers.rb +17 -4
  14. data/lib/bugsnag/integrations/delayed_job.rb +13 -1
  15. data/lib/bugsnag/integrations/mailman.rb +2 -1
  16. data/lib/bugsnag/integrations/que.rb +2 -1
  17. data/lib/bugsnag/integrations/rack.rb +3 -1
  18. data/lib/bugsnag/integrations/railtie.rb +17 -5
  19. data/lib/bugsnag/integrations/rake.rb +4 -2
  20. data/lib/bugsnag/integrations/resque.rb +12 -5
  21. data/lib/bugsnag/integrations/shoryuken.rb +2 -1
  22. data/lib/bugsnag/integrations/sidekiq.rb +1 -2
  23. data/lib/bugsnag/middleware/delayed_job.rb +1 -0
  24. data/lib/bugsnag/middleware_stack.rb +38 -3
  25. data/lib/bugsnag/on_error_callbacks.rb +33 -0
  26. data/lib/bugsnag/report.rb +85 -3
  27. data/lib/bugsnag/session_tracker.rb +3 -3
  28. data/lib/bugsnag/stacktrace.rb +25 -68
  29. metadata +6 -620
  30. data/.buildkite/pipeline.yml +0 -470
  31. data/.github/PULL_REQUEST_TEMPLATE.md +0 -84
  32. data/.gitignore +0 -55
  33. data/.rdoc_options +0 -27
  34. data/.rspec +0 -3
  35. data/.rubocop.yml +0 -57
  36. data/.rubocop_todo.yml +0 -1049
  37. data/CONTRIBUTING.md +0 -64
  38. data/Gemfile +0 -50
  39. data/Rakefile +0 -37
  40. data/TESTING.md +0 -81
  41. data/UPGRADING.md +0 -91
  42. data/docker-compose.yml +0 -46
  43. data/dockerfiles/Dockerfile.jruby-unit-tests +0 -13
  44. data/dockerfiles/Dockerfile.ruby-maze-runner +0 -26
  45. data/dockerfiles/Dockerfile.ruby-unit-tests +0 -12
  46. data/features/.gitignore +0 -1
  47. data/features/delayed_job.feature +0 -36
  48. data/features/fixtures/delayed_job/Dockerfile +0 -15
  49. data/features/fixtures/delayed_job/app/.gitignore +0 -21
  50. data/features/fixtures/delayed_job/app/Gemfile +0 -57
  51. data/features/fixtures/delayed_job/app/README.md +0 -24
  52. data/features/fixtures/delayed_job/app/Rakefile +0 -24
  53. data/features/fixtures/delayed_job/app/app/assets/config/manifest.js +0 -3
  54. data/features/fixtures/delayed_job/app/app/assets/images/.keep +0 -0
  55. data/features/fixtures/delayed_job/app/app/assets/javascripts/application.js +0 -16
  56. data/features/fixtures/delayed_job/app/app/assets/javascripts/cable.js +0 -13
  57. data/features/fixtures/delayed_job/app/app/assets/javascripts/channels/.keep +0 -0
  58. data/features/fixtures/delayed_job/app/app/assets/stylesheets/application.css +0 -15
  59. data/features/fixtures/delayed_job/app/app/channels/application_cable/channel.rb +0 -4
  60. data/features/fixtures/delayed_job/app/app/channels/application_cable/connection.rb +0 -4
  61. data/features/fixtures/delayed_job/app/app/controllers/application_controller.rb +0 -3
  62. data/features/fixtures/delayed_job/app/app/controllers/concerns/.keep +0 -0
  63. data/features/fixtures/delayed_job/app/app/helpers/application_helper.rb +0 -2
  64. data/features/fixtures/delayed_job/app/app/jobs/application_job.rb +0 -2
  65. data/features/fixtures/delayed_job/app/app/mailers/application_mailer.rb +0 -4
  66. data/features/fixtures/delayed_job/app/app/models/application_record.rb +0 -3
  67. data/features/fixtures/delayed_job/app/app/models/concerns/.keep +0 -0
  68. data/features/fixtures/delayed_job/app/app/models/test_model.rb +0 -10
  69. data/features/fixtures/delayed_job/app/app/views/layouts/application.html.erb +0 -14
  70. data/features/fixtures/delayed_job/app/app/views/layouts/mailer.html.erb +0 -13
  71. data/features/fixtures/delayed_job/app/app/views/layouts/mailer.text.erb +0 -1
  72. data/features/fixtures/delayed_job/app/config.ru +0 -5
  73. data/features/fixtures/delayed_job/app/config/application.rb +0 -15
  74. data/features/fixtures/delayed_job/app/config/boot.rb +0 -3
  75. data/features/fixtures/delayed_job/app/config/cable.yml +0 -9
  76. data/features/fixtures/delayed_job/app/config/database.yml +0 -25
  77. data/features/fixtures/delayed_job/app/config/environment.rb +0 -5
  78. data/features/fixtures/delayed_job/app/config/environments/development.rb +0 -54
  79. data/features/fixtures/delayed_job/app/config/environments/production.rb +0 -86
  80. data/features/fixtures/delayed_job/app/config/environments/test.rb +0 -42
  81. data/features/fixtures/delayed_job/app/config/initializers/application_controller_renderer.rb +0 -8
  82. data/features/fixtures/delayed_job/app/config/initializers/assets.rb +0 -11
  83. data/features/fixtures/delayed_job/app/config/initializers/backtrace_silencers.rb +0 -7
  84. data/features/fixtures/delayed_job/app/config/initializers/bugsnag.rb +0 -14
  85. data/features/fixtures/delayed_job/app/config/initializers/cookies_serializer.rb +0 -5
  86. data/features/fixtures/delayed_job/app/config/initializers/delayed_job.rb +0 -3
  87. data/features/fixtures/delayed_job/app/config/initializers/filter_parameter_logging.rb +0 -4
  88. data/features/fixtures/delayed_job/app/config/initializers/inflections.rb +0 -16
  89. data/features/fixtures/delayed_job/app/config/initializers/mime_types.rb +0 -4
  90. data/features/fixtures/delayed_job/app/config/initializers/new_framework_defaults.rb +0 -26
  91. data/features/fixtures/delayed_job/app/config/initializers/session_store.rb +0 -3
  92. data/features/fixtures/delayed_job/app/config/initializers/wrap_parameters.rb +0 -14
  93. data/features/fixtures/delayed_job/app/config/locales/en.yml +0 -23
  94. data/features/fixtures/delayed_job/app/config/puma.rb +0 -47
  95. data/features/fixtures/delayed_job/app/config/routes.rb +0 -3
  96. data/features/fixtures/delayed_job/app/config/secrets.yml +0 -22
  97. data/features/fixtures/delayed_job/app/config/spring.rb +0 -6
  98. data/features/fixtures/delayed_job/app/db/migrate/20181024232549_create_delayed_jobs.rb +0 -22
  99. data/features/fixtures/delayed_job/app/db/migrate/20181024232817_create_test_models.rb +0 -8
  100. data/features/fixtures/delayed_job/app/db/schema.rb +0 -30
  101. data/features/fixtures/delayed_job/app/db/seeds.rb +0 -7
  102. data/features/fixtures/delayed_job/app/lib/assets/.keep +0 -0
  103. data/features/fixtures/delayed_job/app/lib/tasks/.keep +0 -0
  104. data/features/fixtures/delayed_job/app/log/.keep +0 -0
  105. data/features/fixtures/delayed_job/app/public/404.html +0 -67
  106. data/features/fixtures/delayed_job/app/public/422.html +0 -67
  107. data/features/fixtures/delayed_job/app/public/500.html +0 -66
  108. data/features/fixtures/delayed_job/app/public/apple-touch-icon-precomposed.png +0 -0
  109. data/features/fixtures/delayed_job/app/public/apple-touch-icon.png +0 -0
  110. data/features/fixtures/delayed_job/app/public/favicon.ico +0 -0
  111. data/features/fixtures/delayed_job/app/public/robots.txt +0 -5
  112. data/features/fixtures/delayed_job/app/test/controllers/.keep +0 -0
  113. data/features/fixtures/delayed_job/app/test/fixtures/.keep +0 -0
  114. data/features/fixtures/delayed_job/app/test/fixtures/files/.keep +0 -0
  115. data/features/fixtures/delayed_job/app/test/fixtures/test_models.yml +0 -11
  116. data/features/fixtures/delayed_job/app/test/helpers/.keep +0 -0
  117. data/features/fixtures/delayed_job/app/test/integration/.keep +0 -0
  118. data/features/fixtures/delayed_job/app/test/mailers/.keep +0 -0
  119. data/features/fixtures/delayed_job/app/test/models/.keep +0 -0
  120. data/features/fixtures/delayed_job/app/test/models/test_model_test.rb +0 -7
  121. data/features/fixtures/delayed_job/app/test/test_helper.rb +0 -10
  122. data/features/fixtures/delayed_job/app/tmp/.keep +0 -0
  123. data/features/fixtures/docker-compose.yml +0 -299
  124. data/features/fixtures/expected_breadcrumbs/active_job.json +0 -9
  125. data/features/fixtures/expected_breadcrumbs/mongo_failed.json +0 -15
  126. data/features/fixtures/expected_breadcrumbs/mongo_filtered_request.json +0 -15
  127. data/features/fixtures/expected_breadcrumbs/mongo_filtered_result.json +0 -15
  128. data/features/fixtures/expected_breadcrumbs/mongo_success.json +0 -14
  129. data/features/fixtures/expected_breadcrumbs/request.json +0 -13
  130. data/features/fixtures/expected_breadcrumbs/sql_with_bindings.json +0 -12
  131. data/features/fixtures/expected_breadcrumbs/sql_without_bindings.json +0 -11
  132. data/features/fixtures/plain/.dockerignore +0 -2
  133. data/features/fixtures/plain/Dockerfile +0 -11
  134. data/features/fixtures/plain/app/Gemfile +0 -3
  135. data/features/fixtures/plain/app/app.rb +0 -38
  136. data/features/fixtures/plain/app/configuration/api_key.rb +0 -9
  137. data/features/fixtures/plain/app/configuration/proxy.rb +0 -14
  138. data/features/fixtures/plain/app/configuration/send_handled.rb +0 -7
  139. data/features/fixtures/plain/app/configuration/send_unhandled.rb +0 -9
  140. data/features/fixtures/plain/app/delivery/fork_threadpool.rb +0 -27
  141. data/features/fixtures/plain/app/delivery/synchronous.rb +0 -14
  142. data/features/fixtures/plain/app/delivery/threadpool.rb +0 -14
  143. data/features/fixtures/plain/app/exception_data/crash.rb +0 -34
  144. data/features/fixtures/plain/app/exception_data/handled_context.rb +0 -10
  145. data/features/fixtures/plain/app/exception_data/handled_hash.rb +0 -10
  146. data/features/fixtures/plain/app/exception_data/handled_meta_data.rb +0 -10
  147. data/features/fixtures/plain/app/exception_data/handled_user_id.rb +0 -10
  148. data/features/fixtures/plain/app/exception_data/unhandled_context.rb +0 -7
  149. data/features/fixtures/plain/app/exception_data/unhandled_hash.rb +0 -7
  150. data/features/fixtures/plain/app/exception_data/unhandled_meta_data.rb +0 -7
  151. data/features/fixtures/plain/app/exception_data/unhandled_user_id.rb +0 -7
  152. data/features/fixtures/plain/app/filters/additional_filters.rb +0 -11
  153. data/features/fixtures/plain/app/filters/default_filters.rb +0 -15
  154. data/features/fixtures/plain/app/handled/block_metadata.rb +0 -15
  155. data/features/fixtures/plain/app/handled/ignore_exception.rb +0 -12
  156. data/features/fixtures/plain/app/handled/notify_exception.rb +0 -9
  157. data/features/fixtures/plain/app/handled/notify_string.rb +0 -9
  158. data/features/fixtures/plain/app/ignore_classes/handled.rb +0 -8
  159. data/features/fixtures/plain/app/ignore_classes/ignore_error.rb +0 -8
  160. data/features/fixtures/plain/app/ignore_classes/unhandled.rb +0 -4
  161. data/features/fixtures/plain/app/report_modification/add_tab.rb +0 -16
  162. data/features/fixtures/plain/app/report_modification/add_tab_existing.rb +0 -22
  163. data/features/fixtures/plain/app/report_modification/add_tab_override.rb +0 -19
  164. data/features/fixtures/plain/app/report_modification/ignore_report.rb +0 -9
  165. data/features/fixtures/plain/app/report_modification/initiators/handled_before_notify.rb +0 -10
  166. data/features/fixtures/plain/app/report_modification/initiators/handled_block.rb +0 -8
  167. data/features/fixtures/plain/app/report_modification/initiators/unhandled_before_notify.rb +0 -11
  168. data/features/fixtures/plain/app/report_modification/modify_api_key.rb +0 -9
  169. data/features/fixtures/plain/app/report_modification/modify_severity.rb +0 -9
  170. data/features/fixtures/plain/app/report_modification/remove_user_details.rb +0 -14
  171. data/features/fixtures/plain/app/report_modification/set_custom_user_details.rb +0 -16
  172. data/features/fixtures/plain/app/report_modification/set_user_details.rb +0 -13
  173. data/features/fixtures/plain/app/stack_frame_modification/initiators/handled_before_notify.rb +0 -29
  174. data/features/fixtures/plain/app/stack_frame_modification/initiators/handled_block.rb +0 -24
  175. data/features/fixtures/plain/app/stack_frame_modification/initiators/unhandled_before_notify.rb +0 -26
  176. data/features/fixtures/plain/app/stack_frame_modification/mark_frames_in_project.rb +0 -13
  177. data/features/fixtures/plain/app/stack_frame_modification/remove_stack_frame.rb +0 -9
  178. data/features/fixtures/plain/app/unhandled/bad_syntax.rb +0 -1
  179. data/features/fixtures/plain/app/unhandled/custom_error.rb +0 -9
  180. data/features/fixtures/plain/app/unhandled/interrupt.rb +0 -6
  181. data/features/fixtures/plain/app/unhandled/load_error.rb +0 -6
  182. data/features/fixtures/plain/app/unhandled/local_jump_error.rb +0 -10
  183. data/features/fixtures/plain/app/unhandled/name_error.rb +0 -6
  184. data/features/fixtures/plain/app/unhandled/no_method_error.rb +0 -6
  185. data/features/fixtures/plain/app/unhandled/runtime_error.rb +0 -6
  186. data/features/fixtures/plain/app/unhandled/syntax_error.rb +0 -6
  187. data/features/fixtures/plain/app/unhandled/system_call_error.rb +0 -6
  188. data/features/fixtures/plain/app/unhandled/system_exit.rb +0 -6
  189. data/features/fixtures/plain/json/delivery_fork.json +0 -4
  190. data/features/fixtures/plain/json/delivery_synchronous.json +0 -4
  191. data/features/fixtures/plain/json/delivery_threadpool.json +0 -4
  192. data/features/fixtures/plain/json/filters_default_metadata_filters.json +0 -9
  193. data/features/fixtures/rack1/.dockerignore +0 -1
  194. data/features/fixtures/rack1/Dockerfile +0 -13
  195. data/features/fixtures/rack1/Gemfile +0 -4
  196. data/features/fixtures/rack1/app.rb +0 -8
  197. data/features/fixtures/rack2/.dockerignore +0 -1
  198. data/features/fixtures/rack2/Dockerfile +0 -13
  199. data/features/fixtures/rack2/Gemfile +0 -4
  200. data/features/fixtures/rack2/app.rb +0 -8
  201. data/features/fixtures/rails3/.dockerignore +0 -1
  202. data/features/fixtures/rails3/Dockerfile +0 -15
  203. data/features/fixtures/rails3/app/.gitignore +0 -15
  204. data/features/fixtures/rails3/app/Gemfile +0 -17
  205. data/features/fixtures/rails3/app/Rakefile +0 -7
  206. data/features/fixtures/rails3/app/app/assets/images/rails.png +0 -0
  207. data/features/fixtures/rails3/app/app/assets/javascripts/application.js +0 -15
  208. data/features/fixtures/rails3/app/app/assets/stylesheets/application.css +0 -13
  209. data/features/fixtures/rails3/app/app/controllers/api_key_controller.rb +0 -20
  210. data/features/fixtures/rails3/app/app/controllers/app_type_controller.rb +0 -20
  211. data/features/fixtures/rails3/app/app/controllers/app_version_controller.rb +0 -25
  212. data/features/fixtures/rails3/app/app/controllers/application_controller.rb +0 -7
  213. data/features/fixtures/rails3/app/app/controllers/auto_notify_controller.rb +0 -31
  214. data/features/fixtures/rails3/app/app/controllers/before_notify_controller.rb +0 -44
  215. data/features/fixtures/rails3/app/app/controllers/breadcrumbs_controller.rb +0 -19
  216. data/features/fixtures/rails3/app/app/controllers/handled_controller.rb +0 -26
  217. data/features/fixtures/rails3/app/app/controllers/ignore_classes_controller.rb +0 -23
  218. data/features/fixtures/rails3/app/app/controllers/metadata_filters_controller.rb +0 -16
  219. data/features/fixtures/rails3/app/app/controllers/project_root_controller.rb +0 -25
  220. data/features/fixtures/rails3/app/app/controllers/release_stage_controller.rb +0 -20
  221. data/features/fixtures/rails3/app/app/controllers/send_code_controller.rb +0 -20
  222. data/features/fixtures/rails3/app/app/controllers/send_environment_controller.rb +0 -12
  223. data/features/fixtures/rails3/app/app/controllers/session_tracking_controller.rb +0 -24
  224. data/features/fixtures/rails3/app/app/controllers/unhandled_controller.rb +0 -11
  225. data/features/fixtures/rails3/app/app/controllers/warden_controller.rb +0 -30
  226. data/features/fixtures/rails3/app/app/helpers/application_helper.rb +0 -2
  227. data/features/fixtures/rails3/app/app/mailers/.gitkeep +0 -0
  228. data/features/fixtures/rails3/app/app/models/.gitkeep +0 -0
  229. data/features/fixtures/rails3/app/app/models/user.rb +0 -6
  230. data/features/fixtures/rails3/app/app/views/layouts/application.html.erb +0 -14
  231. data/features/fixtures/rails3/app/config.ru +0 -4
  232. data/features/fixtures/rails3/app/config/application.rb +0 -67
  233. data/features/fixtures/rails3/app/config/boot.rb +0 -6
  234. data/features/fixtures/rails3/app/config/database.yml +0 -31
  235. data/features/fixtures/rails3/app/config/environment.rb +0 -5
  236. data/features/fixtures/rails3/app/config/environments/development.rb +0 -37
  237. data/features/fixtures/rails3/app/config/environments/production.rb +0 -67
  238. data/features/fixtures/rails3/app/config/environments/rails_env.rb +0 -37
  239. data/features/fixtures/rails3/app/config/initializers/bugsnag.rb +0 -21
  240. data/features/fixtures/rails3/app/config/initializers/secret_token.rb +0 -7
  241. data/features/fixtures/rails3/app/config/initializers/session_store.rb +0 -8
  242. data/features/fixtures/rails3/app/config/initializers/warden.rb +0 -3
  243. data/features/fixtures/rails3/app/config/initializers/wrap_parameters.rb +0 -14
  244. data/features/fixtures/rails3/app/config/locales/en.yml +0 -5
  245. data/features/fixtures/rails3/app/config/routes.rb +0 -19
  246. data/features/fixtures/rails3/app/db/migrate/20180423142727_create_users.rb +0 -45
  247. data/features/fixtures/rails3/app/db/schema.rb +0 -37
  248. data/features/fixtures/rails3/app/db/seeds.rb +0 -7
  249. data/features/fixtures/rails3/app/lib/assets/.gitkeep +0 -0
  250. data/features/fixtures/rails3/app/lib/strategies/token_strategy.rb +0 -12
  251. data/features/fixtures/rails3/app/lib/tasks/.gitkeep +0 -0
  252. data/features/fixtures/rails3/app/log/.gitkeep +0 -0
  253. data/features/fixtures/rails3/app/public/404.html +0 -26
  254. data/features/fixtures/rails3/app/public/422.html +0 -26
  255. data/features/fixtures/rails3/app/public/500.html +0 -25
  256. data/features/fixtures/rails3/app/public/favicon.ico +0 -0
  257. data/features/fixtures/rails3/app/public/index.html +0 -241
  258. data/features/fixtures/rails3/app/public/robots.txt +0 -5
  259. data/features/fixtures/rails3/app/script/rails +0 -6
  260. data/features/fixtures/rails4/.dockerignore +0 -1
  261. data/features/fixtures/rails4/Dockerfile +0 -17
  262. data/features/fixtures/rails4/app/.gitignore +0 -16
  263. data/features/fixtures/rails4/app/Gemfile +0 -46
  264. data/features/fixtures/rails4/app/README.rdoc +0 -28
  265. data/features/fixtures/rails4/app/Rakefile +0 -6
  266. data/features/fixtures/rails4/app/app/assets/images/.keep +0 -0
  267. data/features/fixtures/rails4/app/app/assets/javascripts/application.js +0 -16
  268. data/features/fixtures/rails4/app/app/assets/stylesheets/application.css +0 -13
  269. data/features/fixtures/rails4/app/app/controllers/api_key_controller.rb +0 -20
  270. data/features/fixtures/rails4/app/app/controllers/app_type_controller.rb +0 -20
  271. data/features/fixtures/rails4/app/app/controllers/app_version_controller.rb +0 -25
  272. data/features/fixtures/rails4/app/app/controllers/application_controller.rb +0 -7
  273. data/features/fixtures/rails4/app/app/controllers/auto_notify_controller.rb +0 -31
  274. data/features/fixtures/rails4/app/app/controllers/before_notify_controller.rb +0 -44
  275. data/features/fixtures/rails4/app/app/controllers/breadcrumbs_controller.rb +0 -26
  276. data/features/fixtures/rails4/app/app/controllers/concerns/.keep +0 -0
  277. data/features/fixtures/rails4/app/app/controllers/devise_controller.rb +0 -32
  278. data/features/fixtures/rails4/app/app/controllers/handled_controller.rb +0 -26
  279. data/features/fixtures/rails4/app/app/controllers/ignore_classes_controller.rb +0 -23
  280. data/features/fixtures/rails4/app/app/controllers/metadata_filters_controller.rb +0 -16
  281. data/features/fixtures/rails4/app/app/controllers/mongo_controller.rb +0 -23
  282. data/features/fixtures/rails4/app/app/controllers/project_root_controller.rb +0 -25
  283. data/features/fixtures/rails4/app/app/controllers/release_stage_controller.rb +0 -20
  284. data/features/fixtures/rails4/app/app/controllers/send_code_controller.rb +0 -20
  285. data/features/fixtures/rails4/app/app/controllers/send_environment_controller.rb +0 -12
  286. data/features/fixtures/rails4/app/app/controllers/session_tracking_controller.rb +0 -24
  287. data/features/fixtures/rails4/app/app/controllers/unhandled_controller.rb +0 -11
  288. data/features/fixtures/rails4/app/app/helpers/application_helper.rb +0 -2
  289. data/features/fixtures/rails4/app/app/jobs/application_job.rb +0 -2
  290. data/features/fixtures/rails4/app/app/jobs/notify_job.rb +0 -5
  291. data/features/fixtures/rails4/app/app/mailers/.keep +0 -0
  292. data/features/fixtures/rails4/app/app/models/.keep +0 -0
  293. data/features/fixtures/rails4/app/app/models/concerns/.keep +0 -0
  294. data/features/fixtures/rails4/app/app/models/mongo_model.rb +0 -6
  295. data/features/fixtures/rails4/app/app/models/user.rb +0 -6
  296. data/features/fixtures/rails4/app/app/views/layouts/application.html.erb +0 -14
  297. data/features/fixtures/rails4/app/config.ru +0 -4
  298. data/features/fixtures/rails4/app/config/application.rb +0 -23
  299. data/features/fixtures/rails4/app/config/boot.rb +0 -4
  300. data/features/fixtures/rails4/app/config/database.yml +0 -31
  301. data/features/fixtures/rails4/app/config/environment.rb +0 -5
  302. data/features/fixtures/rails4/app/config/environments/development.rb +0 -31
  303. data/features/fixtures/rails4/app/config/environments/production.rb +0 -81
  304. data/features/fixtures/rails4/app/config/environments/rails_env.rb +0 -30
  305. data/features/fixtures/rails4/app/config/environments/test.rb +0 -31
  306. data/features/fixtures/rails4/app/config/initializers/backtrace_silencers.rb +0 -7
  307. data/features/fixtures/rails4/app/config/initializers/bugsnag.rb +0 -21
  308. data/features/fixtures/rails4/app/config/initializers/devise.rb +0 -283
  309. data/features/fixtures/rails4/app/config/initializers/filter_parameter_logging.rb +0 -5
  310. data/features/fixtures/rails4/app/config/initializers/inflections.rb +0 -16
  311. data/features/fixtures/rails4/app/config/initializers/mime_types.rb +0 -5
  312. data/features/fixtures/rails4/app/config/initializers/secret_token.rb +0 -12
  313. data/features/fixtures/rails4/app/config/initializers/session_store.rb +0 -3
  314. data/features/fixtures/rails4/app/config/initializers/wrap_parameters.rb +0 -14
  315. data/features/fixtures/rails4/app/config/locales/devise.en.yml +0 -64
  316. data/features/fixtures/rails4/app/config/locales/en.yml +0 -23
  317. data/features/fixtures/rails4/app/config/mongoid.yml +0 -22
  318. data/features/fixtures/rails4/app/config/routes.rb +0 -21
  319. data/features/fixtures/rails4/app/db/migrate/20180420160315_devise_create_users.rb +0 -47
  320. data/features/fixtures/rails4/app/db/seeds.rb +0 -7
  321. data/features/fixtures/rails4/app/lib/assets/.keep +0 -0
  322. data/features/fixtures/rails4/app/lib/tasks/.keep +0 -0
  323. data/features/fixtures/rails4/app/log/.keep +0 -0
  324. data/features/fixtures/rails4/app/public/404.html +0 -58
  325. data/features/fixtures/rails4/app/public/422.html +0 -58
  326. data/features/fixtures/rails4/app/public/500.html +0 -57
  327. data/features/fixtures/rails4/app/public/favicon.ico +0 -0
  328. data/features/fixtures/rails4/app/public/robots.txt +0 -5
  329. data/features/fixtures/rails4/app/test/controllers/.keep +0 -0
  330. data/features/fixtures/rails4/app/test/fixtures/.keep +0 -0
  331. data/features/fixtures/rails4/app/test/helpers/.keep +0 -0
  332. data/features/fixtures/rails4/app/test/integration/.keep +0 -0
  333. data/features/fixtures/rails4/app/test/mailers/.keep +0 -0
  334. data/features/fixtures/rails4/app/test/models/.keep +0 -0
  335. data/features/fixtures/rails4/app/test/test_helper.rb +0 -15
  336. data/features/fixtures/rails5/.dockerignore +0 -1
  337. data/features/fixtures/rails5/Dockerfile +0 -17
  338. data/features/fixtures/rails5/app/.gitignore +0 -21
  339. data/features/fixtures/rails5/app/Gemfile +0 -52
  340. data/features/fixtures/rails5/app/README.md +0 -24
  341. data/features/fixtures/rails5/app/Rakefile +0 -6
  342. data/features/fixtures/rails5/app/app/assets/config/manifest.js +0 -3
  343. data/features/fixtures/rails5/app/app/assets/images/.keep +0 -0
  344. data/features/fixtures/rails5/app/app/assets/javascripts/application.js +0 -16
  345. data/features/fixtures/rails5/app/app/assets/javascripts/cable.js +0 -13
  346. data/features/fixtures/rails5/app/app/assets/javascripts/channels/.keep +0 -0
  347. data/features/fixtures/rails5/app/app/assets/stylesheets/application.css +0 -15
  348. data/features/fixtures/rails5/app/app/channels/application_cable/channel.rb +0 -4
  349. data/features/fixtures/rails5/app/app/channels/application_cable/connection.rb +0 -4
  350. data/features/fixtures/rails5/app/app/controllers/api_key_controller.rb +0 -16
  351. data/features/fixtures/rails5/app/app/controllers/app_type_controller.rb +0 -16
  352. data/features/fixtures/rails5/app/app/controllers/app_version_controller.rb +0 -21
  353. data/features/fixtures/rails5/app/app/controllers/application_controller.rb +0 -7
  354. data/features/fixtures/rails5/app/app/controllers/auto_notify_controller.rb +0 -27
  355. data/features/fixtures/rails5/app/app/controllers/before_notify_controller.rb +0 -40
  356. data/features/fixtures/rails5/app/app/controllers/breadcrumbs_controller.rb +0 -24
  357. data/features/fixtures/rails5/app/app/controllers/clearance_controller.rb +0 -33
  358. data/features/fixtures/rails5/app/app/controllers/concerns/.keep +0 -0
  359. data/features/fixtures/rails5/app/app/controllers/handled_controller.rb +0 -22
  360. data/features/fixtures/rails5/app/app/controllers/ignore_classes_controller.rb +0 -19
  361. data/features/fixtures/rails5/app/app/controllers/metadata_filters_controller.rb +0 -12
  362. data/features/fixtures/rails5/app/app/controllers/mongo_controller.rb +0 -22
  363. data/features/fixtures/rails5/app/app/controllers/project_root_controller.rb +0 -21
  364. data/features/fixtures/rails5/app/app/controllers/release_stage_controller.rb +0 -16
  365. data/features/fixtures/rails5/app/app/controllers/send_code_controller.rb +0 -16
  366. data/features/fixtures/rails5/app/app/controllers/send_environment_controller.rb +0 -8
  367. data/features/fixtures/rails5/app/app/controllers/session_tracking_controller.rb +0 -20
  368. data/features/fixtures/rails5/app/app/controllers/unhandled_controller.rb +0 -7
  369. data/features/fixtures/rails5/app/app/helpers/application_helper.rb +0 -2
  370. data/features/fixtures/rails5/app/app/jobs/application_job.rb +0 -2
  371. data/features/fixtures/rails5/app/app/jobs/notify_job.rb +0 -5
  372. data/features/fixtures/rails5/app/app/mailers/application_mailer.rb +0 -4
  373. data/features/fixtures/rails5/app/app/models/application_record.rb +0 -3
  374. data/features/fixtures/rails5/app/app/models/concerns/.keep +0 -0
  375. data/features/fixtures/rails5/app/app/models/mongo_model.rb +0 -6
  376. data/features/fixtures/rails5/app/app/models/user.rb +0 -3
  377. data/features/fixtures/rails5/app/app/views/layouts/application.html.erb +0 -14
  378. data/features/fixtures/rails5/app/app/views/layouts/mailer.html.erb +0 -13
  379. data/features/fixtures/rails5/app/app/views/layouts/mailer.text.erb +0 -1
  380. data/features/fixtures/rails5/app/config.ru +0 -5
  381. data/features/fixtures/rails5/app/config/application.rb +0 -15
  382. data/features/fixtures/rails5/app/config/boot.rb +0 -3
  383. data/features/fixtures/rails5/app/config/cable.yml +0 -9
  384. data/features/fixtures/rails5/app/config/database.yml +0 -29
  385. data/features/fixtures/rails5/app/config/environment.rb +0 -5
  386. data/features/fixtures/rails5/app/config/environments/development.rb +0 -55
  387. data/features/fixtures/rails5/app/config/environments/production.rb +0 -87
  388. data/features/fixtures/rails5/app/config/environments/rails_env.rb +0 -55
  389. data/features/fixtures/rails5/app/config/environments/test.rb +0 -55
  390. data/features/fixtures/rails5/app/config/initializers/assets.rb +0 -11
  391. data/features/fixtures/rails5/app/config/initializers/backtrace_silencers.rb +0 -7
  392. data/features/fixtures/rails5/app/config/initializers/bugsnag.rb +0 -21
  393. data/features/fixtures/rails5/app/config/initializers/clearance.rb +0 -5
  394. data/features/fixtures/rails5/app/config/initializers/cookies_serializer.rb +0 -5
  395. data/features/fixtures/rails5/app/config/initializers/filter_parameter_logging.rb +0 -5
  396. data/features/fixtures/rails5/app/config/initializers/inflections.rb +0 -16
  397. data/features/fixtures/rails5/app/config/initializers/mime_types.rb +0 -4
  398. data/features/fixtures/rails5/app/config/initializers/new_framework_defaults.rb +0 -24
  399. data/features/fixtures/rails5/app/config/initializers/session_store.rb +0 -3
  400. data/features/fixtures/rails5/app/config/initializers/wrap_parameters.rb +0 -14
  401. data/features/fixtures/rails5/app/config/locales/devise.en.yml +0 -64
  402. data/features/fixtures/rails5/app/config/locales/en.yml +0 -23
  403. data/features/fixtures/rails5/app/config/mongoid.yml +0 -23
  404. data/features/fixtures/rails5/app/config/puma.rb +0 -47
  405. data/features/fixtures/rails5/app/config/routes.rb +0 -62
  406. data/features/fixtures/rails5/app/config/secrets.yml +0 -25
  407. data/features/fixtures/rails5/app/config/spring.rb +0 -6
  408. data/features/fixtures/rails5/app/db/migrate/20180426095545_create_users.rb +0 -17
  409. data/features/fixtures/rails5/app/db/schema.rb +0 -29
  410. data/features/fixtures/rails5/app/db/seeds.rb +0 -7
  411. data/features/fixtures/rails5/app/lib/assets/.keep +0 -0
  412. data/features/fixtures/rails5/app/lib/tasks/.keep +0 -0
  413. data/features/fixtures/rails5/app/log/.keep +0 -0
  414. data/features/fixtures/rails5/app/public/404.html +0 -67
  415. data/features/fixtures/rails5/app/public/422.html +0 -67
  416. data/features/fixtures/rails5/app/public/500.html +0 -66
  417. data/features/fixtures/rails5/app/public/apple-touch-icon-precomposed.png +0 -0
  418. data/features/fixtures/rails5/app/public/apple-touch-icon.png +0 -0
  419. data/features/fixtures/rails5/app/public/favicon.ico +0 -0
  420. data/features/fixtures/rails5/app/public/robots.txt +0 -5
  421. data/features/fixtures/rails5/app/test/controllers/.keep +0 -0
  422. data/features/fixtures/rails5/app/test/fixtures/.keep +0 -0
  423. data/features/fixtures/rails5/app/test/fixtures/files/.keep +0 -0
  424. data/features/fixtures/rails5/app/test/helpers/.keep +0 -0
  425. data/features/fixtures/rails5/app/test/integration/.keep +0 -0
  426. data/features/fixtures/rails5/app/test/mailers/.keep +0 -0
  427. data/features/fixtures/rails5/app/test/models/.keep +0 -0
  428. data/features/fixtures/rails5/app/test/test_helper.rb +0 -10
  429. data/features/fixtures/rails5/app/tmp/.keep +0 -0
  430. data/features/fixtures/rails6/.dockerignore +0 -1
  431. data/features/fixtures/rails6/Dockerfile +0 -26
  432. data/features/fixtures/rails6/app/.browserslistrc +0 -1
  433. data/features/fixtures/rails6/app/.gitignore +0 -35
  434. data/features/fixtures/rails6/app/.ruby-version +0 -1
  435. data/features/fixtures/rails6/app/Gemfile +0 -58
  436. data/features/fixtures/rails6/app/README.md +0 -24
  437. data/features/fixtures/rails6/app/Rakefile +0 -6
  438. data/features/fixtures/rails6/app/app/assets/config/manifest.js +0 -2
  439. data/features/fixtures/rails6/app/app/assets/images/.keep +0 -0
  440. data/features/fixtures/rails6/app/app/assets/stylesheets/application.css +0 -15
  441. data/features/fixtures/rails6/app/app/channels/application_cable/channel.rb +0 -4
  442. data/features/fixtures/rails6/app/app/channels/application_cable/connection.rb +0 -4
  443. data/features/fixtures/rails6/app/app/controllers/api_key_controller.rb +0 -16
  444. data/features/fixtures/rails6/app/app/controllers/app_type_controller.rb +0 -16
  445. data/features/fixtures/rails6/app/app/controllers/app_version_controller.rb +0 -21
  446. data/features/fixtures/rails6/app/app/controllers/application_controller.rb +0 -7
  447. data/features/fixtures/rails6/app/app/controllers/auto_notify_controller.rb +0 -27
  448. data/features/fixtures/rails6/app/app/controllers/before_notify_controller.rb +0 -40
  449. data/features/fixtures/rails6/app/app/controllers/breadcrumbs_controller.rb +0 -24
  450. data/features/fixtures/rails6/app/app/controllers/clearance_controller.rb +0 -33
  451. data/features/fixtures/rails6/app/app/controllers/concerns/.keep +0 -0
  452. data/features/fixtures/rails6/app/app/controllers/handled_controller.rb +0 -22
  453. data/features/fixtures/rails6/app/app/controllers/ignore_classes_controller.rb +0 -19
  454. data/features/fixtures/rails6/app/app/controllers/metadata_filters_controller.rb +0 -12
  455. data/features/fixtures/rails6/app/app/controllers/mongo_controller.rb +0 -22
  456. data/features/fixtures/rails6/app/app/controllers/project_root_controller.rb +0 -21
  457. data/features/fixtures/rails6/app/app/controllers/release_stage_controller.rb +0 -16
  458. data/features/fixtures/rails6/app/app/controllers/send_code_controller.rb +0 -16
  459. data/features/fixtures/rails6/app/app/controllers/send_environment_controller.rb +0 -8
  460. data/features/fixtures/rails6/app/app/controllers/session_tracking_controller.rb +0 -20
  461. data/features/fixtures/rails6/app/app/controllers/unhandled_controller.rb +0 -7
  462. data/features/fixtures/rails6/app/app/helpers/application_helper.rb +0 -2
  463. data/features/fixtures/rails6/app/app/javascript/channels/consumer.js +0 -6
  464. data/features/fixtures/rails6/app/app/javascript/channels/index.js +0 -5
  465. data/features/fixtures/rails6/app/app/javascript/packs/application.js +0 -9
  466. data/features/fixtures/rails6/app/app/jobs/application_job.rb +0 -7
  467. data/features/fixtures/rails6/app/app/jobs/notify_job.rb +0 -5
  468. data/features/fixtures/rails6/app/app/mailers/application_mailer.rb +0 -4
  469. data/features/fixtures/rails6/app/app/models/application_record.rb +0 -3
  470. data/features/fixtures/rails6/app/app/models/concerns/.keep +0 -0
  471. data/features/fixtures/rails6/app/app/models/mongo_model.rb +0 -6
  472. data/features/fixtures/rails6/app/app/models/user.rb +0 -3
  473. data/features/fixtures/rails6/app/app/views/layouts/application.html.erb +0 -15
  474. data/features/fixtures/rails6/app/app/views/layouts/mailer.html.erb +0 -13
  475. data/features/fixtures/rails6/app/app/views/layouts/mailer.text.erb +0 -1
  476. data/features/fixtures/rails6/app/babel.config.js +0 -70
  477. data/features/fixtures/rails6/app/config.ru +0 -5
  478. data/features/fixtures/rails6/app/config/application.rb +0 -19
  479. data/features/fixtures/rails6/app/config/boot.rb +0 -4
  480. data/features/fixtures/rails6/app/config/cable.yml +0 -13
  481. data/features/fixtures/rails6/app/config/credentials.yml.enc +0 -1
  482. data/features/fixtures/rails6/app/config/database.yml +0 -29
  483. data/features/fixtures/rails6/app/config/environment.rb +0 -5
  484. data/features/fixtures/rails6/app/config/environments/development.rb +0 -64
  485. data/features/fixtures/rails6/app/config/environments/production.rb +0 -113
  486. data/features/fixtures/rails6/app/config/environments/rails_env.rb +0 -56
  487. data/features/fixtures/rails6/app/config/environments/test.rb +0 -48
  488. data/features/fixtures/rails6/app/config/initializers/application_controller_renderer.rb +0 -8
  489. data/features/fixtures/rails6/app/config/initializers/assets.rb +0 -14
  490. data/features/fixtures/rails6/app/config/initializers/backtrace_silencers.rb +0 -7
  491. data/features/fixtures/rails6/app/config/initializers/bugsnag.rb +0 -21
  492. data/features/fixtures/rails6/app/config/initializers/content_security_policy.rb +0 -27
  493. data/features/fixtures/rails6/app/config/initializers/cookies_serializer.rb +0 -5
  494. data/features/fixtures/rails6/app/config/initializers/filter_parameter_logging.rb +0 -5
  495. data/features/fixtures/rails6/app/config/initializers/inflections.rb +0 -16
  496. data/features/fixtures/rails6/app/config/initializers/mime_types.rb +0 -4
  497. data/features/fixtures/rails6/app/config/initializers/wrap_parameters.rb +0 -14
  498. data/features/fixtures/rails6/app/config/locales/en.yml +0 -33
  499. data/features/fixtures/rails6/app/config/mongoid.yml +0 -23
  500. data/features/fixtures/rails6/app/config/puma.rb +0 -35
  501. data/features/fixtures/rails6/app/config/routes.rb +0 -62
  502. data/features/fixtures/rails6/app/config/secrets.yml +0 -25
  503. data/features/fixtures/rails6/app/config/spring.rb +0 -6
  504. data/features/fixtures/rails6/app/config/storage.yml +0 -34
  505. data/features/fixtures/rails6/app/config/webpack/development.js +0 -5
  506. data/features/fixtures/rails6/app/config/webpack/environment.js +0 -3
  507. data/features/fixtures/rails6/app/config/webpack/production.js +0 -5
  508. data/features/fixtures/rails6/app/config/webpack/rails_env.js +0 -5
  509. data/features/fixtures/rails6/app/config/webpack/test.js +0 -5
  510. data/features/fixtures/rails6/app/config/webpacker.yml +0 -121
  511. data/features/fixtures/rails6/app/db/migrate/20180426095545_create_users.rb +0 -17
  512. data/features/fixtures/rails6/app/db/schema.rb +0 -29
  513. data/features/fixtures/rails6/app/db/seeds.rb +0 -7
  514. data/features/fixtures/rails6/app/lib/assets/.keep +0 -0
  515. data/features/fixtures/rails6/app/lib/tasks/.keep +0 -0
  516. data/features/fixtures/rails6/app/log/.keep +0 -0
  517. data/features/fixtures/rails6/app/package.json +0 -15
  518. data/features/fixtures/rails6/app/postcss.config.js +0 -12
  519. data/features/fixtures/rails6/app/public/404.html +0 -67
  520. data/features/fixtures/rails6/app/public/422.html +0 -67
  521. data/features/fixtures/rails6/app/public/500.html +0 -66
  522. data/features/fixtures/rails6/app/public/apple-touch-icon-precomposed.png +0 -0
  523. data/features/fixtures/rails6/app/public/apple-touch-icon.png +0 -0
  524. data/features/fixtures/rails6/app/public/favicon.ico +0 -0
  525. data/features/fixtures/rails6/app/public/robots.txt +0 -1
  526. data/features/fixtures/rails6/app/storage/.keep +0 -0
  527. data/features/fixtures/rails6/app/test/application_system_test_case.rb +0 -5
  528. data/features/fixtures/rails6/app/test/channels/application_cable/connection_test.rb +0 -11
  529. data/features/fixtures/rails6/app/test/controllers/.keep +0 -0
  530. data/features/fixtures/rails6/app/test/fixtures/.keep +0 -0
  531. data/features/fixtures/rails6/app/test/fixtures/files/.keep +0 -0
  532. data/features/fixtures/rails6/app/test/helpers/.keep +0 -0
  533. data/features/fixtures/rails6/app/test/integration/.keep +0 -0
  534. data/features/fixtures/rails6/app/test/mailers/.keep +0 -0
  535. data/features/fixtures/rails6/app/test/models/.keep +0 -0
  536. data/features/fixtures/rails6/app/test/system/.keep +0 -0
  537. data/features/fixtures/rails6/app/test/test_helper.rb +0 -13
  538. data/features/fixtures/rails6/app/tmp/.keep +0 -0
  539. data/features/fixtures/rails6/app/yarn.lock +0 -6082
  540. data/features/fixtures/resque/.dockerignore +0 -1
  541. data/features/fixtures/resque/Dockerfile +0 -14
  542. data/features/fixtures/resque/Gemfile +0 -6
  543. data/features/fixtures/resque/Rakefile +0 -4
  544. data/features/fixtures/resque/app.rb +0 -12
  545. data/features/fixtures/sidekiq/.dockerignore +0 -2
  546. data/features/fixtures/sidekiq/Dockerfile +0 -17
  547. data/features/fixtures/sidekiq/app/Gemfile +0 -7
  548. data/features/fixtures/sidekiq/app/Rakefile.rb +0 -14
  549. data/features/fixtures/sidekiq/app/app.rb +0 -35
  550. data/features/fixtures/sidekiq/app/initializers/HandledError.rb +0 -3
  551. data/features/fixtures/sidekiq/app/initializers/UnhandledError.rb +0 -3
  552. data/features/fixtures/sidekiq/payloads/handled_metadata_ca_false.json +0 -11
  553. data/features/fixtures/sidekiq/payloads/handled_metadata_ca_true.json +0 -12
  554. data/features/fixtures/sidekiq/payloads/unhandled_metadata_ca_false.json +0 -11
  555. data/features/fixtures/sidekiq/payloads/unhandled_metadata_ca_true.json +0 -12
  556. data/features/fixtures/sinatra1/.dockerignore +0 -1
  557. data/features/fixtures/sinatra1/Dockerfile +0 -13
  558. data/features/fixtures/sinatra1/Gemfile +0 -4
  559. data/features/fixtures/sinatra1/app.rb +0 -9
  560. data/features/fixtures/sinatra2/.dockerignore +0 -1
  561. data/features/fixtures/sinatra2/Dockerfile +0 -13
  562. data/features/fixtures/sinatra2/Gemfile +0 -4
  563. data/features/fixtures/sinatra2/app.rb +0 -9
  564. data/features/plain_features/add_tab.feature +0 -49
  565. data/features/plain_features/app_type.feature +0 -8
  566. data/features/plain_features/app_version.feature +0 -8
  567. data/features/plain_features/auto_notify.feature +0 -7
  568. data/features/plain_features/delivery.feature +0 -20
  569. data/features/plain_features/exception_data.feature +0 -50
  570. data/features/plain_features/filters.feature +0 -14
  571. data/features/plain_features/handled_errors.feature +0 -42
  572. data/features/plain_features/ignore_classes.feature +0 -11
  573. data/features/plain_features/ignore_report.feature +0 -12
  574. data/features/plain_features/proxies.feature +0 -25
  575. data/features/plain_features/release_stages.feature +0 -20
  576. data/features/plain_features/report_api_key.feature +0 -14
  577. data/features/plain_features/report_severity.feature +0 -15
  578. data/features/plain_features/report_stack_frames.feature +0 -49
  579. data/features/plain_features/report_user.feature +0 -45
  580. data/features/plain_features/unhandled_errors.feature +0 -33
  581. data/features/rails_features/api_key.feature +0 -15
  582. data/features/rails_features/app_type.feature +0 -24
  583. data/features/rails_features/app_version.feature +0 -26
  584. data/features/rails_features/auto_capture_sessions.feature +0 -34
  585. data/features/rails_features/auto_notify.feature +0 -41
  586. data/features/rails_features/before_notify.feature +0 -44
  587. data/features/rails_features/breadcrumbs.feature +0 -43
  588. data/features/rails_features/handled.feature +0 -42
  589. data/features/rails_features/ignore_classes.feature +0 -14
  590. data/features/rails_features/meta_data_filters.feature +0 -16
  591. data/features/rails_features/mongo_breadcrumbs.feature +0 -26
  592. data/features/rails_features/project_root.feature +0 -35
  593. data/features/rails_features/release_stage.feature +0 -27
  594. data/features/rails_features/send_code.feature +0 -18
  595. data/features/rails_features/send_environment.feature +0 -13
  596. data/features/rails_features/unhandled.feature +0 -16
  597. data/features/rails_features/user_info.feature +0 -52
  598. data/features/sidekiq.feature +0 -30
  599. data/features/steps/ruby_notifier_steps.rb +0 -75
  600. data/features/support/env.rb +0 -23
  601. data/issue_template.md +0 -48
  602. data/spec/breadcrumbs/breadcrumb_spec.rb +0 -93
  603. data/spec/breadcrumbs/validator_spec.rb +0 -176
  604. data/spec/bugsnag_spec.rb +0 -366
  605. data/spec/cleaner_spec.rb +0 -350
  606. data/spec/configuration_spec.rb +0 -445
  607. data/spec/fixtures/apps/rails-initializer-config/Gemfile +0 -9
  608. data/spec/fixtures/apps/rails-initializer-config/config.ru +0 -16
  609. data/spec/fixtures/apps/rails-initializer-config/config/initializers/bugsnag.rb +0 -3
  610. data/spec/fixtures/apps/rails-invalid-initializer-config/Gemfile +0 -9
  611. data/spec/fixtures/apps/rails-invalid-initializer-config/config.ru +0 -16
  612. data/spec/fixtures/apps/rails-invalid-initializer-config/config/initializers/bugsnag.rb +0 -3
  613. data/spec/fixtures/apps/rails-no-config/Gemfile +0 -9
  614. data/spec/fixtures/apps/rails-no-config/config.ru +0 -16
  615. data/spec/fixtures/apps/scripts/Gemfile +0 -3
  616. data/spec/fixtures/apps/scripts/configure_invalid_key.rb +0 -5
  617. data/spec/fixtures/apps/scripts/configure_key.rb +0 -5
  618. data/spec/fixtures/apps/scripts/no_config.rb +0 -3
  619. data/spec/fixtures/crashes/end_of_file.rb +0 -9
  620. data/spec/fixtures/crashes/short_file.rb +0 -1
  621. data/spec/fixtures/crashes/start_of_file.rb +0 -9
  622. data/spec/fixtures/middleware/internal_info_setter.rb +0 -11
  623. data/spec/fixtures/middleware/public_info_setter.rb +0 -11
  624. data/spec/fixtures/tasks/Rakefile +0 -26
  625. data/spec/helper_spec.rb +0 -131
  626. data/spec/integration_spec.rb +0 -107
  627. data/spec/integrations/clearance_user_spec.rb +0 -38
  628. data/spec/integrations/logger_spec.rb +0 -134
  629. data/spec/integrations/mailman_spec.rb +0 -83
  630. data/spec/integrations/mongo_spec.rb +0 -262
  631. data/spec/integrations/que_spec.rb +0 -94
  632. data/spec/integrations/rack_spec.rb +0 -232
  633. data/spec/integrations/rails3_request_spec.rb +0 -67
  634. data/spec/integrations/rake_spec.rb +0 -71
  635. data/spec/integrations/resque_spec.rb +0 -99
  636. data/spec/integrations/shoryuken_spec.rb +0 -70
  637. data/spec/integrations/sidekiq_spec.rb +0 -137
  638. data/spec/integrations/warden_user_spec.rb +0 -41
  639. data/spec/middleware/exception_meta_data_spec.rb +0 -104
  640. data/spec/middleware_spec.rb +0 -254
  641. data/spec/middleware_stack_spec.rb +0 -151
  642. data/spec/report_spec.rb +0 -1580
  643. data/spec/session_tracker_spec.rb +0 -156
  644. data/spec/spec_helper.rb +0 -91
  645. data/spec/stacktrace_spec.rb +0 -197
  646. data/spec/utility/circular_buffer_spec.rb +0 -98
@@ -1,254 +0,0 @@
1
- require 'spec_helper'
2
- require 'fixtures/middleware/public_info_setter'
3
- require 'fixtures/middleware/internal_info_setter'
4
-
5
- describe Bugsnag::MiddlewareStack do
6
- it "runs before_bugsnag_notify callbacks, adding a tab" do
7
- callback_run_count = 0
8
- Bugsnag.before_notify_callbacks << lambda {|notif|
9
- notif.add_tab(:some_tab, {
10
- :info => "here",
11
- :data => "also here"
12
- })
13
- callback_run_count += 1
14
- }
15
-
16
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
17
- expect(callback_run_count).to eq(1)
18
-
19
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
20
- event = get_event_from_payload(payload)
21
- expect(event["metaData"]["some_tab"]).not_to be_nil
22
- expect(event["metaData"]["some_tab"]["info"]).to eq("here")
23
- expect(event["metaData"]["some_tab"]["data"]).to eq("also here")
24
- }
25
-
26
- end
27
-
28
- it "runs before_bugsnag_notify callbacks, adding custom data" do
29
- callback_run_count = 0
30
- Bugsnag.before_notify_callbacks << lambda {|notif|
31
- notif.add_tab(:custom, {info: "here"})
32
- notif.add_tab(:custom, {data: "also here"})
33
-
34
- callback_run_count += 1
35
- }
36
-
37
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
38
- expect(callback_run_count).to eq(1)
39
-
40
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
41
- event = get_event_from_payload(payload)
42
- expect(event["metaData"]["custom"]).not_to be_nil
43
- expect(event["metaData"]["custom"]["info"]).to eq("here")
44
- expect(event["metaData"]["custom"]["data"]).to eq("also here")
45
- }
46
-
47
- end
48
-
49
- it "runs before_bugsnag_notify callbacks, setting the user" do
50
- callback_run_count = 0
51
- Bugsnag.before_notify_callbacks << lambda {|notif|
52
- notif.user = {:id => "here", :email => "also here", :name => "also here too", :random_key => "also here too too"}
53
- callback_run_count += 1
54
- }
55
-
56
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
57
- expect(callback_run_count).to eq(1)
58
-
59
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
60
- event = get_event_from_payload(payload)
61
- expect(event["user"]).not_to be_nil
62
- expect(event["user"]["id"]).to eq("here")
63
- expect(event["user"]["email"]).to eq("also here")
64
- expect(event["user"]["name"]).to eq("also here too")
65
- expect(event["user"]["random_key"]).to eq("also here too too")
66
- }
67
-
68
- end
69
-
70
- it "allows block to override values set by internal middleware" do
71
- Bugsnag.configuration.internal_middleware.use(InternalInfoSetter)
72
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
73
- report.meta_data.merge!({custom: {info: 'overridden'}})
74
- end
75
-
76
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
77
- event = get_event_from_payload(payload)
78
- expect(event["metaData"]["custom"]).not_to be_nil
79
- expect(event["metaData"]["custom"]["info"]).to eq("overridden")
80
- }
81
- end
82
-
83
- it "allows block to override public middleware" do
84
- Bugsnag.configuration.middleware.use(PublicInfoSetter)
85
-
86
- Bugsnag.notify(BugsnagTestException.new("It crashed")) do |report|
87
- report.meta_data.merge!({custom: {info: 'overridden'}})
88
- end
89
-
90
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
91
- event = get_event_from_payload(payload)
92
- expect(event["metaData"]["custom"]).not_to be_nil
93
- expect(event["metaData"]["custom"]["info"]).to eq("overridden")
94
- }
95
- end
96
-
97
- it "does not have have before callbacks by default" do
98
- expect(Bugsnag.before_notify_callbacks.size).to eq(0)
99
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
100
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
101
- event = get_event_from_payload(payload)
102
- expect(event["metaData"].size).to eq(0)
103
- }
104
- end
105
-
106
- it "does not execute disabled bugsnag middleware" do
107
- callback_run_count = 0
108
- Bugsnag.configure do |config|
109
- config.middleware.disable(Bugsnag::Middleware::Callbacks)
110
- end
111
-
112
- Bugsnag.before_notify_callbacks << lambda {|notif|
113
- callback_run_count += 1
114
- }
115
-
116
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
117
- expect(callback_run_count).to eq(0)
118
- end
119
-
120
- it "does not notify if a callback told so" do
121
- Bugsnag.before_notify_callbacks << lambda do |notif|
122
- notif.ignore!
123
- end
124
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
125
- expect(Bugsnag).not_to have_sent_notification
126
- end
127
-
128
- it "allows inspection of meta_data before ignoring exception" do
129
- # Use before notify callbacks as only the callback based metadata is
130
- # available to before_notify_callbacks
131
- Bugsnag.before_notify_callbacks << lambda do |notif|
132
- notif.add_tab(:sidekiq, {:retry_count => 4})
133
- end
134
-
135
- Bugsnag.before_notify_callbacks << lambda do |notif|
136
- notif.ignore! if notif.meta_data[:sidekiq][:retry_count] > 3
137
- end
138
-
139
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
140
- expect(Bugsnag).not_to have_sent_notification
141
-
142
- end
143
-
144
- it "allows meta_data to be modified in a middleware" do
145
- MetaDataAdder = Class.new do
146
- def initialize(bugsnag)
147
- @bugsnag = bugsnag
148
- end
149
-
150
- def call(report)
151
- report.meta_data = {test: {value: "abcdef123456abcdef123456abcdef123456"}}
152
- @bugsnag.call(report)
153
- end
154
- end
155
-
156
- MetaDataMunger = Class.new do
157
- def initialize(bugsnag)
158
- @bugsnag = bugsnag
159
- end
160
-
161
- def call(report)
162
- token = report.meta_data[:test][:value]
163
- report.meta_data[:test][:value] = "#{token[0...6]}*****#{token[-4..-1]}"
164
- @bugsnag.call(report)
165
- end
166
- end
167
-
168
- Bugsnag.configure do |c|
169
- c.middleware.use MetaDataAdder
170
- c.middleware.use MetaDataMunger
171
- end
172
-
173
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
174
-
175
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
176
- event = get_event_from_payload(payload)
177
- expect(event["metaData"]['test']['value']).to eq("abcdef*****3456")
178
- }
179
- end
180
-
181
- if ruby_version_greater_equal?("2.3.0")
182
- context "with a ruby version >= 2.3.0" do
183
- it "attaches did you mean metadata when necessary" do
184
- begin
185
- "Test".prepnd "T"
186
- rescue Exception => e
187
- Bugsnag.notify(e)
188
- end
189
-
190
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
191
- event = get_event_from_payload(payload)
192
- expect(event["metaData"]["error"]).to_not be_nil
193
- expect(event["metaData"]["error"]).to eq({"suggestion" => "prepend"})
194
- }
195
- end
196
- end
197
- end
198
-
199
- context "with a ruby version < 2.3.0" do
200
- if !ruby_version_greater_equal?("2.3.0")
201
- it "doesn't attach did you mean metadata" do
202
- begin
203
- "Test".prepnd "T"
204
- rescue Exception => e
205
- Bugsnag.notify(e)
206
- end
207
-
208
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
209
- event = get_event_from_payload(payload)
210
- expect(event["metaData"]["error"]).to be_nil
211
- }
212
- end
213
- end
214
- end
215
-
216
- it "doesn't allow handledState properties to be changed in middleware" do
217
- HandledStateChanger = Class.new do
218
- def initialize(bugsnag)
219
- @bugsnag = bugsnag
220
- end
221
-
222
- def call(report)
223
- report.severity_reason = {
224
- :test => "test"
225
- }
226
- @bugsnag.call(report)
227
- end
228
- end
229
-
230
- Bugsnag.configure do |c|
231
- c.middleware.use HandledStateChanger
232
- end
233
-
234
- Bugsnag.notify(BugsnagTestException.new("It crashed"), true) do |report|
235
- report.severity_reason = {
236
- :type => "middleware_handler",
237
- :attributes => {
238
- :name => "middleware_test"
239
- }
240
- }
241
- end
242
-
243
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
244
- event = get_event_from_payload(payload)
245
- expect(event["unhandled"]).to be true
246
- expect(event["severityReason"]).to eq({
247
- "type" => "middleware_handler",
248
- "attributes" => {
249
- "name" => "middleware_test"
250
- }
251
- })
252
- }
253
- end
254
- end
@@ -1,151 +0,0 @@
1
- require 'spec_helper'
2
-
3
- class TestMiddleware
4
- def initialize(bugsnag)
5
- @bugsnag = bugsnag
6
- end
7
-
8
- def call(report)
9
- @bugsnag.call(report)
10
- end
11
- end
12
-
13
- module Bugsnag
14
- class MiddlewareStack
15
- attr_reader :middlewares
16
- attr_reader :disabled_middleware
17
- end
18
- end
19
-
20
- describe Bugsnag::MiddlewareStack do
21
- describe "defaults" do
22
- it "to empty middleware lists" do
23
- expect(subject.middlewares.size).to eq(0)
24
- expect(subject.disabled_middleware.size).to eq(0)
25
- end
26
- end
27
-
28
- describe "use" do
29
- it "allows middleware to be added to the stack" do
30
- middleware = TestMiddleware.new(nil)
31
- subject.use(middleware)
32
- expect(subject.middlewares.size).to eq(1)
33
- expect(subject.middlewares.last).to eq(middleware)
34
- end
35
-
36
- it "doesn't add middleware more than once" do
37
- middleware = TestMiddleware.new(nil)
38
- subject.use(middleware)
39
- expect(subject.middlewares.size).to eq(1)
40
- subject.use(middleware)
41
- expect(subject.middlewares.size).to eq(1)
42
- end
43
- end
44
-
45
- describe "disable" do
46
- it "adds middleware to a disabled list" do
47
- middleware = TestMiddleware.new(nil)
48
- subject.disable(middleware)
49
- expect(subject.disabled_middleware.size).to eq(1)
50
- expect(subject.disabled_middleware.last).to eq(middleware)
51
- end
52
-
53
- it "prevents middleware from being added" do
54
- middleware = TestMiddleware.new(nil)
55
- subject.disable(middleware)
56
- subject.use(middleware)
57
- expect(subject.middlewares.size).to eq(0)
58
- end
59
-
60
- it "removes already added middleware" do
61
- middleware = TestMiddleware.new(nil)
62
- subject.use(middleware)
63
- expect(subject.middlewares.size).to eq(1)
64
- subject.disable(middleware)
65
- expect(subject.middlewares.size).to eq(0)
66
- end
67
- end
68
-
69
- describe "insert_before" do
70
- it "inserts middleware before specified middleware" do
71
- middleware_one = TestMiddleware.new(nil)
72
- middleware_two = TestMiddleware.new(nil)
73
- subject.use(middleware_one)
74
- expect(subject.middlewares.size).to eq(1)
75
- expect(subject.middlewares.first).to eq(middleware_one)
76
- subject.insert_before(middleware_one, middleware_two)
77
- expect(subject.middlewares.size).to eq(2)
78
- expect(subject.middlewares.first).to eq(middleware_two)
79
- end
80
-
81
- it "appends middleware otherwise" do
82
- middleware_one = TestMiddleware.new(nil)
83
- middleware_two = TestMiddleware.new(nil)
84
- subject.use(middleware_one)
85
- expect(subject.middlewares.size).to eq(1)
86
- expect(subject.middlewares.first).to eq(middleware_one)
87
- subject.insert_before(nil, middleware_two)
88
- expect(subject.middlewares.size).to eq(2)
89
- expect(subject.middlewares.first).to eq(middleware_one)
90
- end
91
-
92
- it "accepts an array of middleware to insert before" do
93
- middleware_one = TestMiddleware.new(nil)
94
- middleware_two = TestMiddleware.new(nil)
95
- middleware_three = TestMiddleware.new(nil)
96
- subject.use(middleware_one)
97
- subject.use(middleware_two)
98
- expect(subject.middlewares.size).to eq(2)
99
- expect(subject.middlewares.first).to eq(middleware_one)
100
- subject.insert_before([middleware_one, middleware_two], middleware_three)
101
- expect(subject.middlewares.size).to eq(3)
102
- expect(subject.middlewares.first).to eq(middleware_three)
103
- end
104
- end
105
-
106
- describe "insert_after" do
107
- it "inserts middleware after specified middleware" do
108
- middleware_one = TestMiddleware.new(nil)
109
- middleware_two = TestMiddleware.new(nil)
110
- subject.use(middleware_one)
111
- expect(subject.middlewares.size).to eq(1)
112
- expect(subject.middlewares.first).to eq(middleware_one)
113
- subject.insert_after(middleware_one, middleware_two)
114
- expect(subject.middlewares.size).to eq(2)
115
- expect(subject.middlewares.last).to eq(middleware_two)
116
- end
117
-
118
- it "appends middleware otherwise" do
119
- middleware_one = TestMiddleware.new(nil)
120
- middleware_two = TestMiddleware.new(nil)
121
- subject.use(middleware_one)
122
- expect(subject.middlewares.size).to eq(1)
123
- expect(subject.middlewares.first).to eq(middleware_one)
124
- subject.insert_after(nil, middleware_two)
125
- expect(subject.middlewares.size).to eq(2)
126
- expect(subject.middlewares.first).to eq(middleware_one)
127
- end
128
-
129
- it "accepts an array of middleware to insert after" do
130
- middleware_one = TestMiddleware.new(nil)
131
- middleware_two = TestMiddleware.new(nil)
132
- middleware_three = TestMiddleware.new(nil)
133
- subject.use(middleware_one)
134
- subject.use(middleware_two)
135
- expect(subject.middlewares.size).to eq(2)
136
- expect(subject.middlewares.last).to eq(middleware_two)
137
- subject.insert_after([middleware_one, middleware_two], middleware_three)
138
- expect(subject.middlewares.size).to eq(3)
139
- expect(subject.middlewares.last).to eq(middleware_three)
140
- end
141
- end
142
-
143
- describe "method_missing" do
144
- it "calls send and proxies the method into the array" do
145
- middleware = TestMiddleware.new(nil)
146
- subject.method_missing(:<<, middleware)
147
- expect(subject.middlewares.size).to eq(1)
148
- expect(subject.middlewares.last).to eq(middleware)
149
- end
150
- end
151
- end
@@ -1,1580 +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
- bugsnag_count = 0
1377
- exception["stacktrace"].each do |frame|
1378
- if /.*lib\/bugsnag.*\.rb/.match(frame["file"])
1379
- bugsnag_count += 1
1380
- expect(frame["inProject"]).to be_nil
1381
- end
1382
- end
1383
- # 7 is used here as the called bugsnag frames for a `notify` call should be:
1384
- # - Bugsnag.notify
1385
- # - Report.new
1386
- # - Report.initialize
1387
- # - Report.generate_exceptions_list
1388
- # - Report.generate_exceptions_list | raw_exceptions.map
1389
- # - Report.generate_exceptions_list | raw_exceptions.map | block
1390
- # - Report.generate_exceptions_list | raw_exceptions.map | block | Stacktrace.new
1391
- # However, JRUBY does not include the two `new` frames, resulting in 5 bugsnag frames
1392
- if defined?(JRUBY_VERSION)
1393
- frame_count = 5
1394
- else
1395
- frame_count = 7
1396
- end
1397
- expect(bugsnag_count).to equal frame_count
1398
- }
1399
- end
1400
-
1401
- describe "breadcrumbs" do
1402
- let(:timestamp_regex) { /^\d{4}\-\d{2}\-\d{2}T\d{2}:\d{2}:[\d\.]+Z$/ }
1403
-
1404
- it "includes left breadcrumbs" do
1405
- Bugsnag.leave_breadcrumb("Test breadcrumb")
1406
- notify_test_exception
1407
- expect(Bugsnag).to have_sent_notification { |payload, headers|
1408
- event = get_event_from_payload(payload)
1409
- expect(event["breadcrumbs"].size).to eq(1)
1410
- expect(event["breadcrumbs"].first).to match({
1411
- "name" => "Test breadcrumb",
1412
- "type" => "manual",
1413
- "metaData" => {},
1414
- "timestamp" => match(timestamp_regex)
1415
- })
1416
- }
1417
- end
1418
-
1419
- it "filters left breadcrumbs" do
1420
- Bugsnag.leave_breadcrumb("Test breadcrumb", {
1421
- :forbidden_key => false,
1422
- :allowed_key => true
1423
- })
1424
- Bugsnag.configuration.meta_data_filters << "forbidden"
1425
- notify_test_exception
1426
- expect(Bugsnag).to have_sent_notification { |payload, headers|
1427
- event = get_event_from_payload(payload)
1428
- expect(event["breadcrumbs"].size).to eq(1)
1429
- expect(event["breadcrumbs"].first).to match({
1430
- "name" => "Test breadcrumb",
1431
- "type" => "manual",
1432
- "metaData" => {
1433
- "forbidden_key" => "[FILTERED]",
1434
- "allowed_key" => true
1435
- },
1436
- "timestamp" => match(timestamp_regex)
1437
- })
1438
- }
1439
- end
1440
-
1441
- it "defaults to an empty array" do
1442
- notify_test_exception
1443
- expect(Bugsnag).to have_sent_notification { |payload, headers|
1444
- event = get_event_from_payload(payload)
1445
- expect(event["breadcrumbs"].size).to eq(0)
1446
- }
1447
- end
1448
-
1449
- it "allows breadcrumbs to be editted in callbacks" do
1450
- Bugsnag.leave_breadcrumb("Test breadcrumb")
1451
- Bugsnag.before_notify_callbacks << Proc.new { |report|
1452
- breadcrumb = report.breadcrumbs.first
1453
- breadcrumb.meta_data = {:a => 1, :b => 2}
1454
- }
1455
- notify_test_exception
1456
- expect(Bugsnag).to have_sent_notification { |payload, headers|
1457
- event = get_event_from_payload(payload)
1458
- expect(event["breadcrumbs"].size).to eq(1)
1459
- expect(event["breadcrumbs"].first).to match({
1460
- "name" => "Test breadcrumb",
1461
- "type" => "manual",
1462
- "metaData" => {"a" => 1, "b" => 2},
1463
- "timestamp" => match(timestamp_regex)
1464
- })
1465
- }
1466
- end
1467
- end
1468
-
1469
- describe "#summary" do
1470
- it "provides a hash of the name, message, and severity" do
1471
- begin
1472
- 1/0
1473
- rescue ZeroDivisionError => e
1474
- report = Bugsnag::Report.new(e, Bugsnag.configuration)
1475
-
1476
- expect(report.summary).to eq({
1477
- :error_class => "ZeroDivisionError",
1478
- :message => "divided by 0",
1479
- :severity => "warning"
1480
- })
1481
- end
1482
- end
1483
-
1484
- it "handles strings" do
1485
- report = Bugsnag::Report.new("test string", Bugsnag.configuration)
1486
-
1487
- expect(report.summary).to eq({
1488
- :error_class => "RuntimeError",
1489
- :message => "test string",
1490
- :severity => "warning"
1491
- })
1492
- end
1493
-
1494
- it "handles error edge cases" do
1495
- report = Bugsnag::Report.new(Timeout::Error, Bugsnag.configuration)
1496
-
1497
- expect(report.summary).to eq({
1498
- :error_class => "Timeout::Error",
1499
- :message => "Timeout::Error",
1500
- :severity => "warning"
1501
- })
1502
- end
1503
-
1504
- it "handles empty exceptions" do
1505
- begin
1506
- 1/0
1507
- rescue ZeroDivisionError => e
1508
- report = Bugsnag::Report.new(e, Bugsnag.configuration)
1509
-
1510
- report.exceptions = []
1511
-
1512
- expect(report.summary).to eq({
1513
- :error_class => "Unknown",
1514
- :severity => "warning"
1515
- })
1516
- end
1517
- end
1518
-
1519
- it "handles removed exceptions" do
1520
- begin
1521
- 1/0
1522
- rescue ZeroDivisionError => e
1523
- report = Bugsnag::Report.new(e, Bugsnag.configuration)
1524
-
1525
- report.exceptions = nil
1526
-
1527
- expect(report.summary).to eq({
1528
- :error_class => "Unknown",
1529
- :severity => "warning"
1530
- })
1531
- end
1532
- end
1533
-
1534
- it "handles exceptions being replaced" do
1535
- begin
1536
- 1/0
1537
- rescue ZeroDivisionError => e
1538
- report = Bugsnag::Report.new(e, Bugsnag.configuration)
1539
-
1540
- report.exceptions = "no one should ever do this"
1541
-
1542
- expect(report.summary).to eq({
1543
- :error_class => "Unknown",
1544
- :severity => "warning"
1545
- })
1546
- end
1547
- end
1548
- end
1549
-
1550
- if defined?(JRUBY_VERSION)
1551
-
1552
- it "works with java.lang.Throwables" do
1553
- begin
1554
- JRubyException.raise!
1555
- rescue
1556
- Bugsnag.notify $!
1557
- end
1558
-
1559
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
1560
- exception = get_exception_from_payload(payload)
1561
- expect(exception["errorClass"]).to eq('Java::JavaLang::NullPointerException')
1562
- expect(exception["message"]).to eq("")
1563
- expect(exception["stacktrace"].size).to be > 0
1564
- }
1565
- end
1566
- end
1567
-
1568
- it 'includes device data when notify is called' do
1569
- Bugsnag.configuration.hostname = 'test-host'
1570
- Bugsnag.configuration.runtime_versions["ruby"] = '9.9.9'
1571
- Bugsnag.notify(BugsnagTestException.new("It crashed"))
1572
-
1573
- expect(Bugsnag).to have_sent_notification{ |payload, headers|
1574
- event = payload["events"][0]
1575
- expect(event["device"]["hostname"]).to eq('test-host')
1576
- expect(event["device"]["runtimeVersions"]["ruby"]).to eq('9.9.9')
1577
- }
1578
- end
1579
- end
1580
- # rubocop:enable Metrics/BlockLength