use async/await HealthCheckTests, promisify helpers

GitOrigin-RevId: 1016296695eb1c09d74d6f50c765438b83df1024
This commit is contained in:
Domagoj Kriskovic
2025-10-01 12:03:23 +02:00
committed by Copybot
parent b0b7822d8d
commit 854536fcc9
3 changed files with 42 additions and 55 deletions

View File

@@ -1,17 +1,6 @@
/* eslint-disable
no-undef,
*/
// TODO: This file was created by bulk-decaffeinate.
// Fix any style issues and re-enable lint.
/*
* decaffeinate suggestions:
* DS102: Remove unnecessary code created because of implicit returns
* DS207: Consider shorter variations of null checks
* Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md
*/
import { expect } from 'chai'
import settings from '@overleaf/settings'
import request from 'request'
import { fetchNothing } from '@overleaf/fetch-utils'
import mongodb from 'mongodb-legacy'
import nock from 'nock'
import * as ProjectHistoryClient from './helpers/ProjectHistoryClient.js'
@@ -22,55 +11,43 @@ const MockHistoryStore = () => nock('http://127.0.0.1:3100')
const MockWeb = () => nock('http://127.0.0.1:3000')
describe('Health Check', function () {
beforeEach(function (done) {
beforeEach(async function () {
const projectId = new ObjectId()
const historyId = new ObjectId().toString()
settings.history.healthCheck = { project_id: projectId }
return ProjectHistoryApp.ensureRunning(error => {
if (error != null) {
throw error
}
MockHistoryStore().post('/api/projects').reply(200, {
projectId: historyId,
})
MockHistoryStore()
.get(`/api/projects/${historyId}/latest/history`)
.reply(200, {
chunk: {
startVersion: 0,
history: {
snapshot: {},
changes: [],
},
},
})
MockWeb()
.get(`/project/${projectId}/details`)
.reply(200, {
name: 'Test Project',
overleaf: {
history: {
id: historyId,
},
},
})
return ProjectHistoryClient.initializeProject(historyId, done)
await ProjectHistoryApp.promises.ensureRunning()
MockHistoryStore().post('/api/projects').reply(200, {
projectId: historyId,
})
MockHistoryStore()
.get(`/api/projects/${historyId}/latest/history`)
.reply(200, {
chunk: {
startVersion: 0,
history: {
snapshot: {},
changes: [],
},
},
})
MockWeb()
.get(`/project/${projectId}/details`)
.reply(200, {
name: 'Test Project',
overleaf: {
history: {
id: historyId,
},
},
})
await ProjectHistoryClient.promises.initializeProject(historyId)
})
return it('should respond to the health check', function (done) {
return request.get(
{
url: 'http://127.0.0.1:3054/health_check',
},
(error, res, body) => {
if (error != null) {
return callback(error)
}
expect(res.statusCode).to.equal(200)
return done()
}
)
it('should respond to the health check', async function () {
const response = await fetchNothing('http://127.0.0.1:3054/health_check')
expect(response.status).to.equal(200)
})
})

View File

@@ -10,6 +10,7 @@
*/
import { app } from '../../../../app/js/server.js'
import { mongoClient } from '../../../../app/js/mongodb.js'
import { promisify } from '@overleaf/promise-utils'
let running = false
let initing = false
@@ -43,3 +44,7 @@ export function ensureRunning(callback) {
})
})
}
export const promises = {
ensureRunning: promisify(ensureRunning),
}

View File

@@ -3,6 +3,7 @@ import request from 'request'
import Settings from '@overleaf/settings'
import RedisWrapper from '@overleaf/redis-wrapper'
import { db } from '../../../../app/js/mongodb.js'
import { promisify } from '@overleaf/promise-utils'
const rclient = RedisWrapper.createClient(Settings.redis.project_history)
const Keys = Settings.redis.project_history.key_schema
@@ -352,3 +353,7 @@ export function deleteProject(projectId, callback) {
callback()
})
}
export const promises = {
initializeProject: promisify(initializeProject),
}