Skip to content

Latest commit

 

History

History
167 lines (108 loc) · 5.99 KB

File metadata and controls

167 lines (108 loc) · 5.99 KB

Build Status

ember-cli-deploy-honeybadger-sourcemap

An ember-cli-deploy plugin that uploads your source maps to Honeybadger.

This plugin uploads generated source maps to the Honeybadger API. During upload of the source maps to Honeybadger you must provide source_code string that will match the error raised in Honeybadger with the same value. To do this, Honeybadger snippet is injected into index.html after the revision data is generated with revision key as source_code. After all, the plugin uploads the source maps with the same revision key as injected into index.html.

You can take a look here how Honeybadger defines its flow with source maps

This library was adapted from @bgentry's ember-cli-deploy-rollbar-sourcemap

What is an ember-cli-deploy plugin?

A plugin is an addon that can be executed as a part of the ember-cli-deploy pipeline. A plugin will implement one or more of the ember-cli-deploy's pipeline hooks.

For more information on what plugins are and how they work, please refer to the Plugin Documentation.

Quick Start

To get up and running quickly, do the following:

$ ember install ember-cli-deploy-honeybadger-sourcemap
  • Enable sourcemaps for all environments in ember-cli-build.js:
/* jshint node:true */
/* global require, module */
var EmberApp = require('ember-cli/lib/broccoli/ember-app');

module.exports = function(defaults) {
  var app = new EmberApp(defaults, {
    // …
    sourcemaps: {
      enabled: true, // This allows sourcemaps to be generated in all environments
      extensions: ['js']
    }
  });
  • Run the pipeline
$ ember deploy

Installation

Run the following command in your terminal:

ember install ember-cli-deploy-honeybadger-sourcemap

ember-cli-deploy Hooks Implemented

For detailed information on what plugin hooks are and how they work, please refer to the Plugin Documentation.

  • willUpload (inject Honeybadger snippet)
  • upload (upload source maps)
  • didDeploy (send information about deploy to Honeybadger)

Configuration Options

For detailed information on how configuration of plugins works, please refer to the Plugin Documentation.

Configure this addon in your deploy.js ENV:

'honeybadger-sourcemap': {
  apiKey: process.env.Honeybadger_SERVER_ACCESS_TOKEN,
},

apiKey (required)

Honeybadger server access token to allow uploading source maps to your account.

publicUrl (required)

The fully qualified domain name for your application e.g., https://app.fancy-app.com

enabled

Defines internal enabled Honeybadger config.

Default: true Alternatives: false

environment

Defines internal environment Honeybadger config.

Default: environment setting from ember-cli-deploy-build || production Alternatives: any other env

additionalFiles

Defines additional sourcemap files to be uploaded to Honeybadger. Use this if you build .js files other than projectName.js and vendor.js.

Set to an array of filenames excluding their extentions. For example in an app that builds exta-functionality.js and additional-library.js set to ['exta-functionality', 'additional-library'].

Default: [] Alternatives: an array of filenames without extensions

Prerequisites

The following properties are expected to be present on the deployment context object:

Plugins known to work well with this one

Known issues

  • You must enable source maps in your ember-cli-build.js file, even in production env. However, you don't need to upload them anywhere (they won't be available online) - they are only needed during upload phase in deploy pipeline.
  • If you are using gzipping, make sure that you are not gzipping source maps - Honeybadger will not accept gzipped files.
  • If you bump in any other issue in your deployment flow, give me a sign and I'll try to make this addon more flexible for you.

Development

Installation

  • git clone https://github.com/wmoxam/ember-cli-deploy-honeybadger-sourcemap
  • cd my-addon
  • npm install

Linting

  • npm run lint:js
  • npm run lint:js -- --fix

Running tests

  • ember test – Runs the test suite on the current Ember version
  • ember test --server – Runs the test suite in "watch mode"
  • ember try:each – Runs the test suite against multiple Ember versions

Running the dummy application

For more information on using ember-cli, visit https://ember-cli.com/.

License

This project is licensed under the MIT License.