mirror of
https://github.com/yu-i-i/overleaf-cep.git
synced 2026-06-06 23:59:01 +02:00
da11cf2669
* [monorepo] fix running tests locally * [web] fix east invocation * [web] move corepack into entrypoint * [web] fix running module acceptance tests locally * [web] fix merged module targets * [web] remove spurious change GitOrigin-RevId: 84cf7f8d768d3429c8a98c789acf76f6cecd6e3e
60 lines
1.7 KiB
JavaScript
60 lines
1.7 KiB
JavaScript
import { db, ObjectId } from '../../../app/src/infrastructure/mongodb.mjs'
|
|
import { promisify } from 'node:util'
|
|
import { exec } from 'node:child_process'
|
|
import logger from '@overleaf/logger'
|
|
import { expect } from 'chai'
|
|
|
|
describe('BackFillDocRevTests', function () {
|
|
const docId1 = new ObjectId()
|
|
const docId2 = new ObjectId()
|
|
const docId3 = new ObjectId()
|
|
|
|
beforeEach('insert docs', async function () {
|
|
await db.docs.insertMany([
|
|
{ _id: docId1, deleted: true },
|
|
{ _id: docId2 },
|
|
{ _id: docId3, rev: 42 },
|
|
])
|
|
})
|
|
|
|
async function runScript() {
|
|
let result
|
|
try {
|
|
result = await promisify(exec)(
|
|
'cd ../../tools/migrations && VERBOSE_LOGGING=true yarn run migrations migrate -t server-ce --force 20230315170739_back_fill_doc_rev'
|
|
)
|
|
} catch (error) {
|
|
// dump details like exit code, stdErr and stdOut
|
|
logger.error({ error }, 'script failed')
|
|
throw error
|
|
}
|
|
const { stdout: stdOut } = result
|
|
|
|
expect(stdOut).to.include('rev missing 2 | deleted=true 1')
|
|
expect(stdOut).to.match(
|
|
new RegExp(`Running update on batch with ids .+${docId1}`)
|
|
)
|
|
expect(stdOut).to.match(
|
|
new RegExp(`Running update on batch with ids .+${docId2}`)
|
|
)
|
|
expect(stdOut).to.not.match(
|
|
new RegExp(`Running update on batch with ids .+${docId3}`)
|
|
)
|
|
}
|
|
|
|
describe('dry-run=false', function () {
|
|
beforeEach('run script', async function () {
|
|
await runScript()
|
|
})
|
|
|
|
it('should back fill the rev', async function () {
|
|
const docs = await db.docs.find({}, { $sort: { _id: 1 } }).toArray()
|
|
expect(docs).to.deep.equal([
|
|
{ _id: docId1, rev: 1, deleted: true },
|
|
{ _id: docId2, rev: 1 },
|
|
{ _id: docId3, rev: 42 },
|
|
])
|
|
})
|
|
})
|
|
})
|