Compare commits

..

6 Commits

Author SHA1 Message Date
739e040776 4.0.24 2021-11-12 19:02:29 +01:00
28d57efd9e fix(core): update 2021-11-12 19:02:29 +01:00
f50a61308c 4.0.23 2021-11-12 18:12:59 +01:00
42aa9f9f8a fix(core): update 2021-11-12 18:12:59 +01:00
3f591ff9d8 4.0.22 2021-11-12 18:04:08 +01:00
7b33347b4c fix(core): update 2021-11-12 18:04:08 +01:00
9 changed files with 38 additions and 37 deletions

View File

@ -13,7 +13,6 @@ stages:
- metadata - metadata
before_script: before_script:
- apt-get update && apt-get install -y libcurl3 libssl-dev openssl libssl1.0.0 mongodb
- npm install -g @shipzone/npmci - npm install -g @shipzone/npmci
# ==================== # ====================

4
package-lock.json generated
View File

@ -1,12 +1,12 @@
{ {
"name": "@pushrocks/smartdata", "name": "@pushrocks/smartdata",
"version": "4.0.21", "version": "4.0.24",
"lockfileVersion": 2, "lockfileVersion": 2,
"requires": true, "requires": true,
"packages": { "packages": {
"": { "": {
"name": "@pushrocks/smartdata", "name": "@pushrocks/smartdata",
"version": "4.0.21", "version": "4.0.24",
"license": "MIT", "license": "MIT",
"dependencies": { "dependencies": {
"@pushrocks/lik": "^5.0.0", "@pushrocks/lik": "^5.0.0",

View File

@ -1,6 +1,6 @@
{ {
"name": "@pushrocks/smartdata", "name": "@pushrocks/smartdata",
"version": "4.0.21", "version": "4.0.24",
"private": false, "private": false,
"description": "do more with data", "description": "do more with data",
"main": "dist_ts/index.js", "main": "dist_ts/index.js",

View File

@ -37,6 +37,7 @@ tap.test('should connect to atlas', async (tools) => {
mongoDbUrl: testQenv.getEnvVarOnDemand('MONGO_URL'), mongoDbUrl: testQenv.getEnvVarOnDemand('MONGO_URL'),
mongoDbName: databaseName, mongoDbName: databaseName,
}); });
await testDb.init();
}); });
let easyStore: smartdata.EasyStore<{ let easyStore: smartdata.EasyStore<{
@ -52,11 +53,12 @@ tap.test('should create an easystore', async () => {
}); });
tap.test('close', async () => { tap.test('close', async () => {
testDb.close(); if (mongod) {
mongod.stop(); await mongod.stop();
setTimeout(() => { } else {
process.exit(0); await testDb.mongoDb.dropDatabase();
}, 1000); }
await testDb.close();
}); });
tap.start(); tap.start();

View File

@ -30,6 +30,7 @@ tap.skip.test('should create a testinstance as database', async () => {
}; };
console.log(smartdataOptions); console.log(smartdataOptions);
testDb = new smartdata.SmartdataDb(smartdataOptions); testDb = new smartdata.SmartdataDb(smartdataOptions);
await testDb.init();
}); });
tap.test('should connect to atlas', async (tools) => { tap.test('should connect to atlas', async (tools) => {
@ -38,9 +39,6 @@ tap.test('should connect to atlas', async (tools) => {
mongoDbUrl: testQenv.getEnvVarOnDemand('MONGO_URL'), mongoDbUrl: testQenv.getEnvVarOnDemand('MONGO_URL'),
mongoDbName: databaseName, mongoDbName: databaseName,
}); });
});
tap.test('should establish a connection to mongod', async () => {
await testDb.init(); await testDb.init();
}); });
@ -204,7 +202,7 @@ tap.test('should store a new Truck', async () => {
tap.test('should use a cursor', async () => { tap.test('should use a cursor', async () => {
const cursor = await Truck.getCursor({}); const cursor = await Truck.getCursor({});
cursor.forEach(async truckArg => { cursor.forEach(async (truckArg) => {
console.log(truckArg.id); console.log(truckArg.id);
}); });
}); });
@ -212,12 +210,13 @@ tap.test('should use a cursor', async () => {
// ======================================= // =======================================
// close the database connection // close the database connection
// ======================================= // =======================================
tap.test('should drop the db and close the database connection', async (tools) => { tap.test('close', async () => {
await testDb.mongoDb.dropDatabase(); if (mongod) {
await testDb.close();
try {
await mongod.stop(); await mongod.stop();
} catch (e) {} } else {
await testDb.mongoDb.dropDatabase();
}
await testDb.close();
}); });
tap.start({ throwOnError: true }); tap.start({ throwOnError: true });

View File

@ -30,6 +30,7 @@ tap.skip.test('should create a testinstance as database', async () => {
}; };
console.log(smartdataOptions); console.log(smartdataOptions);
testDb = new smartdata.SmartdataDb(smartdataOptions); testDb = new smartdata.SmartdataDb(smartdataOptions);
await testDb.init();
}); });
tap.test('should connect to atlas', async (tools) => { tap.test('should connect to atlas', async (tools) => {
@ -38,9 +39,6 @@ tap.test('should connect to atlas', async (tools) => {
mongoDbUrl: testQenv.getEnvVarOnDemand('MONGO_URL'), mongoDbUrl: testQenv.getEnvVarOnDemand('MONGO_URL'),
mongoDbName: databaseName, mongoDbName: databaseName,
}); });
});
tap.test('should establish a connection to mongod', async () => {
await testDb.init(); await testDb.init();
}); });
@ -94,12 +92,13 @@ tap.test('should get a car', async () => {
// ======================================= // =======================================
// close the database connection // close the database connection
// ======================================= // =======================================
tap.test('should close the database connection', async (tools) => { tap.test('close', async () => {
await testDb.mongoDb.dropDatabase(); if (mongod) {
await testDb.close();
try {
await mongod.stop(); await mongod.stop();
} catch (e) {} } else {
await testDb.mongoDb.dropDatabase();
}
await testDb.close();
}); });
tap.start({ throwOnError: true }); tap.start({ throwOnError: true });

View File

@ -85,7 +85,7 @@ export function Manager<TManager extends IManager>(managerArg?: TManager | TDela
public static get manager() { public static get manager() {
let manager: TManager; let manager: TManager;
if (!managerArg) { if (!managerArg) {
manager = this.prototype.defaultManager manager = this.prototype.defaultManager;
} else if (managerArg['db']) { } else if (managerArg['db']) {
manager = managerArg as TManager; manager = managerArg as TManager;
} else { } else {
@ -96,7 +96,7 @@ export function Manager<TManager extends IManager>(managerArg?: TManager | TDela
public get manager() { public get manager() {
let manager: TManager; let manager: TManager;
if (!managerArg) { if (!managerArg) {
manager = this.defaultManager manager = this.defaultManager;
} else if (managerArg['db']) { } else if (managerArg['db']) {
manager = managerArg as TManager; manager = managerArg as TManager;
} else { } else {
@ -171,7 +171,7 @@ export class SmartdataCollection<T> {
/** /**
* finds an object in the DbCollection * finds an object in the DbCollection
*/ */
public async findOne(filterObject: any): Promise<any> { public async findOne(filterObject: any): Promise<any> {
await this.init(); await this.init();
const cursor = this.mongoDbCollection.find(filterObject); const cursor = this.mongoDbCollection.find(filterObject);
const result = await cursor.next(); const result = await cursor.next();

View File

@ -1,7 +1,7 @@
import * as plugins from './smartdata.plugins'; import * as plugins from './smartdata.plugins';
/** /**
* a wrapper for the native mongodb cursor. Exposes better * a wrapper for the native mongodb cursor. Exposes better
*/ */
export class SmartdataDbCursor<T = any> { export class SmartdataDbCursor<T = any> {
// STATIC // STATIC
@ -9,16 +9,16 @@ 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>) { constructor(cursorArg: plugins.mongodb.FindCursor<T>) {
this.mongodbCursor = cursorArg this.mongodbCursor = cursorArg;
}; }
public async next(closeAtEnd = true) { public async next(closeAtEnd = true) {
const result = await this.mongodbCursor.next(); const result = 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: T) => Promise<any>, closeCursorAtEnd = true) {
let currentValue: T; let currentValue: T;
@ -36,4 +36,4 @@ export class SmartdataDbCursor<T = any> {
public async close() { public async close() {
await this.mongodbCursor.close(); await this.mongodbCursor.close();
} }
} }

View File

@ -165,7 +165,9 @@ 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(convertFilterForMongoDb(filterArg)); const cursor: SmartdataDbCursor<T> = await (this as any).collection.getCursor(
convertFilterForMongoDb(filterArg)
);
return cursor; return cursor;
} }
@ -179,7 +181,7 @@ export class SmartDataDbDoc<T extends TImplements, TImplements, TManager extends
forEachFunction: (itemArg: T) => Promise<any> forEachFunction: (itemArg: T) => Promise<any>
) { ) {
const cursor: SmartdataDbCursor<T> = await (this as any).getCursor(filterArg); const cursor: SmartdataDbCursor<T> = await (this as any).getCursor(filterArg);
await cursor.forEach(forEachFunction) await cursor.forEach(forEachFunction);
} }
/** /**