2018-08-12 16:42:09 +02:00
|
|
|
import { expect, tap } from '@pushrocks/tapbundle';
|
2018-11-03 20:01:39 +01:00
|
|
|
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();
|