07c827e9fd
[web] last infrastructure conversions GitOrigin-RevId: ad1aff9b7df0610ed0303157d9e2c8032f32c02b
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 east 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 },
|
|
])
|
|
})
|
|
})
|
|
})
|