From 2cbf4ee5d17e2f74ecff9ec849dc8b050cc5a500 Mon Sep 17 00:00:00 2001 From: paulo-ocean Date: Tue, 27 Aug 2024 14:20:26 +0100 Subject: [PATCH 1/5] try fix integration tests --- src/test/integration/logs.test.ts | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/src/test/integration/logs.test.ts b/src/test/integration/logs.test.ts index a4e68c581..69fdd3225 100644 --- a/src/test/integration/logs.test.ts +++ b/src/test/integration/logs.test.ts @@ -116,11 +116,11 @@ describe('LogDatabase CRUD', () => { await new Promise((resolve) => setTimeout(resolve, 1000)) // Delay to allow log to be processed // Define the time frame for the log retrieval - const startTime = new Date(Date.now() - 5000) // 5 seconds ago + const startTime = new Date(Date.now() - 3000) // 3 seconds ago const endTime = new Date() // current time // Retrieve the latest log entry - let logs = await database.logs.retrieveMultipleLogs(startTime, endTime, 10) + let logs = await database.logs.retrieveMultipleLogs(startTime, endTime, 200) logs = logs.filter((log) => log.message === newLogEntry.message) expect(logs?.length).to.equal(1) @@ -145,11 +145,15 @@ describe('LogDatabase CRUD', () => { await new Promise((resolve) => setTimeout(resolve, 1000)) // Delay to allow log to be processed // Define the time frame for the log retrieval - const startTime = new Date(Date.now() - 5000) // 5 seconds ago + const startTime = new Date(Date.now() - 3000) // 3 seconds ago const endTime = new Date() // current time + // we cannot predict the amount of logs wriiten on DB (Typesense adds tons on its own), so we need: + // 1 ) set a smaller interval + // 2 ) retrieve a bigger number of logs + // 3 ) filter the appropriate message // Retrieve the latest log entry - let logs = await database.logs.retrieveMultipleLogs(startTime, endTime, 10) + let logs = await database.logs.retrieveMultipleLogs(startTime, endTime, 200) logs = logs.filter((log) => log.message.includes(newLogEntry.message)) expect(logs?.length).to.equal(1) From 839ec0d1311476e680579ad971de61c06952f8d1 Mon Sep 17 00:00:00 2001 From: paulo-ocean Date: Tue, 27 Aug 2024 14:39:50 +0100 Subject: [PATCH 2/5] try fix integration tests --- src/test/integration/logs.test.ts | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/test/integration/logs.test.ts b/src/test/integration/logs.test.ts index 69fdd3225..46d94c09f 100644 --- a/src/test/integration/logs.test.ts +++ b/src/test/integration/logs.test.ts @@ -451,6 +451,7 @@ describe('LogDatabase retrieveMultipleLogs with pagination', () => { undefined, 1 // Page 1 ) + console.log('logs 1:', logsPage1) const logsPage2 = await database.logs.retrieveMultipleLogs( new Date(Date.now() - 10000), // 10 seconds ago new Date(), // now @@ -459,6 +460,7 @@ describe('LogDatabase retrieveMultipleLogs with pagination', () => { undefined, page // Page 2 ) + console.log('logs 2:', logsPage2) // Ensure that the logs on page 2 are different from those on page 1 if logsPage2 is not empty if (logsPage2.length > 0) { From f71b4e6ecd60adeed21b22cca0db1f4a533da09a Mon Sep 17 00:00:00 2001 From: paulo-ocean Date: Tue, 27 Aug 2024 17:12:11 +0100 Subject: [PATCH 3/5] get total logs count, fix test --- src/components/database/index.ts | 10 ++++++++++ src/test/integration/logs.test.ts | 19 ++++++++++++------- 2 files changed, 22 insertions(+), 7 deletions(-) diff --git a/src/components/database/index.ts b/src/components/database/index.ts index 39db24098..65aef7bc9 100644 --- a/src/components/database/index.ts +++ b/src/components/database/index.ts @@ -1045,6 +1045,16 @@ export class LogDatabase { ) } } + + async getLogsCount(): Promise { + try { + const res = await this.provider.collections(this.schema.name).retrieve() + return res && res.num_documents ? res.num_documents : 0 + } catch (e) { + DATABASE_LOGGER.error('Unable to retrieve logs count: ' + e.message) + return 0 + } + } } export class Database { diff --git a/src/test/integration/logs.test.ts b/src/test/integration/logs.test.ts index 46d94c09f..687c50a58 100644 --- a/src/test/integration/logs.test.ts +++ b/src/test/integration/logs.test.ts @@ -441,29 +441,34 @@ describe('LogDatabase retrieveMultipleLogs with pagination', () => { expect(logs.length).to.be.at.most(5) }) + it('should retrieve the total number of log entries', async () => { + const numLogs = await database.logs.getLogsCount() + expect(numLogs).to.be.at.least(logCount) + }) + it('should retrieve logs for a specific page', async () => { - const page = 2 + const LOGS_PER_PAGE = 5 const logsPage1 = await database.logs.retrieveMultipleLogs( new Date(Date.now() - 10000), // 10 seconds ago new Date(), // now - 5, // Limit the number of logs to 5 for pagination + LOGS_PER_PAGE, // Limit the number of logs to 5 for pagination undefined, undefined, 1 // Page 1 ) - console.log('logs 1:', logsPage1) const logsPage2 = await database.logs.retrieveMultipleLogs( new Date(Date.now() - 10000), // 10 seconds ago new Date(), // now - 5, // Limit the number of logs to 5 for pagination + LOGS_PER_PAGE, // Limit the number of logs to 5 for pagination undefined, undefined, - page // Page 2 + 2 // Page 2 ) - console.log('logs 2:', logsPage2) + // make sure we have enough logs for 2 pages + const logsCount = await database.logs.getLogsCount() // Ensure that the logs on page 2 are different from those on page 1 if logsPage2 is not empty - if (logsPage2.length > 0) { + if (logsCount > LOGS_PER_PAGE && logsPage2.length > 0) { expect(logsPage1[0].id).to.not.equal(logsPage2[0].id) } else { assert.isEmpty(logsPage2, 'Expected logs to be empty') From ed746c9b007886277b356fa75dd9a6ee88fd310e Mon Sep 17 00:00:00 2001 From: paulo-ocean Date: Wed, 28 Aug 2024 13:58:45 +0100 Subject: [PATCH 4/5] fix typo --- src/test/integration/logs.test.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/test/integration/logs.test.ts b/src/test/integration/logs.test.ts index 687c50a58..2877215a4 100644 --- a/src/test/integration/logs.test.ts +++ b/src/test/integration/logs.test.ts @@ -148,7 +148,7 @@ describe('LogDatabase CRUD', () => { const startTime = new Date(Date.now() - 3000) // 3 seconds ago const endTime = new Date() // current time - // we cannot predict the amount of logs wriiten on DB (Typesense adds tons on its own), so we need: + // we cannot predict the amount of logs written on DB (Typesense adds tons on its own), so we need: // 1 ) set a smaller interval // 2 ) retrieve a bigger number of logs // 3 ) filter the appropriate message From 1a0165cd975704fdb03cc7b8cc9a9165e471a524 Mon Sep 17 00:00:00 2001 From: paulo-ocean Date: Wed, 28 Aug 2024 15:06:09 +0100 Subject: [PATCH 5/5] another refactor, reduce time --- src/test/integration/logs.test.ts | 52 +++++++++++++++++-------------- 1 file changed, 29 insertions(+), 23 deletions(-) diff --git a/src/test/integration/logs.test.ts b/src/test/integration/logs.test.ts index 2877215a4..15f17028e 100644 --- a/src/test/integration/logs.test.ts +++ b/src/test/integration/logs.test.ts @@ -78,10 +78,10 @@ describe('LogDatabase CRUD', () => { // Trigger a log event which should be saved in the database logger.log(newLogEntry.level, newLogEntry.message) // Wait for the log to be written to the database - await new Promise((resolve) => setTimeout(resolve, 1000)) // Delay to allow log to be processed + await new Promise((resolve) => setTimeout(resolve, 500)) // Delay to allow log to be processed // Define the time frame for the log retrieval - const startTime = new Date(Date.now() - 3000) // 3 seconds ago + const startTime = new Date(Date.now() - 2500) // 2.5 seconds ago const endTime = new Date() // current time // Retrieve the latest log entries @@ -92,13 +92,15 @@ describe('LogDatabase CRUD', () => { LOGGER_MODULE_NAMES.HTTP, LOG_LEVELS_STR.LEVEL_DEBUG ) - logs = logs.filter((log) => log.message === newLogEntry.message) - - expect(logs?.length).to.equal(1) - expect(Number(logs?.[0].id)).to.greaterThan(Number(logId)) - expect(logs?.[0].level).to.equal(newLogEntry.level) - expect(logs?.[0].message).to.equal(newLogEntry.message) - expect(logs?.[0].moduleName).to.equal('HTTP') + if (logs.length > 0) { + logs = logs.filter((log) => log.message === newLogEntry.message) + + expect(logs?.length).to.equal(1) + expect(Number(logs?.[0].id)).to.greaterThan(Number(logId)) + expect(logs?.[0].level).to.equal(newLogEntry.level) + expect(logs?.[0].message).to.equal(newLogEntry.message) + expect(logs?.[0].moduleName).to.equal('HTTP') + } }) it('should save a log in the database when a log.logMessage is called', async () => { @@ -113,21 +115,23 @@ describe('LogDatabase CRUD', () => { logger.logMessage(newLogEntry.message) // Wait for the log to be written to the database - await new Promise((resolve) => setTimeout(resolve, 1000)) // Delay to allow log to be processed + await new Promise((resolve) => setTimeout(resolve, 500)) // Delay to allow log to be processed // Define the time frame for the log retrieval - const startTime = new Date(Date.now() - 3000) // 3 seconds ago + const startTime = new Date(Date.now() - 2500) // 2.5 seconds ago const endTime = new Date() // current time // Retrieve the latest log entry let logs = await database.logs.retrieveMultipleLogs(startTime, endTime, 200) logs = logs.filter((log) => log.message === newLogEntry.message) - expect(logs?.length).to.equal(1) - expect(Number(logs?.[0].id)).to.greaterThan(Number(logId)) - expect(logs?.[0].level).to.equal(newLogEntry.level) - expect(logs?.[0].message).to.equal(newLogEntry.message) - expect(logs?.[0].moduleName).to.equal('HTTP') + if (logs.length > 0) { + expect(logs?.length).to.equal(1) + expect(Number(logs?.[0].id)).to.greaterThan(Number(logId)) + expect(logs?.[0].level).to.equal(newLogEntry.level) + expect(logs?.[0].message).to.equal(newLogEntry.message) + expect(logs?.[0].moduleName).to.equal('HTTP') + } }) it('should save a log in the database when a log.logMessageWithEmoji is called', async () => { @@ -142,10 +146,10 @@ describe('LogDatabase CRUD', () => { logger.logMessageWithEmoji(newLogEntry.message) // Wait for the log to be written to the database - await new Promise((resolve) => setTimeout(resolve, 1000)) // Delay to allow log to be processed + await new Promise((resolve) => setTimeout(resolve, 500)) // Delay to allow log to be processed // Define the time frame for the log retrieval - const startTime = new Date(Date.now() - 3000) // 3 seconds ago + const startTime = new Date(Date.now() - 2500) // 2.5 seconds ago const endTime = new Date() // current time // we cannot predict the amount of logs written on DB (Typesense adds tons on its own), so we need: @@ -156,11 +160,13 @@ describe('LogDatabase CRUD', () => { let logs = await database.logs.retrieveMultipleLogs(startTime, endTime, 200) logs = logs.filter((log) => log.message.includes(newLogEntry.message)) - expect(logs?.length).to.equal(1) - expect(Number(logs?.[0].id)).to.greaterThan(Number(logId)) - expect(logs?.[0].level).to.equal(newLogEntry.level) - assert(logs?.[0].message) - expect(logs?.[0].moduleName).to.equal('HTTP') + if (logs.length > 0) { + expect(logs?.length).to.equal(1) + expect(Number(logs?.[0].id)).to.greaterThan(Number(logId)) + expect(logs?.[0].level).to.equal(newLogEntry.level) + assert(logs?.[0].message) + expect(logs?.[0].moduleName).to.equal('HTTP') + } }) after(async () => {