overleaf/services/spelling/test/unit/js/ASpellTests.js

140 lines
3.9 KiB
JavaScript
Raw Normal View History

2019-07-03 12:41:01 +00:00
/* eslint-disable
no-undef
*/
// TODO: This file was created by bulk-decaffeinate.
// Sanity-check the conversion and remove this comment.
/*
* decaffeinate suggestions:
* DS102: Remove unnecessary code created because of implicit returns
* Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md
*/
import { expect, assert } from 'chai'
import esmock from 'esmock'
2019-07-03 12:41:01 +00:00
2020-08-10 16:23:15 +00:00
describe('ASpell', function () {
beforeEach(async function () {
this.ASpell = await esmock('../../../app/js/ASpell', {
'@overleaf/metrics': {
gauge() {},
inc() {},
2021-07-13 11:04:47 +00:00
},
})
})
2019-07-03 12:41:01 +00:00
2020-08-10 16:23:15 +00:00
describe('a correctly spelled word', function () {
beforeEach(function (done) {
2019-07-03 12:41:01 +00:00
return this.ASpell.checkWords('en', ['word'], (error, result) => {
if (error) return done(error)
2019-07-03 12:41:01 +00:00
this.result = result
return done()
})
})
2020-08-10 16:23:15 +00:00
return it('should not correct the word', function () {
2019-07-03 12:41:01 +00:00
return this.result.length.should.equal(0)
})
})
2020-08-10 16:23:15 +00:00
describe('a misspelled word', function () {
beforeEach(function (done) {
2019-07-03 12:41:01 +00:00
return this.ASpell.checkWords('en', ['bussines'], (error, result) => {
if (error) return done(error)
2019-07-03 12:41:01 +00:00
this.result = result
return done()
})
})
2020-08-10 16:23:15 +00:00
return it('should correct the word', function () {
2019-07-03 12:41:01 +00:00
this.result.length.should.equal(1)
return this.result[0].suggestions.indexOf('business').should.not.equal(-1)
})
})
2020-08-10 16:23:15 +00:00
describe('multiple words', function () {
beforeEach(function (done) {
2019-07-03 12:41:01 +00:00
return this.ASpell.checkWords(
'en',
['bussines', 'word', 'neccesary'],
(error, result) => {
if (error) return done(error)
2019-07-03 12:41:01 +00:00
this.result = result
return done()
}
)
})
2020-08-10 16:23:15 +00:00
return it('should correct the incorrect words', function () {
2019-07-03 12:41:01 +00:00
this.result[0].index.should.equal(0)
this.result[0].suggestions.indexOf('business').should.not.equal(-1)
this.result[1].index.should.equal(2)
return this.result[1].suggestions
.indexOf('necessary')
.should.not.equal(-1)
})
})
2020-08-10 16:23:15 +00:00
describe('without a valid language', function () {
beforeEach(function (done) {
2019-07-03 12:41:01 +00:00
return this.ASpell.checkWords('notALang', ['banana'], (error, result) => {
this.error = error
this.result = result
return done()
})
})
2020-08-10 16:23:15 +00:00
return it('should return an error', function () {
return expect(this.error).to.exist
2019-07-03 12:41:01 +00:00
})
})
2020-08-10 16:23:15 +00:00
describe('when there are no suggestions', function () {
beforeEach(function (done) {
2019-07-03 12:41:01 +00:00
return this.ASpell.checkWords(
'en',
['asdkfjalkdjfadhfkajsdhfashdfjhadflkjadhflajsd'],
(error, result) => {
this.error = error
this.result = result
return done()
}
)
})
2020-08-10 16:23:15 +00:00
return it('should return a blank array', function () {
2019-07-03 12:41:01 +00:00
this.result.length.should.equal(1)
return assert.deepEqual(this.result[0].suggestions, [])
})
})
2020-08-10 16:23:15 +00:00
return describe('when the request times out', function () {
beforeEach(function (done) {
2021-07-13 11:04:47 +00:00
const words = __range__(0, 1000, true).map(i => 'abcdefg')
this.ASpell.setTimeout(1)
2019-07-03 12:41:01 +00:00
this.start = Date.now()
return this.ASpell.checkWords('en', words, (error, result) => {
expect(error).to.exist
2019-07-03 12:41:01 +00:00
this.result = result
return done()
})
})
// Note that this test fails on OS X, due to differing pipe behaviour
// on killing the child process. It can be tested successfully on Travis
// or the CI server.
2020-08-10 16:23:15 +00:00
return it('should return in reasonable time', function () {
2019-07-03 12:41:01 +00:00
const delta = Date.now() - this.start
return delta.should.be.below(1000)
2019-07-03 12:41:01 +00:00
})
})
})
function __range__(left, right, inclusive) {
2020-06-03 08:52:36 +00:00
const range = []
const ascending = left < right
const end = !inclusive ? right : ascending ? right + 1 : right - 1
2019-07-03 12:41:01 +00:00
for (let i = left; ascending ? i < end : i > end; ascending ? i++ : i--) {
range.push(i)
}
return range
}