Skip to content

Universal JavaScript library for reporting errors to Honeybadger.io ⚡

License

Notifications You must be signed in to change notification settings

apepper/honeybadger-js

 
 

Repository files navigation

Honeybadger for JavaScript

Node CI npm version deploy

Universal JavaScript library for integrating apps with the ⚡ Honeybadger Error Notifier.

Note: The NPM package has been moved to @honeybadger-io/js starting with v3.0.0. See the v2-stable branch for the honeybadger-js 2.x package. Upgrade instructions

Documentation and Support

For comprehensive documentation and support, check out our documentation site.

Changelog

See https://github.com/honeybadger-io/honeybadger-js/blob/master/CHANGELOG.md

Contributing

  1. Fork it.
  2. Create a topic branch git checkout -b my_branch
  3. Commit your changes git commit -am "Boom"
  4. Push to your branch git push origin my_branch
  5. Send a pull request

Development

  1. Run npm install.
  2. To run the test suite by itself, use npm test.
  3. To run the tests across all supported platforms, set up a BrowserStack account and use BROWSERSTACK_USERNAME=your_username BROWSERSTACK_ACCESS_KEY=your-access-key npm run test:integration.

Releasing

Releasing is done with two commands: npm version and npm publish. Both commands should be used with care. The npm publish command publishes to NPM and to our js.honeybadger.io CDN (hosted on AWS via S3/CloudFront).

For the CDN release, make sure you have the following environment variable available in your shell:

export HONEYBADGER_JS_S3_BUCKET=honeybadger-js
export HONEYBADGER_DISTRIBUTION_ID=cloudfront-id

AWS credentials are read from ~/.aws/credentials, using the default profile.

To perform a full release:

  1. With a clean working tree, use npm version [new version] to bump the version, commit the changes, tag the release, and push to GitHub. See npm help version for documentation.

  2. To publish the release, use npm publish. See npm help publish for documentation.

If the CDN release fails for some reason (bad AWS credentials, for instance), re-run the release manually with npm run release-cdn.

Release Automation

We use Ship.js to automate releasing. Our custom Ship.js config determines the next release version based on the unreleased section of our changelog (Keep a Changelog format).

Ship.js creates a PR once per week when unreleased changes are present. You can also trigger a release PR by saying "@shipjs prepare" in any issue or pull request comment on GitHub.

Available Commands

  • npm run release - Calculates the next version and creates a PR via shipjs prepare. This can run locally or in CI
  • npx shipjs trigger - Publish to NPM (usually happens in CI, but can also run locally)

GitHub Workflows

Related Links

License

The Honeybadger gem is MIT licensed. See the MIT-LICENSE file in this repository for details.



We use BrowserStack to run our automated integration tests on multiple platforms in CI.

About

Universal JavaScript library for reporting errors to Honeybadger.io ⚡

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • TypeScript 83.4%
  • JavaScript 15.0%
  • Other 1.6%