BigW Consortium Gitlab

test_bundle.js 4.51 KB
Newer Older
1
/* eslint-disable jasmine/no-global-setup */
2 3 4 5
import $ from 'jquery';
import _ from 'underscore';
import 'jasmine-jquery';
import '~/commons';
Fatih Acet committed
6

7 8 9
import Vue from 'vue';
import VueResource from 'vue-resource';

10 11 12 13
const isHeadlessChrome = /\bHeadlessChrome\//.test(navigator.userAgent);
Vue.config.devtools = !isHeadlessChrome;
Vue.config.productionTip = false;

14 15
Vue.use(VueResource);

16
// enable test fixtures
17 18
jasmine.getFixtures().fixturesPath = '/base/spec/javascripts/fixtures';
jasmine.getJSONFixtures().fixturesPath = '/base/spec/javascripts/fixtures';
19

20 21 22
// globalize common libraries
window.$ = window.jQuery = $;
window._ = _;
23 24

// stub expected globals
25
window.gl = window.gl || {};
26 27
window.gl.TEST_HOST = 'http://test.host';
window.gon = window.gon || {};
28

29 30 31 32 33 34 35 36 37 38 39 40 41
let hasUnhandledPromiseRejections = false;

window.addEventListener('unhandledrejection', (event) => {
  hasUnhandledPromiseRejections = true;
  console.error('Unhandled promise rejection:');
  console.error(event.reason.stack || event.reason);
});

const checkUnhandledPromiseRejections = (done) => {
  expect(hasUnhandledPromiseRejections).toBe(false);
  done();
};

42 43 44 45 46 47
// HACK: Chrome 59 disconnects if there are too many synchronous tests in a row
// because it appears to lock up the thread that communicates to Karma's socket
// This async beforeEach gets called on every spec and releases the JS thread long
// enough for the socket to continue to communicate.
// The downside is that it creates a minor performance penalty in the time it takes
// to run our unit tests.
48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66
beforeEach(done => done());

beforeAll(() => {
  const origError = console.error;
  spyOn(console, 'error').and.callFake((message) => {
    if (/^\[Vue warn\]/.test(message)) {
      fail(message);
    } else {
      origError(message);
    }
  });
});

const builtinVueHttpInterceptors = Vue.http.interceptors.slice();

beforeEach(() => {
  // restore interceptors so we have no remaining ones from previous tests
  Vue.http.interceptors = builtinVueHttpInterceptors.slice();
});
67

68 69 70 71 72 73
// render all of our tests
const testsContext = require.context('.', true, /_spec$/);
testsContext.keys().forEach(function (path) {
  try {
    testsContext(path);
  } catch (err) {
74 75 76 77 78 79
    console.error('[ERROR] Unable to load spec: ', path);
    describe('Test bundle', function () {
      it(`includes '${path}'`, function () {
        expect(err).toBeNull();
      });
    });
80 81
  }
});
82

83 84 85 86
it('has no unhandled Promise rejections', (done) => {
  setTimeout(checkUnhandledPromiseRejections(done), 1000);
});

87 88 89 90 91
// if we're generating coverage reports, make sure to include all files so
// that we can catch files with 0% coverage
// see: https://github.com/deepsweet/istanbul-instrumenter-loader/issues/15
if (process.env.BABEL_ENV === 'coverage') {
  // exempt these files from the coverage report
92
  const troubleMakers = [
93 94
    './blob_edit/blob_bundle.js',
    './boards/boards_bundle.js',
95
    './cycle_analytics/cycle_analytics_bundle.js',
96 97 98
    './cycle_analytics/components/stage_plan_component.js',
    './cycle_analytics/components/stage_staging_component.js',
    './cycle_analytics/components/stage_test_component.js',
99 100
    './commit/pipelines/pipelines_bundle.js',
    './diff_notes/diff_notes_bundle.js',
101 102
    './diff_notes/components/jump_to_discussion.js',
    './diff_notes/components/resolve_count.js',
103 104 105 106 107 108 109
    './dispatcher.js',
    './environments/environments_bundle.js',
    './filtered_search/filtered_search_bundle.js',
    './graphs/graphs_bundle.js',
    './issuable/time_tracking/time_tracking_bundle.js',
    './main.js',
    './merge_conflicts/merge_conflicts_bundle.js',
110 111
    './merge_conflicts/components/inline_conflict_lines.js',
    './merge_conflicts/components/parallel_conflict_lines.js',
112 113
    './monitoring/monitoring_bundle.js',
    './network/network_bundle.js',
114
    './network/branch_graph.js',
115 116 117 118 119
    './profile/profile_bundle.js',
    './protected_branches/protected_branches_bundle.js',
    './snippet/snippet_bundle.js',
    './terminal/terminal_bundle.js',
    './users/users_bundle.js',
Regis Boudinot committed
120
    './issue_show/index.js',
121 122
  ];

123 124 125 126 127 128 129
  describe('Uncovered files', function () {
    const sourceFiles = require.context('~', true, /\.js$/);
    sourceFiles.keys().forEach(function (path) {
      // ignore if there is a matching spec file
      if (testsContext.keys().indexOf(`${path.replace(/\.js$/, '')}_spec`) > -1) {
        return;
      }
130

131 132 133 134 135 136 137
      it(`includes '${path}'`, function () {
        try {
          sourceFiles(path);
        } catch (err) {
          if (troubleMakers.indexOf(path) === -1) {
            expect(err).toBeNull();
          }
138
        }
139
      });
140 141
    });
  });
142
}