overleaf/libraries/metrics/test/unit/js/event_loop.js

45 lines
1.2 KiB
JavaScript
Raw Normal View History

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')
})
})
})