mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-21 20:47:08 -05:00
[misc] decaffeinate tests: decaffeinate unit tests
This commit is contained in:
parent
7210b3dfed
commit
7b69cc42c9
2 changed files with 134 additions and 75 deletions
|
@ -9,7 +9,7 @@
|
|||
"lint": "eslint --max-warnings 0 .",
|
||||
"format": "prettier-eslint $PWD'/**/*.js' --list-different",
|
||||
"format:fix": "prettier-eslint $PWD'/**/*.js' --write",
|
||||
"test": "mocha --require coffee-script/register test/unit/src/*.coffee"
|
||||
"test": "mocha --recursive test/unit/src/"
|
||||
},
|
||||
"dependencies": {
|
||||
"coffee-script": "1.8.0",
|
||||
|
|
|
@ -1,88 +1,147 @@
|
|||
should = require('chai').should()
|
||||
SandboxedModule = require('sandboxed-module')
|
||||
assert = require('assert')
|
||||
path = require('path')
|
||||
sinon = require('sinon')
|
||||
modulePath = path.join __dirname, "./../../../index.js"
|
||||
expect = require("chai").expect
|
||||
/*
|
||||
* decaffeinate suggestions:
|
||||
* DS102: Remove unnecessary code created because of implicit returns
|
||||
* DS206: Consider reworking classes to avoid initClass
|
||||
* Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md
|
||||
*/
|
||||
const should = require('chai').should()
|
||||
const SandboxedModule = require('sandboxed-module')
|
||||
const assert = require('assert')
|
||||
const path = require('path')
|
||||
const sinon = require('sinon')
|
||||
const modulePath = path.join(__dirname, './../../../index.js')
|
||||
const { expect } = require('chai')
|
||||
|
||||
describe "index", ->
|
||||
describe('index', function () {
|
||||
beforeEach(function () {
|
||||
let Cluster, IoRedis, ioredisConstructor
|
||||
this.settings = {}
|
||||
this.ioredisConstructor = ioredisConstructor = sinon.stub()
|
||||
|
||||
beforeEach ->
|
||||
this.ioredis = IoRedis = (function () {
|
||||
let createIoRedis
|
||||
IoRedis = class IoRedis {
|
||||
static initClass() {
|
||||
this.prototype.on = sinon.stub()
|
||||
createIoRedis = ioredisConstructor
|
||||
}
|
||||
|
||||
@settings = {}
|
||||
@ioredisConstructor = ioredisConstructor = sinon.stub()
|
||||
constructor() {
|
||||
return createIoRedis.apply(this, arguments)
|
||||
}
|
||||
}
|
||||
IoRedis.initClass()
|
||||
return IoRedis
|
||||
})()
|
||||
this.ioredis.Cluster = Cluster = (function () {
|
||||
Cluster = class Cluster {
|
||||
static initClass() {
|
||||
this.prototype.on = sinon.stub()
|
||||
}
|
||||
|
||||
@ioredis = class IoRedis
|
||||
constructor: ioredisConstructor
|
||||
on: sinon.stub()
|
||||
@ioredis.Cluster = class Cluster
|
||||
constructor: (@config, @options) ->
|
||||
on: sinon.stub()
|
||||
@redis = SandboxedModule.require modulePath, requires:
|
||||
"ioredis": @ioredis
|
||||
@auth_pass = "1234 pass"
|
||||
constructor(config, options) {
|
||||
this.config = config
|
||||
this.options = options
|
||||
}
|
||||
}
|
||||
Cluster.initClass()
|
||||
return Cluster
|
||||
})()
|
||||
this.redis = SandboxedModule.require(modulePath, {
|
||||
requires: {
|
||||
ioredis: this.ioredis,
|
||||
},
|
||||
})
|
||||
return (this.auth_pass = '1234 pass')
|
||||
})
|
||||
|
||||
describe "single node redis", ->
|
||||
beforeEach ->
|
||||
@standardOpts =
|
||||
auth_pass: @auth_pass
|
||||
port: 1234
|
||||
host: "redis.mysite.env"
|
||||
describe('single node redis', function () {
|
||||
beforeEach(function () {
|
||||
return (this.standardOpts = {
|
||||
auth_pass: this.auth_pass,
|
||||
port: 1234,
|
||||
host: 'redis.mysite.env',
|
||||
})
|
||||
})
|
||||
|
||||
it "should use the ioredis driver in single-instance mode if a non array is passed", ->
|
||||
client = @redis.createClient @standardOpts
|
||||
assert.equal(client.constructor, @ioredis)
|
||||
it('should use the ioredis driver in single-instance mode if a non array is passed', function () {
|
||||
const client = this.redis.createClient(this.standardOpts)
|
||||
return assert.equal(client.constructor, this.ioredis)
|
||||
})
|
||||
|
||||
it "should call createClient for the ioredis driver in single-instance mode if a non array is passed", ->
|
||||
client = @redis.createClient @standardOpts
|
||||
@ioredisConstructor.calledWith(@standardOpts).should.equal true
|
||||
return it('should call createClient for the ioredis driver in single-instance mode if a non array is passed', function () {
|
||||
const client = this.redis.createClient(this.standardOpts)
|
||||
return this.ioredisConstructor
|
||||
.calledWith(this.standardOpts)
|
||||
.should.equal(true)
|
||||
})
|
||||
})
|
||||
|
||||
describe "cluster", ->
|
||||
beforeEach ->
|
||||
@cluster = [{"mock": "cluster"}, { "mock": "cluster2"}]
|
||||
@extraOptions = {keepAlive:100}
|
||||
@settings =
|
||||
cluster: @cluster
|
||||
redisOptions: @extraOptions
|
||||
key_schema: {foo: (x) -> "#{x}"}
|
||||
describe('cluster', function () {
|
||||
beforeEach(function () {
|
||||
this.cluster = [{ mock: 'cluster' }, { mock: 'cluster2' }]
|
||||
this.extraOptions = { keepAlive: 100 }
|
||||
return (this.settings = {
|
||||
cluster: this.cluster,
|
||||
redisOptions: this.extraOptions,
|
||||
key_schema: {
|
||||
foo(x) {
|
||||
return `${x}`
|
||||
},
|
||||
},
|
||||
})
|
||||
})
|
||||
|
||||
it "should pass the options correctly though with no options", ->
|
||||
client = @redis.createClient cluster: @cluster
|
||||
assert(client instanceof @ioredis.Cluster)
|
||||
client.config.should.deep.equal @cluster
|
||||
it('should pass the options correctly though with no options', function () {
|
||||
const client = this.redis.createClient({ cluster: this.cluster })
|
||||
assert(client instanceof this.ioredis.Cluster)
|
||||
return client.config.should.deep.equal(this.cluster)
|
||||
})
|
||||
|
||||
it "should not pass the key_schema through to the driver", ->
|
||||
client = @redis.createClient cluster: @cluster, key_schema: "foobar"
|
||||
assert(client instanceof @ioredis.Cluster)
|
||||
client.config.should.deep.equal @cluster
|
||||
expect(client.options).to.deep.equal {retry_max_delay: 5000}
|
||||
it('should not pass the key_schema through to the driver', function () {
|
||||
const client = this.redis.createClient({
|
||||
cluster: this.cluster,
|
||||
key_schema: 'foobar',
|
||||
})
|
||||
assert(client instanceof this.ioredis.Cluster)
|
||||
client.config.should.deep.equal(this.cluster)
|
||||
return expect(client.options).to.deep.equal({ retry_max_delay: 5000 })
|
||||
})
|
||||
|
||||
it "should pass the options correctly though with additional options", ->
|
||||
client = @redis.createClient @settings
|
||||
assert(client instanceof @ioredis.Cluster)
|
||||
client.config.should.deep.equal @cluster
|
||||
# need to use expect here because of _.clone in sandbox
|
||||
expect(client.options).to.deep.equal {redisOptions: @extraOptions, retry_max_delay: 5000}
|
||||
return it('should pass the options correctly though with additional options', function () {
|
||||
const client = this.redis.createClient(this.settings)
|
||||
assert(client instanceof this.ioredis.Cluster)
|
||||
client.config.should.deep.equal(this.cluster)
|
||||
// need to use expect here because of _.clone in sandbox
|
||||
return expect(client.options).to.deep.equal({
|
||||
redisOptions: this.extraOptions,
|
||||
retry_max_delay: 5000,
|
||||
})
|
||||
})
|
||||
})
|
||||
|
||||
describe "monkey patch ioredis exec", ->
|
||||
beforeEach ->
|
||||
@callback = sinon.stub()
|
||||
@results = []
|
||||
@multiOrig = { exec: sinon.stub().yields(null, @results)}
|
||||
@client = { multi: sinon.stub().returns(@multiOrig) }
|
||||
@redis._monkeyPatchIoredisExec(@client)
|
||||
@multi = @client.multi()
|
||||
return describe('monkey patch ioredis exec', function () {
|
||||
beforeEach(function () {
|
||||
this.callback = sinon.stub()
|
||||
this.results = []
|
||||
this.multiOrig = { exec: sinon.stub().yields(null, this.results) }
|
||||
this.client = { multi: sinon.stub().returns(this.multiOrig) }
|
||||
this.redis._monkeyPatchIoredisExec(this.client)
|
||||
return (this.multi = this.client.multi())
|
||||
})
|
||||
|
||||
it "should return the old redis format for an array", ->
|
||||
@results[0] = [null, 42]
|
||||
@results[1] = [null, "foo"]
|
||||
@multi.exec @callback
|
||||
@callback.calledWith(null, [42, "foo"]).should.equal true
|
||||
|
||||
it "should return the old redis format when there is an error", ->
|
||||
@results[0] = [null, 42]
|
||||
@results[1] = ["error", "foo"]
|
||||
@multi.exec @callback
|
||||
@callback.calledWith("error").should.equal true
|
||||
it('should return the old redis format for an array', function () {
|
||||
this.results[0] = [null, 42]
|
||||
this.results[1] = [null, 'foo']
|
||||
this.multi.exec(this.callback)
|
||||
return this.callback.calledWith(null, [42, 'foo']).should.equal(true)
|
||||
})
|
||||
|
||||
return it('should return the old redis format when there is an error', function () {
|
||||
this.results[0] = [null, 42]
|
||||
this.results[1] = ['error', 'foo']
|
||||
this.multi.exec(this.callback)
|
||||
return this.callback.calledWith('error').should.equal(true)
|
||||
})
|
||||
})
|
||||
})
|
||||
|
|
Loading…
Reference in a new issue