Browse Source

Merge pull request #736 from mrfelton/fix/show-connection-errors

fix(grpc): ensure connection errors show onscreen
renovate/lint-staged-8.x
JimmyMow 6 years ago
committed by GitHub
parent
commit
994d3617f7
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 1
      app/lib/zap/controller.js
  2. 5
      test/unit/__mocks__/electron.js
  3. 54
      test/unit/zap/controller.spec.js

1
app/lib/zap/controller.js

@ -284,6 +284,7 @@ class ZapController {
this.sendMessage('lightningGrpcActive')
} catch (err) {
mainLog.warn('Unable to connect to Lighitnng gRPC interface: %o', err)
throw err
}
}

5
test/unit/__mocks__/electron.js

@ -9,5 +9,8 @@ module.exports = {
},
remote: jest.fn(),
dialog: jest.fn(),
BrowserWindow: jest.fn()
BrowserWindow: jest.fn(),
ipcMain: {
on: jest.fn()
}
}

54
test/unit/zap/controller.spec.js

@ -0,0 +1,54 @@
import ZapController from 'lib/zap/controller'
import LndConfig from 'lib/lnd/config'
jest.mock('lib/lnd/lightning')
const Lightning = require('lib/lnd/lightning')
describe('ZapController', function() {
describe('Constructor', () => {
beforeAll(() => {
this.controller = new ZapController()
})
describe('initial values', () => {
it('should set the "lndConfig" property to a new LndConfig instance', () => {
expect(this.controller.lndConfig).toBeInstanceOf(LndConfig)
})
it('should set the "splashScreenTime" property to 500', () => {
expect(this.controller.splashScreenTime).toEqual(500)
})
it('should set the "mainWindow" property to undefined', () => {
expect(this.controller.mainWindow).toBeUndefined()
})
})
})
describe('.startLightningWallet', () => {
describe('successful connection', () => {
beforeEach(() => {
Lightning.mockImplementation(() => ({
subscribe: jest.fn(),
connect: jest.fn().mockResolvedValue()
}))
this.controller = new ZapController()
})
it('should resolve with undefined', async () => {
await expect(this.controller.startLightningWallet()).resolves.toBeUndefined()
expect(this.controller.lightning.subscribe).toHaveBeenCalled()
})
})
describe('unsuccessful connection', () => {
beforeEach(() => {
Lightning.mockImplementation(() => ({
subscribe: jest.fn(),
connect: jest.fn().mockRejectedValue(new Error('Async error'))
}))
this.controller = new ZapController()
})
it('should reject an error', async () => {
await expect(this.controller.startLightningWallet()).rejects.toThrow('Async error')
expect(this.controller.lightning.subscribe).not.toHaveBeenCalled()
})
})
})
})
Loading…
Cancel
Save