elasticsearch/test/test.nonci.ts

78 lines
2.2 KiB
TypeScript
Raw Normal View History

2018-08-12 16:42:09 +02:00
import { expect, tap } from '@pushrocks/tapbundle';
import { Qenv } from '@pushrocks/qenv';
2023-07-04 09:13:14 +02:00
import * as elasticsearch from '../ts/index.js';
2018-01-25 00:38:07 +01:00
2023-08-01 12:24:22 +02:00
let testElasticLog: elasticsearch.ElsSmartlogDestination<any>;
2023-08-01 12:38:53 +02:00
let testElasticDoc: elasticsearch.ElasticDoc;
2018-01-25 00:38:07 +01:00
tap.test('first test', async () => {
2023-08-01 12:24:22 +02:00
testElasticLog = new elasticsearch.ElsSmartlogDestination({
2023-07-05 15:31:00 +02:00
indexPrefix: 'testprefix',
2018-11-10 01:48:44 +01:00
indexRetention: 7,
2023-07-05 15:31:00 +02:00
node: 'http://localhost:9200',
2023-07-05 17:27:24 +02:00
auth: {
username: 'elastic',
password: 'YourPassword'
}
2018-08-12 16:42:09 +02:00
});
2023-08-01 12:24:22 +02:00
expect(testElasticLog).toBeInstanceOf(elasticsearch.ElsSmartlogDestination);
2018-08-12 16:42:09 +02:00
});
2018-01-25 00:38:07 +01:00
2023-07-05 15:31:00 +02:00
tap.test('should send a message to Elasticsearch', async () => {
await testElasticLog.log({
2018-11-07 11:38:53 +01:00
timestamp: Date.now(),
2018-11-03 23:45:21 +01:00
type: 'increment',
level: 'info',
context: {
company: 'Lossless GmbH',
companyunit: 'lossless.cloud',
containerName: 'testcontainer',
environment: 'test',
runtime: 'node',
2023-07-04 09:13:14 +02:00
zone: 'ship.zone',
2018-11-03 23:45:21 +01:00
},
2023-07-04 09:13:14 +02:00
message: 'GET https://myroute.to.a.cool.destination/sorare?hello=there',
correlation: null,
2018-08-12 16:42:09 +02:00
});
});
2018-01-25 00:38:07 +01:00
2023-08-01 12:38:53 +02:00
tap.test('should create an ElasticDoc instance', async () => {
testElasticDoc = new elasticsearch.ElasticDoc({
index: 'testindex',
node: 'http://localhost:9200',
auth: {
username: 'elastic',
password: 'YourPassword'
}
});
expect(testElasticDoc).toBeInstanceOf(elasticsearch.ElasticDoc);
});
tap.test('should add and update documents in a piping session', async () => {
await testElasticDoc.startPipingSession();
await testElasticDoc.pipeDocument('1', { name: 'doc1' });
await testElasticDoc.pipeDocument('2', { name: 'doc2' });
await testElasticDoc.pipeDocument('1', { name: 'updated doc1' });
});
tap.test('should delete documents not part of the piping session', async () => {
await testElasticDoc.endPipingSession();
});
2023-08-02 03:11:17 +02:00
tap.test('should take and store snapshot', async () => {
await testElasticDoc.takeSnapshot(async (iterator, prevSnapshot) => {
const aggregationData = [];
for await (const doc of iterator) {
// Sample aggregation: counting documents
aggregationData.push(doc);
}
const snapshot = {
date: new Date().toISOString(),
aggregationData,
};
return snapshot;
});
});
2018-08-12 16:42:09 +02:00
tap.start();