mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-29 16:43:36 -05:00
1be43911b4
Set Prettier's "trailingComma" setting to "es5" GitOrigin-RevId: 9f14150511929a855b27467ad17be6ab262fe5d5
129 lines
3.2 KiB
JavaScript
129 lines
3.2 KiB
JavaScript
const Path = require('path')
|
|
const chai = require('chai')
|
|
const sinon = require('sinon')
|
|
|
|
/*
|
|
* Chai configuration
|
|
*/
|
|
|
|
// add chai.should()
|
|
chai.should()
|
|
|
|
// Load sinon-chai assertions so expect(stubFn).to.have.been.calledWith('abc')
|
|
// has a nicer failure messages
|
|
chai.use(require('sinon-chai'))
|
|
|
|
// Load promise support for chai
|
|
chai.use(require('chai-as-promised'))
|
|
|
|
// Do not truncate assertion errors
|
|
chai.config.truncateThreshold = 0
|
|
|
|
// add support for mongoose in sinon
|
|
require('sinon-mongoose')
|
|
|
|
/*
|
|
* Global stubs
|
|
*/
|
|
const globalStubsSandbox = sinon.createSandbox()
|
|
const globalStubs = {
|
|
logger: {
|
|
debug: globalStubsSandbox.stub(),
|
|
info: globalStubsSandbox.stub(),
|
|
log: globalStubsSandbox.stub(),
|
|
warn: globalStubsSandbox.stub(),
|
|
err: globalStubsSandbox.stub(),
|
|
error: globalStubsSandbox.stub(),
|
|
fatal: globalStubsSandbox.stub(),
|
|
},
|
|
}
|
|
|
|
/*
|
|
* Sandboxed module configuration
|
|
*/
|
|
|
|
const SandboxedModule = require('sandboxed-module')
|
|
SandboxedModule.configure({
|
|
requires: getSandboxedModuleRequires(),
|
|
globals: { Buffer, Promise, console, process },
|
|
sourceTransformers: {
|
|
coffee(source) {
|
|
if (this.filename.endsWith('.coffee')) {
|
|
// Coffeescript mucks with Error.prepareStackTrace, which, in turn,
|
|
// conflicts with OError. This is a hacky way to prevent Coffeescript
|
|
// from interfering.
|
|
//
|
|
// See https://github.com/jashkenas/coffeescript/blob/07f644c39223e016aceedd2cd71b5941579b5659/src/coffeescript.coffee#L368
|
|
const originalPrepareStackTrace = Error.prepareStackTrace
|
|
const compiled = require('coffeescript').compile(source)
|
|
Error.prepareStackTrace = originalPrepareStackTrace
|
|
return compiled
|
|
}
|
|
return source
|
|
},
|
|
},
|
|
})
|
|
|
|
function getSandboxedModuleRequires() {
|
|
const requires = {
|
|
'logger-sharelatex': globalStubs.logger,
|
|
}
|
|
|
|
const internalModules = [
|
|
'../../app/src/util/promises',
|
|
'../../app/src/Features/Errors/Errors',
|
|
'../../app/src/Features/Helpers/Mongo',
|
|
]
|
|
const externalLibs = [
|
|
'async',
|
|
'json2csv',
|
|
'lodash',
|
|
'marked',
|
|
'moment',
|
|
'@overleaf/o-error',
|
|
'sanitize-html',
|
|
'sshpk',
|
|
'underscore',
|
|
'xml2js',
|
|
]
|
|
for (const modulePath of internalModules) {
|
|
requires[Path.resolve(__dirname, modulePath)] = require(modulePath)
|
|
}
|
|
for (const lib of externalLibs) {
|
|
requires[lib] = require(lib)
|
|
}
|
|
return requires
|
|
}
|
|
|
|
/*
|
|
* Mocha hooks
|
|
*/
|
|
|
|
// sandboxed-module somehow registers every fake module it creates in this
|
|
// module's children array, which uses quite a big amount of memory. We'll take
|
|
// a copy of the module children array and restore it after each test so that
|
|
// the garbage collector has a chance to reclaim the fake modules.
|
|
let initialModuleChildren
|
|
|
|
exports.mochaHooks = {
|
|
beforeAll() {
|
|
// Record initial module children
|
|
initialModuleChildren = module.children.slice()
|
|
},
|
|
|
|
beforeEach() {
|
|
// Install logger stub
|
|
this.logger = globalStubs.logger
|
|
},
|
|
|
|
afterEach() {
|
|
// Delete leaking sandboxed modules
|
|
module.children = initialModuleChildren.slice()
|
|
|
|
// Reset global stubs
|
|
globalStubsSandbox.reset()
|
|
|
|
// Restore other stubs
|
|
sinon.restore()
|
|
},
|
|
}
|