binnacle 0.4.8
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.gitignore +3 -0
- data/.ruby-gemset +1 -0
- data/.ruby-version +1 -0
- data/Gemfile +8 -0
- data/Gemfile.lock +138 -0
- data/LICENSE.txt +22 -0
- data/README.asc +264 -0
- data/Rakefile +48 -0
- data/bin/binnacle +5 -0
- data/binnacle.gemspec +49 -0
- data/lib/binnacle.rb +112 -0
- data/lib/binnacle/client.rb +115 -0
- data/lib/binnacle/commands/commands.rb +20 -0
- data/lib/binnacle/commands/help.rb +21 -0
- data/lib/binnacle/commands/tail.rb +187 -0
- data/lib/binnacle/configuration.rb +278 -0
- data/lib/binnacle/connection.rb +66 -0
- data/lib/binnacle/errors.rb +4 -0
- data/lib/binnacle/http_logging/adapters/ethon.rb +44 -0
- data/lib/binnacle/http_logging/adapters/excon.rb +62 -0
- data/lib/binnacle/http_logging/adapters/http.rb +63 -0
- data/lib/binnacle/http_logging/adapters/httpclient.rb +93 -0
- data/lib/binnacle/http_logging/adapters/net_http.rb +54 -0
- data/lib/binnacle/http_logging/adapters/patron.rb +24 -0
- data/lib/binnacle/http_logging/adapters/typhoeus.rb +20 -0
- data/lib/binnacle/http_logging/http_logger.rb +83 -0
- data/lib/binnacle/logging/formatter.rb +62 -0
- data/lib/binnacle/logging/logging.rb +36 -0
- data/lib/binnacle/logging/request_log_subscriber.rb +120 -0
- data/lib/binnacle/resource.rb +54 -0
- data/lib/binnacle/resources/event.rb +100 -0
- data/lib/binnacle/trap/backtrace.rb +130 -0
- data/lib/binnacle/trap/exception_event.rb +176 -0
- data/lib/binnacle/trap/middleware.rb +45 -0
- data/lib/binnacle/trap/railtie.rb +28 -0
- data/lib/binnacle/version.rb +3 -0
- data/lib/generators/binnacle/binnacle_generator.rb +78 -0
- data/lib/generators/binnacle/templates/firebase-messaging-sw.js.erb +35 -0
- data/spec/adapters/ethon_adapter.rb +19 -0
- data/spec/adapters/excon_adapter.rb +10 -0
- data/spec/adapters/faraday_adapter.rb +46 -0
- data/spec/adapters/http_adapter.rb +14 -0
- data/spec/adapters/http_base_adapter.rb +37 -0
- data/spec/adapters/httparty_adapter.rb +10 -0
- data/spec/adapters/httpclient_adapter.rb +21 -0
- data/spec/adapters/net_http_adapter.rb +14 -0
- data/spec/adapters/open_uri_adapter.rb +17 -0
- data/spec/adapters/patron_adapter.rb +29 -0
- data/spec/adapters/typhoeus_adapter.rb +25 -0
- data/spec/backtrace_spec.rb +197 -0
- data/spec/binnacle_spec.rb +33 -0
- data/spec/client_spec.rb +128 -0
- data/spec/commands_spec.rb +91 -0
- data/spec/configuration_spec.rb +139 -0
- data/spec/connection_spec.rb +34 -0
- data/spec/exception_event_spec.rb +72 -0
- data/spec/http_logger_spec.rb +77 -0
- data/spec/logger_spec.rb +60 -0
- data/spec/spec_helper.rb +117 -0
- data/spec/support/index.html +8 -0
- data/spec/support/index.html.gz +0 -0
- data/spec/support/test.bin +0 -0
- data/spec/support/test_server.rb +31 -0
- data/spec/support/utf8-invalid.html +0 -0
- data/spec/support/utf8.html +8 -0
- data/spec/vcr/binnacle/configure_can_be_configured_via_a_hash_of_options.yml +42 -0
- data/spec/vcr/binnacle/configure_creates_a_module_level_instance_of_a_binnacle_client.yml +42 -0
- data/spec/vcr/binnacle_client/events_invokes_the_events_api.yml +124 -0
- data/spec/vcr/binnacle_client/events_returns_a_collection_of_event_objects.yml +124 -0
- data/spec/vcr/binnacle_client/recents_invokes_the_events_api_recents.yml +83 -0
- data/spec/vcr/binnacle_client/recents_returns_a_collection_of_event_objects.yml +83 -0
- data/spec/vcr/binnacle_client/report_exception_invokes_the_events_api_signal.yml +121 -0
- data/spec/vcr/binnacle_client/signal_asynch_invokes_the_events_api_signal.yml +74 -0
- data/spec/vcr/binnacle_client/signal_invokes_the_events_api_signal.yml +74 -0
- data/spec/vcr/binnacle_client_ready_/returns_true_if_a_connection_has_been_successfully_established.yml +42 -0
- data/spec/vcr/binnacle_command/tail_command_with_n_flag_returns_recent_events.yml +81 -0
- data/spec/vcr/binnacle_connection/initialize_fails_with_incorrect_credentials.yml +40 -0
- data/spec/vcr/binnacle_connection/initialize_retrieves_available_endpoints_upon_successful_connection.yml +42 -0
- data/spec/vcr/binnacle_http_logger/_htt_party_adapter_should_log__ge_t_requests.yml +122 -0
- data/spec/vcr/binnacle_http_logger/_http_adapter_should_log__ge_t_requests.yml +165 -0
- data/spec/vcr/binnacle_http_logger/_http_client_adapter_should_log__ge_t_requests.yml +274 -0
- data/spec/vcr/binnacle_http_logger/ethon_adapter_should_log__ge_t_requests.yml +87 -0
- data/spec/vcr/binnacle_http_logger/excon_adapter_should_log__ge_t_requests.yml +204 -0
- data/spec/vcr/binnacle_http_logger/faraday_adapter_should_log__ge_t_requests.yml +200 -0
- data/spec/vcr/binnacle_http_logger/net_http_adapter_should_log__ge_t_requests.yml +827 -0
- data/spec/vcr/binnacle_http_logger/open_uri_adapter_should_log__ge_t_requests.yml +751 -0
- data/spec/vcr/binnacle_http_logger/patron_adapter_should_log__ge_t_requests.yml +124 -0
- data/spec/vcr/binnacle_http_logger/typhoeus_adapter_should_log__ge_t_requests.yml +124 -0
- data/spec/vcr/binnacle_logging/logging_allows_passing_other_parameters_using_a_hash.yml +119 -0
- data/spec/vcr/binnacle_logging/logging_invokes_the_events_api_signal.yml +75 -0
- data/spec/vcr/binnacle_logging/logging_respects_the_logger_severity.yml +81 -0
- data/vendor/assets/javascripts/atmosphere/atmosphere.js +3487 -0
- data/vendor/assets/javascripts/base64/base64.js +61 -0
- data/vendor/assets/javascripts/binnacle.js +5 -0
- data/vendor/assets/javascripts/binnacle/binnacle.js +9090 -0
- data/vendor/assets/javascripts/firebase/firebase-app-externs.js +261 -0
- data/vendor/assets/javascripts/firebase/firebase-app.js +35 -0
- data/vendor/assets/javascripts/firebase/firebase-auth-externs.js +1300 -0
- data/vendor/assets/javascripts/firebase/firebase-auth.js +241 -0
- data/vendor/assets/javascripts/firebase/firebase-database-externs.js +1700 -0
- data/vendor/assets/javascripts/firebase/firebase-database.js +260 -0
- data/vendor/assets/javascripts/firebase/firebase-messaging-externs.js +164 -0
- data/vendor/assets/javascripts/firebase/firebase-messaging.js +35 -0
- data/vendor/assets/javascripts/firebase/firebase-storage-externs.js +663 -0
- data/vendor/assets/javascripts/firebase/firebase-storage.js +52 -0
- data/vendor/assets/javascripts/firebase/firebase.js +611 -0
- data/vendor/assets/javascripts/moment/locale/af.js +73 -0
- data/vendor/assets/javascripts/moment/locale/ar-dz.js +59 -0
- data/vendor/assets/javascripts/moment/locale/ar-kw.js +59 -0
- data/vendor/assets/javascripts/moment/locale/ar-ly.js +126 -0
- data/vendor/assets/javascripts/moment/locale/ar-ma.js +60 -0
- data/vendor/assets/javascripts/moment/locale/ar-sa.js +105 -0
- data/vendor/assets/javascripts/moment/locale/ar-tn.js +59 -0
- data/vendor/assets/javascripts/moment/locale/ar.js +142 -0
- data/vendor/assets/javascripts/moment/locale/az.js +105 -0
- data/vendor/assets/javascripts/moment/locale/be.js +134 -0
- data/vendor/assets/javascripts/moment/locale/bg.js +90 -0
- data/vendor/assets/javascripts/moment/locale/bn.js +119 -0
- data/vendor/assets/javascripts/moment/locale/bo.js +119 -0
- data/vendor/assets/javascripts/moment/locale/br.js +108 -0
- data/vendor/assets/javascripts/moment/locale/bs.js +143 -0
- data/vendor/assets/javascripts/moment/locale/ca.js +88 -0
- data/vendor/assets/javascripts/moment/locale/cs.js +172 -0
- data/vendor/assets/javascripts/moment/locale/cv.js +63 -0
- data/vendor/assets/javascripts/moment/locale/cy.js +81 -0
- data/vendor/assets/javascripts/moment/locale/da.js +60 -0
- data/vendor/assets/javascripts/moment/locale/de-at.js +79 -0
- data/vendor/assets/javascripts/moment/locale/de-ch.js +78 -0
- data/vendor/assets/javascripts/moment/locale/de.js +78 -0
- data/vendor/assets/javascripts/moment/locale/dv.js +100 -0
- data/vendor/assets/javascripts/moment/locale/el.js +100 -0
- data/vendor/assets/javascripts/moment/locale/en-au.js +67 -0
- data/vendor/assets/javascripts/moment/locale/en-ca.js +63 -0
- data/vendor/assets/javascripts/moment/locale/en-gb.js +67 -0
- data/vendor/assets/javascripts/moment/locale/en-ie.js +67 -0
- data/vendor/assets/javascripts/moment/locale/en-nz.js +67 -0
- data/vendor/assets/javascripts/moment/locale/eo.js +73 -0
- data/vendor/assets/javascripts/moment/locale/es-do.js +82 -0
- data/vendor/assets/javascripts/moment/locale/es.js +83 -0
- data/vendor/assets/javascripts/moment/locale/et.js +80 -0
- data/vendor/assets/javascripts/moment/locale/eu.js +66 -0
- data/vendor/assets/javascripts/moment/locale/fa.js +107 -0
- data/vendor/assets/javascripts/moment/locale/fi.js +107 -0
- data/vendor/assets/javascripts/moment/locale/fo.js +60 -0
- data/vendor/assets/javascripts/moment/locale/fr-ca.js +74 -0
- data/vendor/assets/javascripts/moment/locale/fr-ch.js +78 -0
- data/vendor/assets/javascripts/moment/locale/fr.js +83 -0
- data/vendor/assets/javascripts/moment/locale/fy.js +75 -0
- data/vendor/assets/javascripts/moment/locale/gd.js +76 -0
- data/vendor/assets/javascripts/moment/locale/gl.js +77 -0
- data/vendor/assets/javascripts/moment/locale/gom-latn.js +122 -0
- data/vendor/assets/javascripts/moment/locale/he.js +99 -0
- data/vendor/assets/javascripts/moment/locale/hi.js +124 -0
- data/vendor/assets/javascripts/moment/locale/hr.js +145 -0
- data/vendor/assets/javascripts/moment/locale/hu.js +109 -0
- data/vendor/assets/javascripts/moment/locale/hy-am.js +95 -0
- data/vendor/assets/javascripts/moment/locale/id.js +83 -0
- data/vendor/assets/javascripts/moment/locale/is.js +127 -0
- data/vendor/assets/javascripts/moment/locale/it.js +70 -0
- data/vendor/assets/javascripts/moment/locale/ja.js +80 -0
- data/vendor/assets/javascripts/moment/locale/jv.js +83 -0
- data/vendor/assets/javascripts/moment/locale/ka.js +89 -0
- data/vendor/assets/javascripts/moment/locale/kk.js +87 -0
- data/vendor/assets/javascripts/moment/locale/km.js +58 -0
- data/vendor/assets/javascripts/moment/locale/kn.js +126 -0
- data/vendor/assets/javascripts/moment/locale/ko.js +69 -0
- data/vendor/assets/javascripts/moment/locale/ky.js +88 -0
- data/vendor/assets/javascripts/moment/locale/lb.js +137 -0
- data/vendor/assets/javascripts/moment/locale/lo.js +70 -0
- data/vendor/assets/javascripts/moment/locale/lt.js +117 -0
- data/vendor/assets/javascripts/moment/locale/lv.js +97 -0
- data/vendor/assets/javascripts/moment/locale/me.js +111 -0
- data/vendor/assets/javascripts/moment/locale/mi.js +64 -0
- data/vendor/assets/javascripts/moment/locale/mk.js +90 -0
- data/vendor/assets/javascripts/moment/locale/ml.js +81 -0
- data/vendor/assets/javascripts/moment/locale/mr.js +159 -0
- data/vendor/assets/javascripts/moment/locale/ms-my.js +83 -0
- data/vendor/assets/javascripts/moment/locale/ms.js +82 -0
- data/vendor/assets/javascripts/moment/locale/my.js +96 -0
- data/vendor/assets/javascripts/moment/locale/nb.js +63 -0
- data/vendor/assets/javascripts/moment/locale/ne.js +123 -0
- data/vendor/assets/javascripts/moment/locale/nl-be.js +88 -0
- data/vendor/assets/javascripts/moment/locale/nl.js +88 -0
- data/vendor/assets/javascripts/moment/locale/nn.js +60 -0
- data/vendor/assets/javascripts/moment/locale/pa-in.js +124 -0
- data/vendor/assets/javascripts/moment/locale/pl.js +107 -0
- data/vendor/assets/javascripts/moment/locale/pt-br.js +61 -0
- data/vendor/assets/javascripts/moment/locale/pt.js +65 -0
- data/vendor/assets/javascripts/moment/locale/ro.js +75 -0
- data/vendor/assets/javascripts/moment/locale/ru.js +183 -0
- data/vendor/assets/javascripts/moment/locale/sd.js +98 -0
- data/vendor/assets/javascripts/moment/locale/se.js +61 -0
- data/vendor/assets/javascripts/moment/locale/si.js +71 -0
- data/vendor/assets/javascripts/moment/locale/sk.js +150 -0
- data/vendor/assets/javascripts/moment/locale/sl.js +162 -0
- data/vendor/assets/javascripts/moment/locale/sq.js +70 -0
- data/vendor/assets/javascripts/moment/locale/sr-cyrl.js +110 -0
- data/vendor/assets/javascripts/moment/locale/sr.js +110 -0
- data/vendor/assets/javascripts/moment/locale/ss.js +89 -0
- data/vendor/assets/javascripts/moment/locale/sv.js +69 -0
- data/vendor/assets/javascripts/moment/locale/sw.js +59 -0
- data/vendor/assets/javascripts/moment/locale/ta.js +130 -0
- data/vendor/assets/javascripts/moment/locale/te.js +89 -0
- data/vendor/assets/javascripts/moment/locale/tet.js +68 -0
- data/vendor/assets/javascripts/moment/locale/th.js +67 -0
- data/vendor/assets/javascripts/moment/locale/tl-ph.js +62 -0
- data/vendor/assets/javascripts/moment/locale/tlh.js +120 -0
- data/vendor/assets/javascripts/moment/locale/tr.js +90 -0
- data/vendor/assets/javascripts/moment/locale/tzl.js +91 -0
- data/vendor/assets/javascripts/moment/locale/tzm-latn.js +58 -0
- data/vendor/assets/javascripts/moment/locale/tzm.js +58 -0
- data/vendor/assets/javascripts/moment/locale/uk.js +151 -0
- data/vendor/assets/javascripts/moment/locale/ur.js +99 -0
- data/vendor/assets/javascripts/moment/locale/uz-latn.js +58 -0
- data/vendor/assets/javascripts/moment/locale/uz.js +58 -0
- data/vendor/assets/javascripts/moment/locale/vi.js +79 -0
- data/vendor/assets/javascripts/moment/locale/x-pseudo.js +68 -0
- data/vendor/assets/javascripts/moment/locale/yo.js +60 -0
- data/vendor/assets/javascripts/moment/locale/zh-cn.js +111 -0
- data/vendor/assets/javascripts/moment/locale/zh-hk.js +105 -0
- data/vendor/assets/javascripts/moment/locale/zh-tw.js +104 -0
- data/vendor/assets/javascripts/moment/min/locales.js +9252 -0
- data/vendor/assets/javascripts/moment/min/moment-with-locales.js +13700 -0
- data/vendor/assets/javascripts/moment/min/moment.min.js +7 -0
- data/vendor/assets/javascripts/moment/min/tests.js +78265 -0
- data/vendor/assets/javascripts/moment/moment.js +4463 -0
- data/vendor/assets/javascripts/moment/src/lib/create/check-overflow.js +34 -0
- data/vendor/assets/javascripts/moment/src/lib/create/date-from-array.js +21 -0
- data/vendor/assets/javascripts/moment/src/lib/create/from-anything.js +110 -0
- data/vendor/assets/javascripts/moment/src/lib/create/from-array.js +140 -0
- data/vendor/assets/javascripts/moment/src/lib/create/from-object.js +16 -0
- data/vendor/assets/javascripts/moment/src/lib/create/from-string-and-array.js +50 -0
- data/vendor/assets/javascripts/moment/src/lib/create/from-string-and-format.js +113 -0
- data/vendor/assets/javascripts/moment/src/lib/create/from-string.js +202 -0
- data/vendor/assets/javascripts/moment/src/lib/create/local.js +5 -0
- data/vendor/assets/javascripts/moment/src/lib/create/parsing-flags.js +26 -0
- data/vendor/assets/javascripts/moment/src/lib/create/utc.js +5 -0
- data/vendor/assets/javascripts/moment/src/lib/create/valid.js +49 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/abs.js +18 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/add-subtract.js +21 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/as.js +61 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/bubble.js +61 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/constructor.js +44 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/create.js +122 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/duration.js +16 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/get.js +25 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/humanize.js +85 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/iso-string.js +56 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/prototype.js +50 -0
- data/vendor/assets/javascripts/moment/src/lib/duration/valid.js +35 -0
- data/vendor/assets/javascripts/moment/src/lib/format/format.js +92 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/base-config.js +44 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/calendar.js +15 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/constructor.js +5 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/en.js +15 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/formats.js +23 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/invalid.js +5 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/lists.js +93 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/locale.js +39 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/locales.js +186 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/ordinal.js +7 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/pre-post-format.js +3 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/prototype.js +69 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/relative.js +30 -0
- data/vendor/assets/javascripts/moment/src/lib/locale/set.js +49 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/add-subtract.js +55 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/calendar.js +26 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/clone.js +5 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/compare.js +59 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/constructor.js +77 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/creation-data.js +9 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/diff.js +62 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/format.js +57 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/from.js +17 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/get-set.js +55 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/locale.js +34 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/min-max.js +63 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/moment.js +28 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/now.js +3 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/prototype.js +150 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/start-end-of.js +59 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/to-type.js +34 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/to.js +17 -0
- data/vendor/assets/javascripts/moment/src/lib/moment/valid.js +15 -0
- data/vendor/assets/javascripts/moment/src/lib/parse/regex.js +54 -0
- data/vendor/assets/javascripts/moment/src/lib/parse/token.js +33 -0
- data/vendor/assets/javascripts/moment/src/lib/units/aliases.js +30 -0
- data/vendor/assets/javascripts/moment/src/lib/units/constants.js +9 -0
- data/vendor/assets/javascripts/moment/src/lib/units/day-of-month.js +39 -0
- data/vendor/assets/javascripts/moment/src/lib/units/day-of-week.js +364 -0
- data/vendor/assets/javascripts/moment/src/lib/units/day-of-year.js +36 -0
- data/vendor/assets/javascripts/moment/src/lib/units/hour.js +144 -0
- data/vendor/assets/javascripts/moment/src/lib/units/millisecond.js +69 -0
- data/vendor/assets/javascripts/moment/src/lib/units/minute.js +29 -0
- data/vendor/assets/javascripts/moment/src/lib/units/month.js +283 -0
- data/vendor/assets/javascripts/moment/src/lib/units/offset.js +235 -0
- data/vendor/assets/javascripts/moment/src/lib/units/priorities.js +16 -0
- data/vendor/assets/javascripts/moment/src/lib/units/quarter.js +32 -0
- data/vendor/assets/javascripts/moment/src/lib/units/second.js +29 -0
- data/vendor/assets/javascripts/moment/src/lib/units/timestamp.js +20 -0
- data/vendor/assets/javascripts/moment/src/lib/units/timezone.js +16 -0
- data/vendor/assets/javascripts/moment/src/lib/units/units.js +20 -0
- data/vendor/assets/javascripts/moment/src/lib/units/week-calendar-utils.js +65 -0
- data/vendor/assets/javascripts/moment/src/lib/units/week-year.js +107 -0
- data/vendor/assets/javascripts/moment/src/lib/units/week.js +67 -0
- data/vendor/assets/javascripts/moment/src/lib/units/year.js +75 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/abs-ceil.js +7 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/abs-floor.js +8 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/abs-round.js +7 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/compare-arrays.js +16 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/defaults.js +10 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/deprecate.js +55 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/extend.js +19 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/has-own-prop.js +3 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/hooks.js +13 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/index-of.js +18 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/is-array.js +3 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/is-date.js +3 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/is-function.js +3 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/is-number.js +3 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/is-object-empty.js +8 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/is-object.js +5 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/is-undefined.js +3 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/keys.js +19 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/map.js +7 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/some.js +19 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/to-int.js +12 -0
- data/vendor/assets/javascripts/moment/src/lib/utils/zero-fill.js +7 -0
- data/vendor/assets/javascripts/moment/src/locale/af.js +63 -0
- data/vendor/assets/javascripts/moment/src/locale/ar-dz.js +50 -0
- data/vendor/assets/javascripts/moment/src/locale/ar-kw.js +49 -0
- data/vendor/assets/javascripts/moment/src/locale/ar-ly.js +112 -0
- data/vendor/assets/javascripts/moment/src/locale/ar-ma.js +51 -0
- data/vendor/assets/javascripts/moment/src/locale/ar-sa.js +95 -0
- data/vendor/assets/javascripts/moment/src/locale/ar-tn.js +50 -0
- data/vendor/assets/javascripts/moment/src/locale/ar.js +128 -0
- data/vendor/assets/javascripts/moment/src/locale/az.js +96 -0
- data/vendor/assets/javascripts/moment/src/locale/be.js +125 -0
- data/vendor/assets/javascripts/moment/src/locale/bg.js +81 -0
- data/vendor/assets/javascripts/moment/src/locale/bn.js +109 -0
- data/vendor/assets/javascripts/moment/src/locale/bo.js +110 -0
- data/vendor/assets/javascripts/moment/src/locale/br.js +99 -0
- data/vendor/assets/javascripts/moment/src/locale/bs.js +133 -0
- data/vendor/assets/javascripts/moment/src/locale/ca.js +79 -0
- data/vendor/assets/javascripts/moment/src/locale/cs.js +163 -0
- data/vendor/assets/javascripts/moment/src/locale/cv.js +53 -0
- data/vendor/assets/javascripts/moment/src/locale/cy.js +72 -0
- data/vendor/assets/javascripts/moment/src/locale/da.js +50 -0
- data/vendor/assets/javascripts/moment/src/locale/de-at.js +69 -0
- data/vendor/assets/javascripts/moment/src/locale/de-ch.js +68 -0
- data/vendor/assets/javascripts/moment/src/locale/de.js +68 -0
- data/vendor/assets/javascripts/moment/src/locale/dv.js +89 -0
- data/vendor/assets/javascripts/moment/src/locale/el.js +88 -0
- data/vendor/assets/javascripts/moment/src/locale/en-au.js +58 -0
- data/vendor/assets/javascripts/moment/src/locale/en-ca.js +53 -0
- data/vendor/assets/javascripts/moment/src/locale/en-gb.js +58 -0
- data/vendor/assets/javascripts/moment/src/locale/en-ie.js +58 -0
- data/vendor/assets/javascripts/moment/src/locale/en-nz.js +57 -0
- data/vendor/assets/javascripts/moment/src/locale/eo.js +64 -0
- data/vendor/assets/javascripts/moment/src/locale/es-do.js +73 -0
- data/vendor/assets/javascripts/moment/src/locale/es.js +74 -0
- data/vendor/assets/javascripts/moment/src/locale/et.js +71 -0
- data/vendor/assets/javascripts/moment/src/locale/eu.js +57 -0
- data/vendor/assets/javascripts/moment/src/locale/fa.js +97 -0
- data/vendor/assets/javascripts/moment/src/locale/fi.js +98 -0
- data/vendor/assets/javascripts/moment/src/locale/fo.js +51 -0
- data/vendor/assets/javascripts/moment/src/locale/fr-ca.js +65 -0
- data/vendor/assets/javascripts/moment/src/locale/fr-ch.js +69 -0
- data/vendor/assets/javascripts/moment/src/locale/fr.js +74 -0
- data/vendor/assets/javascripts/moment/src/locale/fy.js +66 -0
- data/vendor/assets/javascripts/moment/src/locale/gd.js +67 -0
- data/vendor/assets/javascripts/moment/src/locale/gl.js +68 -0
- data/vendor/assets/javascripts/moment/src/locale/gom-latn.js +112 -0
- data/vendor/assets/javascripts/moment/src/locale/he.js +90 -0
- data/vendor/assets/javascripts/moment/src/locale/hi.js +115 -0
- data/vendor/assets/javascripts/moment/src/locale/hr.js +135 -0
- data/vendor/assets/javascripts/moment/src/locale/hu.js +100 -0
- data/vendor/assets/javascripts/moment/src/locale/hy-am.js +86 -0
- data/vendor/assets/javascripts/moment/src/locale/id.js +74 -0
- data/vendor/assets/javascripts/moment/src/locale/is.js +118 -0
- data/vendor/assets/javascripts/moment/src/locale/it.js +61 -0
- data/vendor/assets/javascripts/moment/src/locale/ja.js +71 -0
- data/vendor/assets/javascripts/moment/src/locale/jv.js +73 -0
- data/vendor/assets/javascripts/moment/src/locale/ka.js +80 -0
- data/vendor/assets/javascripts/moment/src/locale/kk.js +77 -0
- data/vendor/assets/javascripts/moment/src/locale/km.js +49 -0
- data/vendor/assets/javascripts/moment/src/locale/kn.js +116 -0
- data/vendor/assets/javascripts/moment/src/locale/ko.js +60 -0
- data/vendor/assets/javascripts/moment/src/locale/ky.js +78 -0
- data/vendor/assets/javascripts/moment/src/locale/lb.js +128 -0
- data/vendor/assets/javascripts/moment/src/locale/lo.js +61 -0
- data/vendor/assets/javascripts/moment/src/locale/lt.js +108 -0
- data/vendor/assets/javascripts/moment/src/locale/lv.js +88 -0
- data/vendor/assets/javascripts/moment/src/locale/me.js +101 -0
- data/vendor/assets/javascripts/moment/src/locale/mi.js +54 -0
- data/vendor/assets/javascripts/moment/src/locale/mk.js +81 -0
- data/vendor/assets/javascripts/moment/src/locale/ml.js +72 -0
- data/vendor/assets/javascripts/moment/src/locale/mr.js +150 -0
- data/vendor/assets/javascripts/moment/src/locale/ms-my.js +74 -0
- data/vendor/assets/javascripts/moment/src/locale/ms.js +73 -0
- data/vendor/assets/javascripts/moment/src/locale/my.js +86 -0
- data/vendor/assets/javascripts/moment/src/locale/nb.js +54 -0
- data/vendor/assets/javascripts/moment/src/locale/ne.js +114 -0
- data/vendor/assets/javascripts/moment/src/locale/nl-be.js +79 -0
- data/vendor/assets/javascripts/moment/src/locale/nl.js +79 -0
- data/vendor/assets/javascripts/moment/src/locale/nn.js +51 -0
- data/vendor/assets/javascripts/moment/src/locale/pa-in.js +115 -0
- data/vendor/assets/javascripts/moment/src/locale/pl.js +97 -0
- data/vendor/assets/javascripts/moment/src/locale/pt-br.js +52 -0
- data/vendor/assets/javascripts/moment/src/locale/pt.js +56 -0
- data/vendor/assets/javascripts/moment/src/locale/ro.js +66 -0
- data/vendor/assets/javascripts/moment/src/locale/ru.js +173 -0
- data/vendor/assets/javascripts/moment/src/locale/sd.js +88 -0
- data/vendor/assets/javascripts/moment/src/locale/se.js +51 -0
- data/vendor/assets/javascripts/moment/src/locale/si.js +61 -0
- data/vendor/assets/javascripts/moment/src/locale/sk.js +141 -0
- data/vendor/assets/javascripts/moment/src/locale/sl.js +152 -0
- data/vendor/assets/javascripts/moment/src/locale/sq.js +61 -0
- data/vendor/assets/javascripts/moment/src/locale/sr-cyrl.js +100 -0
- data/vendor/assets/javascripts/moment/src/locale/sr.js +100 -0
- data/vendor/assets/javascripts/moment/src/locale/ss.js +80 -0
- data/vendor/assets/javascripts/moment/src/locale/sv.js +60 -0
- data/vendor/assets/javascripts/moment/src/locale/sw.js +50 -0
- data/vendor/assets/javascripts/moment/src/locale/ta.js +120 -0
- data/vendor/assets/javascripts/moment/src/locale/te.js +79 -0
- data/vendor/assets/javascripts/moment/src/locale/tet.js +58 -0
- data/vendor/assets/javascripts/moment/src/locale/th.js +57 -0
- data/vendor/assets/javascripts/moment/src/locale/tl-ph.js +53 -0
- data/vendor/assets/javascripts/moment/src/locale/tlh.js +110 -0
- data/vendor/assets/javascripts/moment/src/locale/tr.js +81 -0
- data/vendor/assets/javascripts/moment/src/locale/tzl.js +82 -0
- data/vendor/assets/javascripts/moment/src/locale/tzm-latn.js +49 -0
- data/vendor/assets/javascripts/moment/src/locale/tzm.js +49 -0
- data/vendor/assets/javascripts/moment/src/locale/uk.js +142 -0
- data/vendor/assets/javascripts/moment/src/locale/ur.js +89 -0
- data/vendor/assets/javascripts/moment/src/locale/uz-latn.js +49 -0
- data/vendor/assets/javascripts/moment/src/locale/uz.js +49 -0
- data/vendor/assets/javascripts/moment/src/locale/vi.js +70 -0
- data/vendor/assets/javascripts/moment/src/locale/x-pseudo.js +58 -0
- data/vendor/assets/javascripts/moment/src/locale/yo.js +50 -0
- data/vendor/assets/javascripts/moment/src/locale/zh-cn.js +102 -0
- data/vendor/assets/javascripts/moment/src/locale/zh-hk.js +95 -0
- data/vendor/assets/javascripts/moment/src/locale/zh-tw.js +94 -0
- data/vendor/assets/javascripts/moment/src/moment.js +82 -0
- data/vendor/assets/javascripts/moment/templates/default.js +5 -0
- data/vendor/assets/javascripts/moment/templates/locale-header.js +6 -0
- data/vendor/assets/javascripts/moment/templates/test-header.js +6 -0
- metadata +943 -0
@@ -0,0 +1,139 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Binnacle::Configuration do
|
4
|
+
|
5
|
+
describe 'initialize' do
|
6
|
+
before { reset_env }
|
7
|
+
|
8
|
+
it 'can be configured via ENV variables' do
|
9
|
+
ENV['BINNACLE_ENDPOINT'] = '127.0.0.1'
|
10
|
+
ENV['BINNACLE_PORT'] = '8080'
|
11
|
+
ENV['BINNACLE_APP_LOG_CHANNEL'] = 'icoc0tnol3obe8pas207'
|
12
|
+
ENV['BINNACLE_APP_ERR_CHANNEL'] = 'id0czm8eryfffcgp875c'
|
13
|
+
ENV['BINNACLE_API_KEY'] = 'vceth4xcwqfoowpz2esi'
|
14
|
+
ENV['BINNACLE_API_SECRET'] = '1grttyb8ozbe9axt88ji'
|
15
|
+
ENV['BINNACLE_RAILS_LOG'] = 'TRUE'
|
16
|
+
ENV['BINNACLE_REPORT_EXCEPTIONS'] = 'TRUE'
|
17
|
+
ENV['BINNACLE_IGNORED_EXCEPTIONS'] = 'ZeroDivisionError'
|
18
|
+
ENV['BINNACLE_RAILS_LOG_ASYNCH'] = 'TRUE'
|
19
|
+
ENV['BINNACLE_ENCRYPTED'] = 'TRUE'
|
20
|
+
|
21
|
+
config = Binnacle::Configuration.new
|
22
|
+
|
23
|
+
expect(config.endpoint).to eq '127.0.0.1'
|
24
|
+
expect(config.port).to eq '8080'
|
25
|
+
expect(config.logging_channel).to eq 'icoc0tnol3obe8pas207'
|
26
|
+
expect(config.error_channel).to eq 'id0czm8eryfffcgp875c'
|
27
|
+
expect(config.api_key).to eq 'vceth4xcwqfoowpz2esi'
|
28
|
+
expect(config.api_secret).to eq '1grttyb8ozbe9axt88ji'
|
29
|
+
expect(config.intercept_rails_logging).to be true
|
30
|
+
expect(config.report_exceptions).to be true
|
31
|
+
expect(config.ignored_exceptions).to include('ZeroDivisionError')
|
32
|
+
expect(config.encrypted).to be true
|
33
|
+
expect(config.asynch_logging).to be true
|
34
|
+
end
|
35
|
+
end
|
36
|
+
|
37
|
+
describe 'endpoint' do
|
38
|
+
before { reset_env }
|
39
|
+
|
40
|
+
it 'configures urls given one endpoint' do
|
41
|
+
config = Binnacle::Configuration.new
|
42
|
+
config.endpoint = '127.0.0.1'
|
43
|
+
config.encrypted = false
|
44
|
+
|
45
|
+
expect(config.url).to eq('http://127.0.0.1:8080')
|
46
|
+
end
|
47
|
+
|
48
|
+
it 'configures urls given multiple endpoints' do
|
49
|
+
config = Binnacle::Configuration.new
|
50
|
+
config.endpoint = ['127.0.0.1', 'localhost', '192.168.0.1']
|
51
|
+
config.encrypted = false
|
52
|
+
|
53
|
+
expect(config.urls).to include('http://127.0.0.1:8080', 'http://localhost:8080', 'http://192.168.0.1:8080')
|
54
|
+
end
|
55
|
+
|
56
|
+
it 'configures urls given multiple endpoints via ENV var' do
|
57
|
+
ENV['BINNACLE_ENDPOINT'] = 'api1.binnacle-api.io,api2.binnacle-api.io,api3.binnacle-api.io'
|
58
|
+
config = Binnacle::Configuration.new
|
59
|
+
|
60
|
+
expect(config.urls).to include('https://api1.binnacle-api.io', 'https://api2.binnacle-api.io', 'https://api3.binnacle-api.io')
|
61
|
+
end
|
62
|
+
end
|
63
|
+
|
64
|
+
describe 'encrypted' do
|
65
|
+
before { reset_env }
|
66
|
+
|
67
|
+
it 'uses HTTP protocol if the encrypted flag is false' do
|
68
|
+
config = Binnacle::Configuration.new
|
69
|
+
config.endpoint = '127.0.0.1'
|
70
|
+
config.encrypted = false
|
71
|
+
|
72
|
+
expect(config.url).to eq('http://127.0.0.1:8080')
|
73
|
+
end
|
74
|
+
|
75
|
+
it 'uses HTTPS protocol by default without a port' do
|
76
|
+
config = Binnacle::Configuration.new
|
77
|
+
config.endpoint = 'api1.binnacle-api.io'
|
78
|
+
|
79
|
+
expect(config.url).to eq('https://api1.binnacle-api.io')
|
80
|
+
end
|
81
|
+
end
|
82
|
+
|
83
|
+
describe '#can_setup_logger?' do
|
84
|
+
before { reset_env }
|
85
|
+
|
86
|
+
it 'returns true if logging channel is set' do
|
87
|
+
ENV['BINNACLE_APP_LOG_CHANNEL'] = 'icoc0tnol3obe8pas207'
|
88
|
+
|
89
|
+
config = Binnacle::Configuration.new
|
90
|
+
expect(config.can_setup_logger?).to be true
|
91
|
+
end
|
92
|
+
end
|
93
|
+
|
94
|
+
describe '#trap?' do
|
95
|
+
before { reset_env }
|
96
|
+
|
97
|
+
it 'return true is log interception and logging channel are set' do
|
98
|
+
ENV['BINNACLE_APP_ERR_CHANNEL'] = 'id0czm8eryfffcgp875c'
|
99
|
+
ENV['BINNACLE_REPORT_EXCEPTIONS'] = 'TRUE'
|
100
|
+
|
101
|
+
config = Binnacle::Configuration.new
|
102
|
+
expect(config.trap?).to be true
|
103
|
+
end
|
104
|
+
end
|
105
|
+
|
106
|
+
describe '#ignore_cascade_pass?' do
|
107
|
+
|
108
|
+
it 'is true by default' do
|
109
|
+
config = Binnacle::Configuration.new
|
110
|
+
expect(config.ignore_cascade_pass?).to be true
|
111
|
+
end
|
112
|
+
end
|
113
|
+
|
114
|
+
describe '#to_s' do
|
115
|
+
before { reset_env }
|
116
|
+
|
117
|
+
it 'returns a representation of the config object' do
|
118
|
+
ENV['BINNACLE_ENDPOINT'] = '127.0.0.1'
|
119
|
+
ENV['BINNACLE_APP_LOG_CHANNEL'] = 'icoc0tnol3obe8pas207'
|
120
|
+
ENV['BINNACLE_APP_ERR_CHANNEL'] = 'id0czm8eryfffcgp875c'
|
121
|
+
ENV['BINNACLE_API_KEY'] = 'vceth4xcwqfoowpz2esi'
|
122
|
+
ENV['BINNACLE_API_SECRET'] = '1grttyb8ozbe9axt88ji'
|
123
|
+
ENV['BINNACLE_ENCRYPTED'] = 'FALSE'
|
124
|
+
|
125
|
+
config = Binnacle::Configuration.new
|
126
|
+
expect(config.to_s).to eq("endpoint: 127.0.0.1,"\
|
127
|
+
" logging_channel: icoc0tnol3obe8pas207,"\
|
128
|
+
" error_channel: id0czm8eryfffcgp875c,"\
|
129
|
+
" api_key: vceth4xcwqfoowpz2esi,"\
|
130
|
+
" api_secret: 1grttyb8ozbe9axt88ji,"\
|
131
|
+
" intercept_rails_logging: false,"\
|
132
|
+
" report_exceptions: false,"\
|
133
|
+
" ignore_cascade_pass: true,"\
|
134
|
+
" encrypted: false,"\
|
135
|
+
" asynch_logging: true")
|
136
|
+
end
|
137
|
+
end
|
138
|
+
|
139
|
+
end
|
@@ -0,0 +1,34 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Binnacle::Connection do
|
4
|
+
|
5
|
+
describe 'initialize', :vcr do
|
6
|
+
before { Binnacle.binnacle_logger = TestLogger.new }
|
7
|
+
|
8
|
+
it 'fails with incorrect credentials', :vcr do
|
9
|
+
expected_output = "ERROR -- : Error communicating with Binnacle (/api/endpoints): Credentials are required to access this resource."
|
10
|
+
connection = Binnacle::Connection.new('vceth4xcwqfoowpz2esi', '1grttyb8ozbe9axt88ji', 'http://104.131.46.61:8080')
|
11
|
+
expect(a_request(:get, 'http://104.131.46.61:8080/api/endpoints'))
|
12
|
+
expect(Binnacle.binnacle_logger.messages).to include(expected_output)
|
13
|
+
end
|
14
|
+
|
15
|
+
it 'retrieves available endpoints upon successful connection', :vcr do
|
16
|
+
connection = Binnacle::Connection.new('863u7fzchvjx2oiclasx', '33lrt5aiizizhu5z7f3b', 'http://104.131.46.61:8080')
|
17
|
+
expect(a_request(:get, 'http://104.131.46.61:8080/api/endpoints'))
|
18
|
+
expect(Binnacle.configuration.urls).to include('http://104.131.41.123:8080',
|
19
|
+
'http://104.236.110.41:8080',
|
20
|
+
'http://104.131.46.61:8080',
|
21
|
+
'http://104.131.106.113:8080',
|
22
|
+
'http://45.55.141.159:8080',
|
23
|
+
'http://104.131.75.74:8080')
|
24
|
+
end
|
25
|
+
|
26
|
+
it 'fails with bad endpoint', :vcr do
|
27
|
+
expected_output = %[ERROR -- : Error communicating with Binnacle (/api/endpoints): Connection refused - Connection refused - connect(2) for "localhost" port 8888 (localhost:8888)]
|
28
|
+
connection = Binnacle::Connection.new('vceth4xcwqfoowpz2esi', '1grttyb8ozbe9axt88ji', 'http://localhost:8888')
|
29
|
+
expect(a_request(:get, 'http://localhost:8888/api/endpoints'))
|
30
|
+
expect(Binnacle.binnacle_logger.messages).to include(expected_output)
|
31
|
+
end
|
32
|
+
end
|
33
|
+
|
34
|
+
end
|
@@ -0,0 +1,72 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Binnacle::Trap::ExceptionEvent do
|
4
|
+
describe 'initialize' do
|
5
|
+
it 'extracts Rails expection information from Action Dispatch request parameters' do
|
6
|
+
exception = ZeroDivisionError.new
|
7
|
+
env = {}
|
8
|
+
env['action_dispatch.request.parameters'] = {}
|
9
|
+
env['action_dispatch.request.parameters'][:controller] = 'dashboard'
|
10
|
+
env['action_dispatch.request.parameters'][:action] = 'analytics'
|
11
|
+
env['action_dispatch.request.parameters'][:module] = 'dashboard'
|
12
|
+
|
13
|
+
exception_event = Binnacle::Trap::ExceptionEvent.new(exception, env)
|
14
|
+
|
15
|
+
expect(exception_event.component).to eq('dashboard')
|
16
|
+
expect(exception_event.method).to eq('analytics')
|
17
|
+
expect(exception_event.module).to eq('dashboard')
|
18
|
+
end
|
19
|
+
|
20
|
+
it 'unwraps original_exception' do
|
21
|
+
class MyWrappedError < StandardError
|
22
|
+
attr_reader :original_exception
|
23
|
+
def initialize(msg, original=$!)
|
24
|
+
super(msg)
|
25
|
+
@original_exception = original
|
26
|
+
end
|
27
|
+
end
|
28
|
+
original_exception = ZeroDivisionError.new
|
29
|
+
exception = MyWrappedError.new("Boom!", original_exception)
|
30
|
+
exception_event = Binnacle::Trap::ExceptionEvent.new(exception, {})
|
31
|
+
|
32
|
+
expect(exception_event.exception).to be(original_exception)
|
33
|
+
end
|
34
|
+
|
35
|
+
it 'unwraps continous_exception' do
|
36
|
+
class MyContinuedError < StandardError
|
37
|
+
attr_reader :continued_exception
|
38
|
+
def initialize(msg, continous=$!)
|
39
|
+
super(msg)
|
40
|
+
@continued_exception = continous
|
41
|
+
end
|
42
|
+
end
|
43
|
+
continued_exception = ZeroDivisionError.new
|
44
|
+
exception = MyContinuedError.new("Boom!", continued_exception)
|
45
|
+
exception_event = Binnacle::Trap::ExceptionEvent.new(exception, {})
|
46
|
+
|
47
|
+
expect(exception_event.exception).to be(continued_exception)
|
48
|
+
end
|
49
|
+
end
|
50
|
+
|
51
|
+
describe 'build_json_payload' do
|
52
|
+
it 'creates a valid JSON payload' do
|
53
|
+
exception = ZeroDivisionError.new
|
54
|
+
env = {}
|
55
|
+
env['action_dispatch.request.parameters'] = {}
|
56
|
+
env['action_dispatch.request.parameters'][:controller] = 'dashboard'
|
57
|
+
env['action_dispatch.request.parameters'][:action] = 'analytics'
|
58
|
+
env['action_dispatch.request.parameters'][:module] = 'dashboard'
|
59
|
+
|
60
|
+
exception_event = Binnacle::Trap::ExceptionEvent.new(exception, env)
|
61
|
+
|
62
|
+
json = {
|
63
|
+
:exception=>"ZeroDivisionError",
|
64
|
+
:message=>"ZeroDivisionError",
|
65
|
+
:component=>"dashboard",
|
66
|
+
:method=>"analytics"
|
67
|
+
}
|
68
|
+
|
69
|
+
expect(exception_event.json).to match(a_hash_including(json))
|
70
|
+
end
|
71
|
+
end
|
72
|
+
end
|
@@ -0,0 +1,77 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Binnacle::HttpLogger do
|
4
|
+
before do
|
5
|
+
reset_env
|
6
|
+
Binnacle.configure do |config|
|
7
|
+
config.endpoint = 'localhost'
|
8
|
+
config.api_key = 'vceth4xcwqfoowpz2esi'
|
9
|
+
config.api_secret = '1grttyb8ozbe9axt88ji'
|
10
|
+
config.logging_channel = 'icoc0tnol3obe8pas207'
|
11
|
+
config.encrypted = false
|
12
|
+
config.asynch_logging = false
|
13
|
+
end
|
14
|
+
end
|
15
|
+
|
16
|
+
let(:host) { 'localhost' }
|
17
|
+
let(:port) { 9292 }
|
18
|
+
let(:path) { "/index.html" }
|
19
|
+
let(:headers) { { "accept" => "*/*", "foo" => "bar" } }
|
20
|
+
let(:data) { {'foo' => 'bar', 'bar' => 'foo'} }
|
21
|
+
let(:params) { {'foo' => 'bar:form-data', 'bar' => 'foo'} }
|
22
|
+
|
23
|
+
ADAPTERS = [
|
24
|
+
NetHTTPAdapter,
|
25
|
+
OpenUriAdapter,
|
26
|
+
HTTPClientAdapter,
|
27
|
+
HTTPartyAdapter,
|
28
|
+
FaradayAdapter,
|
29
|
+
ExconAdapter,
|
30
|
+
ENV['SERVE_TEST_ASSETS'] == 'true' ? EthonAdapter : nil,
|
31
|
+
TyphoeusAdapter,
|
32
|
+
PatronAdapter,
|
33
|
+
HTTPAdapter
|
34
|
+
].compact
|
35
|
+
|
36
|
+
ADAPTERS.each do |adapter_class|
|
37
|
+
context adapter_class, adapter: adapter_class.to_s do
|
38
|
+
let(:adapter) { adapter_class.new(host, port, path, headers, data, params) }
|
39
|
+
|
40
|
+
connection_test_method = adapter_class.is_libcurl? ? :to_not : :to
|
41
|
+
|
42
|
+
if adapter_class.method_defined? :send_get_request
|
43
|
+
it "should log GET requests", :vcr do
|
44
|
+
res = adapter.send_get_request
|
45
|
+
|
46
|
+
expect(a_request(:get, 'http://localhost:8080/api/endpoints'))
|
47
|
+
expect(a_request(:get, 'http://localhost:9292/index.html'))
|
48
|
+
|
49
|
+
expect(
|
50
|
+
a_request(:post, "http://localhost:8080/api/events/icoc0tnol3obe8pas207").
|
51
|
+
with do |request|
|
52
|
+
body_as_json = JSON.parse(request.body)
|
53
|
+
body_as_json["channelId"] == "icoc0tnol3obe8pas207" &&
|
54
|
+
body_as_json["sessionId"] == "" &&
|
55
|
+
body_as_json["clientId"] == "" &&
|
56
|
+
body_as_json["eventName"] == "GET http://localhost:9292/index.html" &&
|
57
|
+
body_as_json["logLevel"] == "log" &&
|
58
|
+
body_as_json["tags"] == [] &&
|
59
|
+
body_as_json["json"]["url"] == "http://localhost:9292/index.html" &&
|
60
|
+
body_as_json["json"]["method"] == "GET" &&
|
61
|
+
body_as_json["json"]["host"] == "localhost" &&
|
62
|
+
body_as_json["json"]["port"] == 9292 &&
|
63
|
+
body_as_json["json"]["path"] == "/index.html" &&
|
64
|
+
body_as_json["json"]["query"] == "foo=bar&bar=foo" &&
|
65
|
+
body_as_json["json"]["format"] == "text/html" &&
|
66
|
+
body_as_json["json"]["status"] == "200" &&
|
67
|
+
body_as_json["json"]["duration"] > 0.0 &&
|
68
|
+
body_as_json["json"]["body"] == "<html>\n <head>\n <title>Test Page</title>\n </head>\n <body>\n <h1>This is the test page.</h1>\n </body>\n</html>" &&
|
69
|
+
body_as_json["json"]["data"] == ""
|
70
|
+
body_as_json["json"]["message"] =~ /GET http:\/\/localhost:9292\/index.html AS text\/html \(duration:(.*)/
|
71
|
+
end
|
72
|
+
).to(have_been_made.times(1))
|
73
|
+
end
|
74
|
+
end
|
75
|
+
end
|
76
|
+
end
|
77
|
+
end
|
data/spec/logger_spec.rb
ADDED
@@ -0,0 +1,60 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Binnacle::Logging do
|
4
|
+
before { Binnacle.configuration.asynch_logging = false }
|
5
|
+
|
6
|
+
let(:logger) {
|
7
|
+
Binnacle::Logging.build('vceth4xcwqfoowpz2esi', '1grttyb8ozbe9axt88ji', 'localhost', 'icoc0tnol3obe8pas207')
|
8
|
+
}
|
9
|
+
|
10
|
+
describe 'logging' do
|
11
|
+
it 'invokes the events api signal', :vcr do
|
12
|
+
logger.info("This is an info message")
|
13
|
+
|
14
|
+
expect(a_request(:get, 'http://localhost:8080/api/endpoints'))
|
15
|
+
expect(
|
16
|
+
a_request(:post, "http://localhost:8080/api/events/icoc0tnol3obe8pas207").
|
17
|
+
with(body: hash_including({
|
18
|
+
"channelId": "icoc0tnol3obe8pas207",
|
19
|
+
"eventName": "log",
|
20
|
+
"logLevel": "INFO",
|
21
|
+
"json": { "message": "This is an info message" }
|
22
|
+
})
|
23
|
+
)
|
24
|
+
).to(have_been_made.times(1))
|
25
|
+
end
|
26
|
+
|
27
|
+
it 'respects the logger severity', :vcr do
|
28
|
+
logger.debug("This is an debug message")
|
29
|
+
|
30
|
+
expect(a_request(:get, 'http://localhost:8080/api/endpoints'))
|
31
|
+
expect(
|
32
|
+
a_request(:post, "http://localhost:8080/api/events/icoc0tnol3obe8pas207").
|
33
|
+
with(body: hash_including({
|
34
|
+
"channelId": "icoc0tnol3obe8pas207",
|
35
|
+
"eventName": "log",
|
36
|
+
"logLevel": "DEBUG",
|
37
|
+
"json": { "message": "This is an debug message" }
|
38
|
+
})
|
39
|
+
)
|
40
|
+
).to(have_been_made.times(1))
|
41
|
+
end
|
42
|
+
|
43
|
+
it 'allows passing other parameters using a hash', :vcr do
|
44
|
+
logger.info(session_id: '8675309', event_name: 'failed_transfer') { 'transfer failed, bad RTN' }
|
45
|
+
|
46
|
+
expect(a_request(:get, 'http://localhost:8080/api/endpoints'))
|
47
|
+
expect(
|
48
|
+
a_request(:post, "http://localhost:8080/api/events/icoc0tnol3obe8pas207").
|
49
|
+
with(body: hash_including({
|
50
|
+
"channelId": "icoc0tnol3obe8pas207",
|
51
|
+
"sessionId": "8675309",
|
52
|
+
"eventName": "failed_transfer",
|
53
|
+
"logLevel": "INFO",
|
54
|
+
"json": { "message": "transfer failed, bad RTN" }
|
55
|
+
})
|
56
|
+
)
|
57
|
+
).to(have_been_made.times(1))
|
58
|
+
end
|
59
|
+
end
|
60
|
+
end
|
data/spec/spec_helper.rb
ADDED
@@ -0,0 +1,117 @@
|
|
1
|
+
ENV['BINNACLE_RB_ENVIRONMENT'] ||= 'test'
|
2
|
+
require 'simplecov'
|
3
|
+
SimpleCov.start
|
4
|
+
|
5
|
+
require 'webmock/rspec'
|
6
|
+
require 'httpclient'
|
7
|
+
require 'excon'
|
8
|
+
require 'typhoeus'
|
9
|
+
require 'ethon'
|
10
|
+
require 'patron'
|
11
|
+
require 'http'
|
12
|
+
require 'vcr'
|
13
|
+
require 'binnacle'
|
14
|
+
require 'rspec/collection_matchers'
|
15
|
+
require 'rspec/wait'
|
16
|
+
require 'rack'
|
17
|
+
require 'logger'
|
18
|
+
|
19
|
+
require 'adapters/http_base_adapter'
|
20
|
+
Dir["#{File.dirname(__FILE__)}/adapters/*.rb"].each { |f| require f }
|
21
|
+
Dir["./spec/support/**/*.rb"].each { |f| require f }
|
22
|
+
|
23
|
+
# Start a local rack server to serve up test pages.
|
24
|
+
if ENV['SERVE_TEST_ASSETS'] == 'true'
|
25
|
+
@server_thread = Thread.new do
|
26
|
+
Rack::Handler::Thin.run HttpLogger::Test::Server.new, :Port => 9292
|
27
|
+
end
|
28
|
+
sleep(3) # wait a moment for the server to be booted
|
29
|
+
end
|
30
|
+
|
31
|
+
VCR.configure do |c|
|
32
|
+
c.cassette_library_dir = 'spec/vcr'
|
33
|
+
c.hook_into :webmock
|
34
|
+
c.ignore_localhost = false
|
35
|
+
c.ignore_hosts 'codeclimate.com'
|
36
|
+
c.allow_http_connections_when_no_cassette = false
|
37
|
+
end
|
38
|
+
|
39
|
+
RSpec.configure do |config|
|
40
|
+
config.around(:each, :vcr) do |example|
|
41
|
+
name = example.metadata[:full_description].gsub(/\A(\S*)([\.])/, '\1 ').split(/\s+/, 2).join("/").underscore.gsub(/[^\w\/]+/, "_")
|
42
|
+
options = example.metadata.slice(:record, :match_requests_on).except(:example_group)
|
43
|
+
VCR.use_cassette(name, options) { example.call }
|
44
|
+
end
|
45
|
+
|
46
|
+
config.expect_with :rspec do |expectations|
|
47
|
+
expectations.include_chain_clauses_in_custom_matcher_descriptions = true
|
48
|
+
end
|
49
|
+
|
50
|
+
config.mock_with :rspec do |mocks|
|
51
|
+
mocks.verify_partial_doubles = true
|
52
|
+
end
|
53
|
+
end
|
54
|
+
|
55
|
+
# Some Monkey Patching since we're not in Rails
|
56
|
+
|
57
|
+
class String
|
58
|
+
def underscore
|
59
|
+
return self.downcase if self =~ /^[A-Z]+$/
|
60
|
+
self.gsub(/([A-Z]+)(?=[A-Z][a-z]?)|\B[A-Z]/, '_\&') =~ /_*(.*)/
|
61
|
+
return $+.downcase
|
62
|
+
end
|
63
|
+
end
|
64
|
+
|
65
|
+
class Hash
|
66
|
+
def except(*keys)
|
67
|
+
dup.except!(*keys)
|
68
|
+
end
|
69
|
+
|
70
|
+
# Replaces the hash without the given keys.
|
71
|
+
def except!(*keys)
|
72
|
+
keys.each { |key| delete(key) }
|
73
|
+
self
|
74
|
+
end
|
75
|
+
|
76
|
+
def slice(*keys)
|
77
|
+
keys.map! { |key| convert_key(key) } if respond_to?(:convert_key, true)
|
78
|
+
keys.each_with_object(self.class.new) { |k, hash| hash[k] = self[k] if has_key?(k) }
|
79
|
+
end
|
80
|
+
end
|
81
|
+
|
82
|
+
|
83
|
+
|
84
|
+
class Logger
|
85
|
+
def pause
|
86
|
+
@_logdev, @logdev = @logdev, nil
|
87
|
+
end
|
88
|
+
|
89
|
+
def continue
|
90
|
+
@logdev = @_logdev
|
91
|
+
end
|
92
|
+
end
|
93
|
+
|
94
|
+
class TestLogger < Logger
|
95
|
+
def initialize
|
96
|
+
@strio = StringIO.new
|
97
|
+
super(@strio)
|
98
|
+
end
|
99
|
+
|
100
|
+
def messages
|
101
|
+
@strio.string
|
102
|
+
end
|
103
|
+
end
|
104
|
+
|
105
|
+
def reset_env
|
106
|
+
[ 'BINNACLE_ENDPOINT',
|
107
|
+
'BINNACLE_PORT',
|
108
|
+
'BINNACLE_APP_LOG_CHANNEL',
|
109
|
+
'BINNACLE_APP_ERR_CHANNEL',
|
110
|
+
'BINNACLE_API_KEY',
|
111
|
+
'BINNACLE_API_SECRET',
|
112
|
+
'BINNACLE_RAILS_LOG',
|
113
|
+
'BINNACLE_REPORT_EXCEPTIONS',
|
114
|
+
'BINNACLE_IGNORED_EXCEPTIONS',
|
115
|
+
'BINNACLE_RAILS_LOG_ASYNCH',
|
116
|
+
'BINNACLE_ENCRYPTED' ].each { |key| ENV[key] = nil }
|
117
|
+
end
|