fastypest 1.1.0 → 1.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/core/fastypest.d.ts +10 -0
- package/dist/core/fastypest.js +56 -0
- package/dist/core/fastypest.js.map +1 -0
- package/dist/core/index.d.ts +1 -0
- package/dist/core/index.js +18 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/sql-script/index.d.ts +1 -0
- package/dist/core/sql-script/index.js +18 -0
- package/dist/core/sql-script/index.js.map +1 -0
- package/dist/core/sql-script/queries/index.d.ts +37 -0
- package/dist/core/sql-script/queries/index.js +14 -0
- package/dist/core/sql-script/queries/index.js.map +1 -0
- package/dist/core/sql-script/queries/mysql.query.json +11 -0
- package/dist/core/sql-script/queries/postgres.query.json +11 -0
- package/dist/core/sql-script/script-sql.d.ts +11 -0
- package/dist/core/sql-script/script-sql.js +25 -0
- package/dist/core/sql-script/script-sql.js.map +1 -0
- package/dist/core/sql-script/types/index.d.ts +1 -0
- package/dist/core/sql-script/types/index.js +18 -0
- package/dist/core/sql-script/types/index.js.map +1 -0
- package/dist/core/sql-script/types/query-path.d.ts +6 -0
- package/dist/core/sql-script/types/query-path.js +3 -0
- package/dist/core/sql-script/types/query-path.js.map +1 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +18 -0
- package/dist/index.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { Connection, DataSource } from "typeorm";
|
|
2
|
+
export declare class Fastypest {
|
|
3
|
+
private manager;
|
|
4
|
+
private tables;
|
|
5
|
+
private scriptSQL;
|
|
6
|
+
constructor(connection: DataSource | Connection);
|
|
7
|
+
init(): Promise<void>;
|
|
8
|
+
restoreData(): Promise<void>;
|
|
9
|
+
clearTempTables(): Promise<void>;
|
|
10
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.Fastypest = void 0;
|
|
13
|
+
const sql_script_1 = require("./sql-script");
|
|
14
|
+
class Fastypest {
|
|
15
|
+
constructor(connection) {
|
|
16
|
+
this.tables = new Set();
|
|
17
|
+
this.manager = connection.manager;
|
|
18
|
+
this.scriptSQL = new sql_script_1.ScriptSQL(connection.options.type);
|
|
19
|
+
}
|
|
20
|
+
init() {
|
|
21
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
22
|
+
yield this.manager.transaction((em) => __awaiter(this, void 0, void 0, function* () {
|
|
23
|
+
(yield em.query(this.scriptSQL.getQuery("getTables"))).map((row) => {
|
|
24
|
+
this.tables.add(row.name);
|
|
25
|
+
});
|
|
26
|
+
yield Promise.all([...this.tables].map((tableName) => __awaiter(this, void 0, void 0, function* () {
|
|
27
|
+
yield em.query(this.scriptSQL.getQuery("createTempTable", { tableName }));
|
|
28
|
+
})));
|
|
29
|
+
}));
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
restoreData() {
|
|
33
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
34
|
+
yield this.manager.transaction((em) => __awaiter(this, void 0, void 0, function* () {
|
|
35
|
+
yield em.query(this.scriptSQL.getQuery("foreignKey.disable"));
|
|
36
|
+
yield Promise.all([...this.tables].map((tableName) => __awaiter(this, void 0, void 0, function* () {
|
|
37
|
+
yield em.query(this.scriptSQL.getQuery("truncateTable", { tableName }));
|
|
38
|
+
yield em.query(this.scriptSQL.getQuery("restoreData", { tableName }));
|
|
39
|
+
})));
|
|
40
|
+
yield em.query(this.scriptSQL.getQuery("foreignKey.enable"));
|
|
41
|
+
}));
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
clearTempTables() {
|
|
45
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
46
|
+
yield this.manager.transaction((em) => __awaiter(this, void 0, void 0, function* () {
|
|
47
|
+
yield Promise.all([...this.tables].map((tableName) => __awaiter(this, void 0, void 0, function* () {
|
|
48
|
+
yield em.query(yield em.query(this.scriptSQL.getQuery("dropTempTable", { tableName })));
|
|
49
|
+
})));
|
|
50
|
+
}));
|
|
51
|
+
this.tables.clear();
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
exports.Fastypest = Fastypest;
|
|
56
|
+
//# sourceMappingURL=fastypest.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fastypest.js","sourceRoot":"","sources":["../../src/core/fastypest.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,6CAAyC;AAEzC,MAAa,SAAS;IAKpB,YAAY,UAAmC;QAHvC,WAAM,GAAgB,IAAI,GAAG,EAAE,CAAC;QAItC,IAAI,CAAC,OAAO,GAAG,UAAU,CAAC,OAAO,CAAC;QAClC,IAAI,CAAC,SAAS,GAAG,IAAI,sBAAS,CAAC,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAC1D,CAAC;IAEK,IAAI;;YACR,MAAM,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAO,EAAE,EAAE,EAAE;gBAC1C,CAAC,MAAM,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,GAAG,CACxD,CAAC,GAA2B,EAAE,EAAE;oBAC9B,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;gBAC5B,CAAC,CACF,CAAC;gBAEF,MAAM,OAAO,CAAC,GAAG,CACf,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAO,SAAS,EAAE,EAAE;oBACvC,MAAM,EAAE,CAAC,KAAK,CACZ,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,iBAAiB,EAAE,EAAE,SAAS,EAAE,CAAC,CAC1D,CAAC;gBACJ,CAAC,CAAA,CAAC,CACH,CAAC;YACJ,CAAC,CAAA,CAAC,CAAC;QACL,CAAC;KAAA;IAEK,WAAW;;YACf,MAAM,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAO,EAAE,EAAE,EAAE;gBAC1C,MAAM,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,oBAAoB,CAAC,CAAC,CAAC;gBAE9D,MAAM,OAAO,CAAC,GAAG,CACf,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAO,SAAS,EAAE,EAAE;oBACvC,MAAM,EAAE,CAAC,KAAK,CACZ,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,eAAe,EAAE,EAAE,SAAS,EAAE,CAAC,CACxD,CAAC;oBACF,MAAM,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,aAAa,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;gBACxE,CAAC,CAAA,CAAC,CACH,CAAC;gBAEF,MAAM,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,mBAAmB,CAAC,CAAC,CAAC;YAC/D,CAAC,CAAA,CAAC,CAAC;QACL,CAAC;KAAA;IAEK,eAAe;;YACnB,MAAM,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAO,EAAE,EAAE,EAAE;gBAC1C,MAAM,OAAO,CAAC,GAAG,CACf,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAO,SAAS,EAAE,EAAE;oBACvC,MAAM,EAAE,CAAC,KAAK,CACZ,MAAM,EAAE,CAAC,KAAK,CACZ,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,eAAe,EAAE,EAAE,SAAS,EAAE,CAAC,CACxD,CACF,CAAC;gBACJ,CAAC,CAAA,CAAC,CACH,CAAC;YACJ,CAAC,CAAA,CAAC,CAAC;YAEH,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;QACtB,CAAC;KAAA;CACF;AA5DD,8BA4DC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./fastypest";
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./fastypest"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,8CAA4B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./script-sql";
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./script-sql"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/core/sql-script/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,+CAA6B"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
export declare const DB_QUERIES: {
|
|
2
|
+
mysql: {
|
|
3
|
+
foreignKey: {
|
|
4
|
+
disable: string;
|
|
5
|
+
enable: string;
|
|
6
|
+
};
|
|
7
|
+
getTables: string;
|
|
8
|
+
createTempTable: string;
|
|
9
|
+
dropTempTable: string;
|
|
10
|
+
restoreData: string;
|
|
11
|
+
truncateTable: string;
|
|
12
|
+
};
|
|
13
|
+
mariadb: {
|
|
14
|
+
foreignKey: {
|
|
15
|
+
disable: string;
|
|
16
|
+
enable: string;
|
|
17
|
+
};
|
|
18
|
+
getTables: string;
|
|
19
|
+
createTempTable: string;
|
|
20
|
+
dropTempTable: string;
|
|
21
|
+
restoreData: string;
|
|
22
|
+
truncateTable: string;
|
|
23
|
+
};
|
|
24
|
+
postgres: {
|
|
25
|
+
foreignKey: {
|
|
26
|
+
disable: string;
|
|
27
|
+
enable: string;
|
|
28
|
+
};
|
|
29
|
+
getTables: string;
|
|
30
|
+
createTempTable: string;
|
|
31
|
+
dropTempTable: string;
|
|
32
|
+
restoreData: string;
|
|
33
|
+
truncateTable: string;
|
|
34
|
+
};
|
|
35
|
+
};
|
|
36
|
+
export type AllowedDataBases = keyof typeof DB_QUERIES;
|
|
37
|
+
export type Queries = (typeof DB_QUERIES)[AllowedDataBases];
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.DB_QUERIES = void 0;
|
|
7
|
+
const mysql_query_json_1 = __importDefault(require("./mysql.query.json"));
|
|
8
|
+
const postgres_query_json_1 = __importDefault(require("./postgres.query.json"));
|
|
9
|
+
exports.DB_QUERIES = {
|
|
10
|
+
mysql: mysql_query_json_1.default,
|
|
11
|
+
mariadb: mysql_query_json_1.default,
|
|
12
|
+
postgres: postgres_query_json_1.default,
|
|
13
|
+
};
|
|
14
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/core/sql-script/queries/index.ts"],"names":[],"mappings":";;;;;;AAAA,0EAA+C;AAC/C,gFAAqD;AAExC,QAAA,UAAU,GAAG;IACxB,KAAK,EAAE,0BAAa;IACpB,OAAO,EAAE,0BAAa;IACtB,QAAQ,EAAE,6BAAgB;CAC3B,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
{
|
|
2
|
+
"foreignKey": {
|
|
3
|
+
"disable": "SET FOREIGN_KEY_CHECKS=0",
|
|
4
|
+
"enable": "SET FOREIGN_KEY_CHECKS=1"
|
|
5
|
+
},
|
|
6
|
+
"getTables": "SELECT table_name AS name FROM information_schema.tables WHERE table_schema = DATABASE() AND table_type = 'BASE TABLE'",
|
|
7
|
+
"createTempTable": "CREATE TEMPORARY TABLE {{tableName}}_temp AS SELECT * FROM {{tableName}}",
|
|
8
|
+
"dropTempTable": "DROP TEMPORARY TABLE {{tableName}}_temp",
|
|
9
|
+
"restoreData": "INSERT INTO {{tableName}} SELECT * FROM {{tableName}}_temp",
|
|
10
|
+
"truncateTable": "TRUNCATE TABLE {{tableName}}"
|
|
11
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
{
|
|
2
|
+
"foreignKey": {
|
|
3
|
+
"disable": "SET CONSTRAINTS ALL DEFERRED",
|
|
4
|
+
"enable": "SET CONSTRAINTS ALL IMMEDIATE"
|
|
5
|
+
},
|
|
6
|
+
"getTables": "SELECT table_name AS name FROM information_schema.tables WHERE table_schema = CURRENT_SCHEMA() AND table_type = 'BASE TABLE'",
|
|
7
|
+
"createTempTable": "CREATE TEMPORARY TABLE {{tableName}}_temp AS SELECT * FROM {{tableName}}",
|
|
8
|
+
"dropTempTable": "DROP TABLE IF EXISTS {{tableName}}_temp",
|
|
9
|
+
"restoreData": "INSERT INTO {{tableName}} SELECT * FROM {{tableName}}_temp",
|
|
10
|
+
"truncateTable": "TRUNCATE TABLE {{tableName}}"
|
|
11
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { DataSourceOptions } from "typeorm";
|
|
2
|
+
import { Queries } from "./queries";
|
|
3
|
+
import { QueryPath } from "./types";
|
|
4
|
+
type DBTypes = DataSourceOptions["type"];
|
|
5
|
+
export declare class ScriptSQL {
|
|
6
|
+
private readonly type;
|
|
7
|
+
queries: Queries;
|
|
8
|
+
constructor(type: DBTypes);
|
|
9
|
+
getQuery(queryPath: QueryPath<Queries>, values?: Record<string, string>): string;
|
|
10
|
+
}
|
|
11
|
+
export {};
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ScriptSQL = void 0;
|
|
4
|
+
const queries_1 = require("./queries");
|
|
5
|
+
class ScriptSQL {
|
|
6
|
+
constructor(type) {
|
|
7
|
+
this.type = type;
|
|
8
|
+
if (!(this.type in queries_1.DB_QUERIES)) {
|
|
9
|
+
throw new Error(`The database type provided is not supported. Please choose from the following: ${Object.keys(queries_1.DB_QUERIES)}`);
|
|
10
|
+
}
|
|
11
|
+
this.queries = queries_1.DB_QUERIES[this.type];
|
|
12
|
+
}
|
|
13
|
+
getQuery(queryPath, values) {
|
|
14
|
+
const queryObj = queryPath
|
|
15
|
+
.split(".")
|
|
16
|
+
.reduce((obj, key) => obj[key], this.queries);
|
|
17
|
+
let queryStr = queryObj;
|
|
18
|
+
for (const key in values) {
|
|
19
|
+
queryStr = queryStr.replace(new RegExp(`{{\\s*${key}\\s*}}`, "g"), values[key]);
|
|
20
|
+
}
|
|
21
|
+
return queryStr;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
exports.ScriptSQL = ScriptSQL;
|
|
25
|
+
//# sourceMappingURL=script-sql.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"script-sql.js","sourceRoot":"","sources":["../../../src/core/sql-script/script-sql.ts"],"names":[],"mappings":";;;AACA,uCAAkE;AAKlE,MAAa,SAAS;IAEpB,YAA6B,IAAa;QAAb,SAAI,GAAJ,IAAI,CAAS;QACxC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,IAAI,oBAAU,CAAC,EAAE;YAC9B,MAAM,IAAI,KAAK,CACb,kFAAkF,MAAM,CAAC,IAAI,CAC3F,oBAAU,CACX,EAAE,CACJ,CAAC;SACH;QAED,IAAI,CAAC,OAAO,GAAG,oBAAU,CAAC,IAAI,CAAC,IAAwB,CAAC,CAAC;IAC3D,CAAC;IAED,QAAQ,CACN,SAA6B,EAC7B,MAA+B;QAE/B,MAAM,QAAQ,GAAG,SAAS;aACvB,KAAK,CAAC,GAAG,CAAC;aACV,MAAM,CAAC,CAAC,GAAQ,EAAE,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QAErD,IAAI,QAAQ,GAAG,QAAQ,CAAC;QAExB,KAAK,MAAM,GAAG,IAAI,MAAM,EAAE;YACxB,QAAQ,GAAG,QAAQ,CAAC,OAAO,CACzB,IAAI,MAAM,CAAC,SAAS,GAAG,QAAQ,EAAE,GAAG,CAAC,EACrC,MAAM,CAAC,GAAG,CAAC,CACZ,CAAC;SACH;QAED,OAAO,QAAQ,CAAC;IAClB,CAAC;CACF;AAjCD,8BAiCC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./query-path";
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./query-path"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/core/sql-script/types/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,+CAA6B"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
type JsonKeys<T> = T extends object ? {
|
|
2
|
+
[K in keyof T]-?: `${string & K}` | `${JsonKeys<T[K]> & `.${string & K}`}`;
|
|
3
|
+
}[keyof T] : "";
|
|
4
|
+
type FlattenJson<T, K = JsonKeys<T>> = K extends keyof T ? T[K] extends Record<string, any> ? `${string & K}.${FlattenJson<T[K]>}` : K : never;
|
|
5
|
+
export type QueryPath<T> = FlattenJson<T>;
|
|
6
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"query-path.js","sourceRoot":"","sources":["../../../../src/core/sql-script/types/query-path.ts"],"names":[],"mappings":""}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./core";
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./core"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,yCAAuB"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "fastypest",
|
|
3
|
-
"version": "1.1.
|
|
3
|
+
"version": "1.1.1",
|
|
4
4
|
"description": "Restores the database automatically after each test. Allows serial execution of tests without having to delete and restore the database having to stop the application",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|