2020-07-17 15:17:18 +00:00
|
|
|
/*
|
|
|
|
* decaffeinate suggestions:
|
|
|
|
* DS102: Remove unnecessary code created because of implicit returns
|
|
|
|
* Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md
|
|
|
|
*/
|
2020-09-11 18:18:22 +00:00
|
|
|
const chai = require('chai')
|
|
|
|
const { expect } = chai
|
|
|
|
const path = require('path')
|
|
|
|
const modulePath = path.join(__dirname, '../../../event_loop.js')
|
|
|
|
const SandboxedModule = require('sandboxed-module')
|
|
|
|
const sinon = require('sinon')
|
2020-07-17 15:17:18 +00:00
|
|
|
|
|
|
|
describe('event_loop', function() {
|
2020-09-11 18:18:22 +00:00
|
|
|
before(function() {
|
|
|
|
this.metrics = {
|
|
|
|
timing: sinon.stub(),
|
|
|
|
registerDestructor: sinon.stub()
|
|
|
|
}
|
|
|
|
this.logger = {
|
|
|
|
warn: sinon.stub()
|
|
|
|
}
|
|
|
|
return (this.event_loop = SandboxedModule.require(modulePath, {
|
|
|
|
requires: {
|
|
|
|
'./index': this.metrics
|
|
|
|
}
|
|
|
|
}))
|
|
|
|
})
|
2020-07-17 15:17:18 +00:00
|
|
|
|
2020-09-11 18:18:22 +00:00
|
|
|
describe('with a logger provided', function() {
|
|
|
|
before(function() {
|
|
|
|
return this.event_loop.monitor(this.logger)
|
|
|
|
})
|
2020-07-17 15:17:18 +00:00
|
|
|
|
2020-09-11 18:18:22 +00:00
|
|
|
return it('should register a destructor with metrics', function() {
|
|
|
|
return expect(this.metrics.registerDestructor.called).to.equal(true)
|
|
|
|
})
|
|
|
|
})
|
2020-07-17 15:17:18 +00:00
|
|
|
|
2020-09-11 18:18:22 +00:00
|
|
|
return describe('without a logger provided', function() {
|
|
|
|
return it('should throw an exception', function() {
|
|
|
|
return expect(this.event_loop.monitor).to.throw('logger is undefined')
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|