mirror of
https://github.com/overleaf/overleaf.git
synced 2024-12-12 12:51:38 -05:00
a450a74351
* Revert "Revert "Bump async to 3.2.2 (#7618)"" This reverts commit 75153a555211d654744c2e61e27fe21085826c22. * [web] fix usage of async.queue.drain in script * [clsi] fix usage of async.queue.drain * [spelling] fix usage of async.queue.drain * [redis-wrapper] fix usage of async.queue.drain * [web] Test that LockManager queue is cleared This protects against a regression found when upgrading the async package. Here we test that the `queue.drain` callback is really getting called, and the lock is being removed from the LOCK_QUEUES map. * [redis-wrapper] Upgrade async to 3.2.2 GitOrigin-RevId: df921e6d7f1d505bd467f22e58600ba1aff48869
162 lines
4.4 KiB
JavaScript
162 lines
4.4 KiB
JavaScript
/* eslint-disable */
|
|
// TODO: This file was created by bulk-decaffeinate.
|
|
// Sanity-check the conversion and remove this comment.
|
|
/*
|
|
* decaffeinate suggestions:
|
|
* DS101: Remove unnecessary use of Array.from
|
|
* DS102: Remove unnecessary code created because of implicit returns
|
|
* DS104: Avoid inline assignments
|
|
* DS202: Simplify dynamic range loops
|
|
* Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md
|
|
*/
|
|
// N requests in parallel
|
|
// send P correct words and Q incorrect words
|
|
// generate incorrect words by qq+random
|
|
|
|
const async = require('async')
|
|
const request = require('request')
|
|
const fs = require('fs')
|
|
|
|
// created with
|
|
// aspell -d en dump master | aspell -l en expand | shuf -n 150000 > words.txt
|
|
const WORDS = 'words.txt'
|
|
const wordlist = fs
|
|
.readFileSync(WORDS)
|
|
.toString()
|
|
.split('\n')
|
|
.filter(w => w.match(/^[a-z]+$/))
|
|
|
|
const generateCorrectWords = function (n) {
|
|
const words = []
|
|
const N = Math.random() > 0.5 ? wordlist.length : 10
|
|
for (
|
|
let i = 1, end = n, asc = 1 <= end;
|
|
asc ? i <= end : i >= end;
|
|
asc ? i++ : i--
|
|
) {
|
|
const j = Math.floor(N * Math.random())
|
|
words.push(wordlist[j])
|
|
}
|
|
return words
|
|
}
|
|
|
|
const generateIncorrectWords = function (n) {
|
|
const words = []
|
|
const N = wordlist.length
|
|
for (
|
|
let i = 1, end = n, asc = 1 <= end;
|
|
asc ? i <= end : i >= end;
|
|
asc ? i++ : i--
|
|
) {
|
|
const j = Math.floor(N * Math.random())
|
|
words.push(`qzxq${wordlist[j]}`)
|
|
}
|
|
return words
|
|
}
|
|
|
|
const make_request = function (correctWords, incorrectWords, callback) {
|
|
let i, j, w
|
|
let i1
|
|
let j1
|
|
const correctSet = generateCorrectWords(correctWords)
|
|
const incorrectSet = generateIncorrectWords(incorrectWords)
|
|
correctSet.push('constructor')
|
|
incorrectSet.push('qzxqfoofoofoo')
|
|
const full = correctSet.concat(incorrectSet)
|
|
const bad = []
|
|
for (j = 0, i = j; j < correctSet.length; j++, i = j) {
|
|
w = correctSet[i]
|
|
bad[i] = false
|
|
}
|
|
for (i1 = 0, i = i1; i1 < incorrectSet.length; i1++, i = i1) {
|
|
w = incorrectSet[i]
|
|
bad[i + correctSet.length] = true
|
|
}
|
|
const k = full.length
|
|
full.forEach(function (e, i) {
|
|
let ref
|
|
j = Math.floor(k * Math.random())
|
|
;[full[i], full[j]] = Array.from([full[j], full[i]])
|
|
return ([bad[i], bad[j]] = Array.from((ref = [bad[j], bad[i]]))), ref
|
|
})
|
|
const expected = []
|
|
for (j1 = 0, i = j1; j1 < bad.length; j1++, i = j1) {
|
|
const tf = bad[i]
|
|
if (tf) {
|
|
expected.push({ index: i, word: full[i] })
|
|
}
|
|
}
|
|
return request.post(
|
|
'http://localhost:3005/user/1/check',
|
|
{ json: true, body: { words: full } },
|
|
function (err, req, body) {
|
|
let m
|
|
const { misspellings } = body
|
|
console.log(JSON.stringify({ full, misspellings }))
|
|
if (expected.length !== misspellings.length) {
|
|
let asc, end
|
|
console.log(
|
|
'ERROR: length mismatch',
|
|
expected.length,
|
|
misspellings.length
|
|
)
|
|
console.log(full, bad)
|
|
console.log('expected', expected, 'mispellings', misspellings)
|
|
for (
|
|
i = 0,
|
|
end = Math.max(expected.length, misspellings.length) - 1,
|
|
asc = 0 <= end;
|
|
asc ? i <= end : i >= end;
|
|
asc ? i++ : i--
|
|
) {
|
|
if (expected[i].index !== misspellings[i].index) {
|
|
console.log(
|
|
'ERROR',
|
|
i,
|
|
expected[i],
|
|
misspellings[i],
|
|
full[misspellings[i].index]
|
|
)
|
|
}
|
|
}
|
|
for (m of Array.from(misspellings)) {
|
|
console.log(full[m.index], '=>', m)
|
|
}
|
|
process.exit()
|
|
callback('error')
|
|
} else {
|
|
for (i = 0; i < body.misspellings.length; i++) {
|
|
m = body.misspellings[i]
|
|
if (m.index !== expected[i].index) {
|
|
console.log('ERROR AT RESULT', i, m, expected[i])
|
|
process.exit()
|
|
callback('error')
|
|
}
|
|
}
|
|
}
|
|
return callback(null, full)
|
|
}
|
|
)
|
|
}
|
|
|
|
const q = async.queue(
|
|
(task, callback) =>
|
|
setTimeout(
|
|
() => make_request(task.correct, task.incorrect, callback),
|
|
Math.random() * 100
|
|
),
|
|
|
|
3
|
|
)
|
|
|
|
q.drain(() => console.log('all items have been processed'))
|
|
|
|
for (let i = 0; i <= 1000; i++) {
|
|
q.push({
|
|
correct: Math.floor(30 * Math.random()) + 1,
|
|
incorrect: Math.floor(3 * Math.random()),
|
|
})
|
|
}
|
|
// if Math.random() < 0.1
|
|
// else
|
|
// q.push({correct: Math.floor(100*Math.random()) + 1, incorrect: Math.floor(3*Math.random())})
|