From e0230353933cdaa22aa649cd0843eb8e0b62c2d9 Mon Sep 17 00:00:00 2001 From: Shelley Vohr Date: Sun, 17 Jun 2018 15:35:24 -0700 Subject: [PATCH 1/3] spec: convert debugger spec to expect --- spec/api-debugger-spec.js | 67 +++++++++++++++++++++++---------------- 1 file changed, 39 insertions(+), 28 deletions(-) diff --git a/spec/api-debugger-spec.js b/spec/api-debugger-spec.js index 1d98e799394..ba98f5df036 100644 --- a/spec/api-debugger-spec.js +++ b/spec/api-debugger-spec.js @@ -1,9 +1,14 @@ +const chai = require('chai') const assert = require('assert') +const dirtyChai = require('dirty-chai') const http = require('http') const path = require('path') const {closeWindow} = require('./window-helpers') const BrowserWindow = require('electron').remote.BrowserWindow +const {expect} = chai +chai.use(dirtyChai) + describe('debugger module', () => { const fixtures = path.resolve(__dirname, 'fixtures') let w = null @@ -19,35 +24,35 @@ describe('debugger module', () => { afterEach(() => closeWindow(w).then(() => { w = null })) describe('debugger.attach', () => { - it('fails when devtools is already open', (done) => { + it('fails when devtools is already open', done => { w.webContents.on('did-finish-load', () => { w.webContents.openDevTools() try { w.webContents.debugger.attach() } catch (err) { - assert(w.webContents.debugger.isAttached()) + expect(w.webContents.debugger.isAttached()).to.be.true() done() } }) w.webContents.loadURL(`file://${path.join(fixtures, 'pages', 'a.html')}`) }) - it('fails when protocol version is not supported', (done) => { + it('fails when protocol version is not supported', done => { try { w.webContents.debugger.attach('2.0') } catch (err) { - assert(!w.webContents.debugger.isAttached()) + expect(w.webContents.debugger.isAttached()).to.be.false() done() } }) - it('attaches when no protocol version is specified', (done) => { + it('attaches when no protocol version is specified', done => { try { w.webContents.debugger.attach() } catch (err) { done(`unexpected error : ${err}`) } - assert(w.webContents.debugger.isAttached()) + expect(w.webContents.debugger.isAttached()).to.be.true() done() }) }) @@ -55,10 +60,11 @@ describe('debugger module', () => { describe('debugger.detach', () => { it('fires detach event', (done) => { w.webContents.debugger.on('detach', (e, reason) => { - assert.equal(reason, 'target closed') - assert(!w.webContents.debugger.isAttached()) + expect(reason).to.equal('target closed') + expect(w.webContents.debugger.isAttached()).to.be.false() done() }) + try { w.webContents.debugger.attach() } catch (err) { @@ -78,41 +84,45 @@ describe('debugger module', () => { } }) - it('retuns response', (done) => { + it('returns response', done => { w.webContents.loadURL('about:blank') try { w.webContents.debugger.attach() } catch (err) { - return done('unexpected error : ' + err) + return done(`unexpected error : ${err}`) } - var callback = function (err, res) { - assert(!err.message) - assert(!res.wasThrown) - assert.equal(res.result.value, 6) + + const callback = (err, res) => { + expect(err.message).to.not.exist() + expect(res.wasThrown).to.be.undefined() + expect(res.result.value).to.equal(6) + w.webContents.debugger.detach() done() } - const params = { - 'expression': '4+2' - } + + const params = {'expression': '4+2'} w.webContents.debugger.sendCommand('Runtime.evaluate', params, callback) }) - it('fires message event', (done) => { + it('fires message event', done => { const url = process.platform !== 'win32' ? `file://${path.join(fixtures, 'pages', 'a.html')}` - : 'file:///' + path.join(fixtures, 'pages', 'a.html').replace(/\\/g, '/') + : `file:///${path.join(fixtures, 'pages', 'a.html').replace(/\\/g, '/')}` w.webContents.loadURL(url) + try { w.webContents.debugger.attach() } catch (err) { - done('unexpected error : ' + err) + done(`unexpected error : ${err}`) } + w.webContents.debugger.on('message', (e, method, params) => { if (method === 'Console.messageAdded') { - assert.equal(params.message.level, 'log') - assert.equal(params.message.url, url) - assert.equal(params.message.text, 'a') + expect(params.message.level).to.equal('log') + expect(params.message.url).to.equal(url) + expect(params.message.text).to.equal('a') + w.webContents.debugger.detach() done() } @@ -120,15 +130,16 @@ describe('debugger module', () => { w.webContents.debugger.sendCommand('Console.enable') }) - it('returns error message when command fails', (done) => { + it('returns error message when command fails', done => { w.webContents.loadURL('about:blank') try { w.webContents.debugger.attach() } catch (err) { done(`unexpected error : ${err}`) } - w.webContents.debugger.sendCommand('Test', (err) => { - assert.equal(err.message, "'Test' wasn't found") + + w.webContents.debugger.sendCommand('Test', err => { + expect(err.message).to.equal("'Test' wasn't found") w.webContents.debugger.detach() done() }) @@ -146,7 +157,7 @@ describe('debugger module', () => { w.webContents.debugger.sendCommand('Network.getResponseBody', { requestId: params.requestId }, (_, data) => { - assert.equal(data.body, '\u0024') + expect(data.body).to.equal('\u0024') done() }) } @@ -163,7 +174,7 @@ describe('debugger module', () => { }) }) - it('does not crash for invalid unicode characters in message', (done) => { + it('does not crash for invalid unicode characters in message', done => { try { w.webContents.debugger.attach() } catch (err) { From 79c2d22c2598aa61cee20db34078313a74d12dc1 Mon Sep 17 00:00:00 2001 From: Shelley Vohr Date: Sun, 17 Jun 2018 15:37:16 -0700 Subject: [PATCH 2/3] remove assert require --- spec/api-debugger-spec.js | 1 - 1 file changed, 1 deletion(-) diff --git a/spec/api-debugger-spec.js b/spec/api-debugger-spec.js index ba98f5df036..ac9e1d7e4cf 100644 --- a/spec/api-debugger-spec.js +++ b/spec/api-debugger-spec.js @@ -1,5 +1,4 @@ const chai = require('chai') -const assert = require('assert') const dirtyChai = require('dirty-chai') const http = require('http') const path = require('path') From c65844a7d0aa330b917bdb9700d348a9013d1bd5 Mon Sep 17 00:00:00 2001 From: Shelley Vohr Date: Mon, 18 Jun 2018 08:56:24 -0700 Subject: [PATCH 3/3] address review feedback --- spec/api-debugger-spec.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/spec/api-debugger-spec.js b/spec/api-debugger-spec.js index ac9e1d7e4cf..ef99bce17b7 100644 --- a/spec/api-debugger-spec.js +++ b/spec/api-debugger-spec.js @@ -92,7 +92,7 @@ describe('debugger module', () => { } const callback = (err, res) => { - expect(err.message).to.not.exist() + expect(err.message).to.be.undefined() expect(res.wasThrown).to.be.undefined() expect(res.result.value).to.equal(6)