fix(core): update
This commit is contained in:
parent
30f4254428
commit
de1f1110b4
@ -92,7 +92,7 @@ tap.test('should save the car to the db', async () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
tap.test('expect to get instance of Car with shallow match', async () => {
|
tap.test('expect to get instance of Car with shallow match', async () => {
|
||||||
const totalQueryCycles = totalCars / 2;
|
const totalQueryCycles = totalCars / 6;
|
||||||
let counter = 0;
|
let counter = 0;
|
||||||
do {
|
do {
|
||||||
const timeStart = Date.now();
|
const timeStart = Date.now();
|
||||||
@ -113,7 +113,7 @@ tap.test('expect to get instance of Car with shallow match', async () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
tap.test('expect to get instance of Car with deep match', async () => {
|
tap.test('expect to get instance of Car with deep match', async () => {
|
||||||
const totalQueryCycles = totalCars / 4;
|
const totalQueryCycles = totalCars / 6;
|
||||||
let counter = 0;
|
let counter = 0;
|
||||||
do {
|
do {
|
||||||
const timeStart = Date.now();
|
const timeStart = Date.now();
|
||||||
|
@ -3,6 +3,6 @@
|
|||||||
*/
|
*/
|
||||||
export const commitinfo = {
|
export const commitinfo = {
|
||||||
name: '@pushrocks/smartdata',
|
name: '@pushrocks/smartdata',
|
||||||
version: '5.0.0',
|
version: '5.0.1',
|
||||||
description: 'do more with data'
|
description: 'do more with data'
|
||||||
}
|
}
|
||||||
|
@ -180,10 +180,10 @@ export class SmartdataCollection<T> {
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
public async getCursor(filterObject: any): Promise<SmartdataDbCursor<any>> {
|
public async getCursor(filterObjectArg: any, dbDocArg: typeof SmartDataDbDoc): Promise<SmartdataDbCursor<any>> {
|
||||||
await this.init();
|
await this.init();
|
||||||
const cursor = this.mongoDbCollection.find(filterObject);
|
const cursor = this.mongoDbCollection.find(filterObjectArg);
|
||||||
return new SmartdataDbCursor(cursor);
|
return new SmartdataDbCursor(cursor, dbDocArg);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -200,7 +200,7 @@ export class SmartdataCollection<T> {
|
|||||||
/**
|
/**
|
||||||
* watches the collection while applying a filter
|
* watches the collection while applying a filter
|
||||||
*/
|
*/
|
||||||
public async watch(filterObject: any): Promise<SmartdataDbWatcher> {
|
public async watch(filterObject: any, smartdataDbDocArg: typeof SmartDataDbDoc): Promise<SmartdataDbWatcher> {
|
||||||
await this.init();
|
await this.init();
|
||||||
const changeStream = this.mongoDbCollection.watch([
|
const changeStream = this.mongoDbCollection.watch([
|
||||||
{
|
{
|
||||||
@ -209,7 +209,7 @@ export class SmartdataCollection<T> {
|
|||||||
], {
|
], {
|
||||||
fullDocument: 'updateLookup'
|
fullDocument: 'updateLookup'
|
||||||
});
|
});
|
||||||
const smartdataWatcher = new SmartdataDbWatcher(changeStream);
|
const smartdataWatcher = new SmartdataDbWatcher(changeStream, smartdataDbDocArg);
|
||||||
await smartdataWatcher.readyDeferred.promise;
|
await smartdataWatcher.readyDeferred.promise;
|
||||||
return smartdataWatcher;
|
return smartdataWatcher;
|
||||||
}
|
}
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
import { SmartDataDbDoc } from './smartdata.classes.doc.js';
|
||||||
import * as plugins from './smartdata.plugins.js';
|
import * as plugins from './smartdata.plugins.js';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -8,26 +9,29 @@ export class SmartdataDbCursor<T = any> {
|
|||||||
|
|
||||||
// INSTANCE
|
// INSTANCE
|
||||||
public mongodbCursor: plugins.mongodb.FindCursor<T>;
|
public mongodbCursor: plugins.mongodb.FindCursor<T>;
|
||||||
constructor(cursorArg: plugins.mongodb.FindCursor<T>) {
|
private smartdataDbDoc: typeof SmartDataDbDoc;
|
||||||
|
constructor(cursorArg: plugins.mongodb.FindCursor<T>, dbDocArg: typeof SmartDataDbDoc) {
|
||||||
this.mongodbCursor = cursorArg;
|
this.mongodbCursor = cursorArg;
|
||||||
|
this.smartdataDbDoc = dbDocArg;
|
||||||
}
|
}
|
||||||
|
|
||||||
public async next(closeAtEnd = true) {
|
public async next(closeAtEnd = true) {
|
||||||
const result = await this.mongodbCursor.next();
|
const result = this.smartdataDbDoc.createInstanceFromMongoDbNativeDoc(await this.mongodbCursor.next());
|
||||||
if (!result && closeAtEnd) {
|
if (!result && closeAtEnd) {
|
||||||
await this.close();
|
await this.close();
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
public async forEach(forEachFuncArg: (itemArg: T) => Promise<any>, closeCursorAtEnd = true) {
|
public async forEach(forEachFuncArg: (itemArg: any) => Promise<any>, closeCursorAtEnd = true) {
|
||||||
let currentValue: T;
|
let nextDocument: any;
|
||||||
do {
|
do {
|
||||||
currentValue = await this.mongodbCursor.next();
|
nextDocument = await this.mongodbCursor.next();
|
||||||
if (currentValue) {
|
if (nextDocument) {
|
||||||
await forEachFuncArg(currentValue);
|
const nextClassInstance = this.smartdataDbDoc.createInstanceFromMongoDbNativeDoc(nextDocument);
|
||||||
|
await forEachFuncArg(nextClassInstance);
|
||||||
}
|
}
|
||||||
} while (currentValue);
|
} while (nextDocument);
|
||||||
if (closeCursorAtEnd) {
|
if (closeCursorAtEnd) {
|
||||||
await this.close();
|
await this.close();
|
||||||
}
|
}
|
||||||
|
@ -137,8 +137,10 @@ export class SmartDataDbDoc<T extends TImplements, TImplements, TManager extends
|
|||||||
this: plugins.tsclass.typeFest.Class<T>,
|
this: plugins.tsclass.typeFest.Class<T>,
|
||||||
filterArg: plugins.tsclass.typeFest.PartialDeep<T>
|
filterArg: plugins.tsclass.typeFest.PartialDeep<T>
|
||||||
) {
|
) {
|
||||||
const cursor: SmartdataDbCursor<T> = await (this as any).collection.getCursor(
|
const collection: SmartdataCollection<T> = (this as any).collection;
|
||||||
convertFilterForMongoDb(filterArg)
|
const cursor: SmartdataDbCursor<T> = await collection.getCursor(
|
||||||
|
convertFilterForMongoDb(filterArg),
|
||||||
|
this as any as typeof SmartDataDbDoc
|
||||||
);
|
);
|
||||||
return cursor;
|
return cursor;
|
||||||
}
|
}
|
||||||
@ -155,7 +157,8 @@ export class SmartDataDbDoc<T extends TImplements, TImplements, TManager extends
|
|||||||
) {
|
) {
|
||||||
const collection: SmartdataCollection<T> = (this as any).collection;
|
const collection: SmartdataCollection<T> = (this as any).collection;
|
||||||
const watcher: SmartdataDbWatcher<T> = await collection.watch(
|
const watcher: SmartdataDbWatcher<T> = await collection.watch(
|
||||||
convertFilterForMongoDb(filterArg)
|
convertFilterForMongoDb(filterArg),
|
||||||
|
(this as any)
|
||||||
);
|
);
|
||||||
return watcher;
|
return watcher;
|
||||||
}
|
}
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
import { SmartDataDbDoc } from './smartdata.classes.doc.js';
|
||||||
import * as plugins from './smartdata.plugins.js';
|
import * as plugins from './smartdata.plugins.js';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -8,12 +9,13 @@ export class SmartdataDbWatcher<T = any> {
|
|||||||
public readyDeferred = plugins.smartpromise.defer();
|
public readyDeferred = plugins.smartpromise.defer();
|
||||||
|
|
||||||
// INSTANCE
|
// INSTANCE
|
||||||
public changeStream: plugins.mongodb.ChangeStream<T>;
|
private changeStream: plugins.mongodb.ChangeStream<T>;
|
||||||
public changeSubject = new plugins.smartrx.rxjs.Subject<T>();
|
|
||||||
constructor(changeStreamArg: plugins.mongodb.ChangeStream<T>) {
|
public changeSubject = new plugins.smartrx.rxjs.Subject<SmartDataDbDoc<T, T>>();
|
||||||
|
constructor(changeStreamArg: plugins.mongodb.ChangeStream<T>, smartdataDbDocArg: typeof SmartDataDbDoc) {
|
||||||
this.changeStream = changeStreamArg;
|
this.changeStream = changeStreamArg;
|
||||||
this.changeStream.on('change', async (item: T) => {
|
this.changeStream.on('change', async (item: T) => {
|
||||||
this.changeSubject.next(item);
|
this.changeSubject.next(smartdataDbDocArg.createInstanceFromMongoDbNativeDoc(item));
|
||||||
})
|
})
|
||||||
plugins.smartdelay.delayFor(0).then(() => {
|
plugins.smartdelay.delayFor(0).then(() => {
|
||||||
this.readyDeferred.resolve();
|
this.readyDeferred.resolve();
|
||||||
|
Loading…
Reference in New Issue
Block a user