From 540b2249e2bae5015e4beb34207bd042e147c80f Mon Sep 17 00:00:00 2001 From: Fabian Date: Wed, 27 Dec 2017 14:59:10 +0100 Subject: [PATCH 1/3] fixing bad error catching --- test/unit/helpers/console_error_throw.js | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/test/unit/helpers/console_error_throw.js b/test/unit/helpers/console_error_throw.js index 73816b61db..463d8a7f41 100644 --- a/test/unit/helpers/console_error_throw.js +++ b/test/unit/helpers/console_error_throw.js @@ -1,5 +1,9 @@ global.console.error = (...args) => { - throw Error('Console Error: ' + args.join(' ')) + // throwing an error from console.error could be catched by Vue + // by throwing it inside an error it will be catched by our unhandledRejection listener + return new Promise(() => { + throw new Error('Console Error: ' + args.join(' ')) + }) } if (!process.env.LISTENING_TO_UNHANDLED_REJECTION) { From c773e7a06293128f05a5823096de51d345920d4c Mon Sep 17 00:00:00 2001 From: Fabian Date: Wed, 27 Dec 2017 14:59:20 +0100 Subject: [PATCH 2/3] fix lidelegate error --- .../components/staking/LiDelegate.vue | 2 +- test/unit/specs/LiDelegate.spec.js | 36 +++++-------------- .../__snapshots__/LiDelegate.spec.js.snap | 7 ++-- 3 files changed, 14 insertions(+), 31 deletions(-) diff --git a/app/src/renderer/components/staking/LiDelegate.vue b/app/src/renderer/components/staking/LiDelegate.vue index f66ce3ec1d..f10e6a61fc 100644 --- a/app/src/renderer/components/staking/LiDelegate.vue +++ b/app/src/renderer/components/staking/LiDelegate.vue @@ -5,7 +5,7 @@ transition(name='ts-li-delegate'): .li-delegate(:class='styles'): .li-delegate__ span i.fa.fa-check-square-o(v-if='inCart' @click='rm(delegate)') i.fa.fa-square-o(v-else @click='add(delegate)') - router-link(v-if="config.devMode" :to="{ name: 'delegate', params: { delegate: delegate.id }}") {{ delegate.id }} + router-link(v-if="config.devMode && delegate.id" :to="{ name: 'delegate', params: { delegate: delegate.id }}") {{ delegate.id }} a(v-else) {{ delegate.id }} .li-delegate__value span {{ delegate.country ? delegate.country : 'n/a' }} diff --git a/test/unit/specs/LiDelegate.spec.js b/test/unit/specs/LiDelegate.spec.js index 3a22ae96ae..4e3863ba8f 100644 --- a/test/unit/specs/LiDelegate.spec.js +++ b/test/unit/specs/LiDelegate.spec.js @@ -1,30 +1,18 @@ -import Vuex from 'vuex' -import { mount, createLocalVue } from 'vue-test-utils' +import setup from '../helpers/vuex-setup' import LiDelegate from 'renderer/components/staking/LiDelegate' -const shoppingCart = require('renderer/vuex/modules/shoppingCart').default({}) -const delegates = require('renderer/vuex/modules/delegates').default({}) - -const localVue = createLocalVue() -localVue.use(Vuex) - describe('LiDelegate', () => { let wrapper, store, delegate + let instance = setup() beforeEach(() => { - store = new Vuex.Store({ - getters: { - shoppingCart: () => shoppingCart.state.delegates, - delegates: () => delegates.state, - config: () => ({ - devMode: true - }) - }, - modules: { - shoppingCart, - delegates + let test = instance.mount(LiDelegate, { + propsData: { + delegate: {} } }) + wrapper = test.wrapper + store = test.store store.commit('addDelegate', { pub_key: { @@ -55,15 +43,9 @@ describe('LiDelegate', () => { delegate = store.state.delegates[0] - wrapper = mount(LiDelegate, { - localVue, - store, - propsData: { - delegate - } + wrapper.setData({ + delegate }) - - jest.spyOn(store, 'commit') }) it('has the expected html structure', () => { diff --git a/test/unit/specs/__snapshots__/LiDelegate.spec.js.snap b/test/unit/specs/__snapshots__/LiDelegate.spec.js.snap index 79e9229aab..3f3ad34a3f 100644 --- a/test/unit/specs/__snapshots__/LiDelegate.spec.js.snap +++ b/test/unit/specs/__snapshots__/LiDelegate.spec.js.snap @@ -18,11 +18,12 @@ exports[`LiDelegate has the expected html structure 1`] = ` - pubkeyX - +
Date: Wed, 27 Dec 2017 15:15:40 +0100 Subject: [PATCH 3/3] removed console.error overwrite in tests --- test/unit/helpers/console_error_throw.js | 8 -------- 1 file changed, 8 deletions(-) diff --git a/test/unit/helpers/console_error_throw.js b/test/unit/helpers/console_error_throw.js index 463d8a7f41..f1a8ccdb10 100644 --- a/test/unit/helpers/console_error_throw.js +++ b/test/unit/helpers/console_error_throw.js @@ -1,11 +1,3 @@ -global.console.error = (...args) => { - // throwing an error from console.error could be catched by Vue - // by throwing it inside an error it will be catched by our unhandledRejection listener - return new Promise(() => { - throw new Error('Console Error: ' + args.join(' ')) - }) -} - if (!process.env.LISTENING_TO_UNHANDLED_REJECTION) { process.on('unhandledRejection', reason => { throw reason