@geekmidas/testkit 0.0.15 → 0.0.16
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/{Factory-D7P3bKKb.d.mts → Factory-BZ8uMoXl.d.cts} +3 -2
- package/dist/{Factory-pNV7ZQ7-.d.cts → Factory-Cmr3s3-s.d.mts} +3 -2
- package/dist/Factory-WMhTNZ9S.cjs +2 -1
- package/dist/Factory-WMhTNZ9S.cjs.map +1 -0
- package/dist/Factory-z2m01hMj.mjs +2 -1
- package/dist/Factory-z2m01hMj.mjs.map +1 -0
- package/dist/Factory.d.cts +2 -2
- package/dist/Factory.d.mts +2 -2
- package/dist/KyselyFactory-BcYkC0t2.mjs +2 -1
- package/dist/KyselyFactory-BcYkC0t2.mjs.map +1 -0
- package/dist/KyselyFactory-Cf0o2YxO.cjs +2 -1
- package/dist/KyselyFactory-Cf0o2YxO.cjs.map +1 -0
- package/dist/{KyselyFactory-72P98y5I.d.mts → KyselyFactory-Cx3sezwH.d.mts} +4 -3
- package/dist/{KyselyFactory-DLBrYWxU.d.cts → KyselyFactory-DRQ83r0o.d.cts} +4 -3
- package/dist/KyselyFactory.d.cts +3 -3
- package/dist/KyselyFactory.d.mts +3 -3
- package/dist/ObjectionFactory-8hebmnai.mjs +2 -1
- package/dist/ObjectionFactory-8hebmnai.mjs.map +1 -0
- package/dist/{ObjectionFactory-B40NQWSe.d.mts → ObjectionFactory-C-59Hjwj.d.mts} +4 -3
- package/dist/{ObjectionFactory-D3l1VuyX.d.cts → ObjectionFactory-C4X78k0B.d.cts} +4 -3
- package/dist/ObjectionFactory-CDriunkS.cjs +2 -1
- package/dist/ObjectionFactory-CDriunkS.cjs.map +1 -0
- package/dist/ObjectionFactory.d.cts +3 -3
- package/dist/ObjectionFactory.d.mts +3 -3
- package/dist/{PostgresKyselyMigrator-_6yHZigp.d.mts → PostgresKyselyMigrator-CIx3AFSR.d.mts} +3 -2
- package/dist/PostgresKyselyMigrator-CQ3aUoy_.d.cts +2 -1
- package/dist/PostgresKyselyMigrator-CfytARcA.cjs +2 -1
- package/dist/PostgresKyselyMigrator-CfytARcA.cjs.map +1 -0
- package/dist/{PostgresKyselyMigrator-Bdhl251C.mjs → PostgresKyselyMigrator-upT-hmrz.mjs} +3 -2
- package/dist/PostgresKyselyMigrator-upT-hmrz.mjs.map +1 -0
- package/dist/PostgresKyselyMigrator.d.mts +2 -2
- package/dist/PostgresKyselyMigrator.mjs +2 -2
- package/dist/PostgresMigrator-D5UkK1_K.d.cts +2 -1
- package/dist/PostgresMigrator-DFcNdCvD.cjs +2 -1
- package/dist/PostgresMigrator-DFcNdCvD.cjs.map +1 -0
- package/dist/{PostgresMigrator-BlvuQl7d.d.mts → PostgresMigrator-DQaRxoaY.d.mts} +2 -1
- package/dist/{PostgresMigrator-DxPC_gGu.mjs → PostgresMigrator-DbuJGAVy.mjs} +4 -3
- package/dist/PostgresMigrator-DbuJGAVy.mjs.map +1 -0
- package/dist/PostgresMigrator.d.mts +1 -1
- package/dist/PostgresMigrator.mjs +1 -1
- package/dist/PostgresObjectionMigrator-BG6ymgnt.cjs +2 -1
- package/dist/PostgresObjectionMigrator-BG6ymgnt.cjs.map +1 -0
- package/dist/PostgresObjectionMigrator-CZHHcCOv.d.cts +2 -1
- package/dist/{PostgresObjectionMigrator-G4h5FLvU.mjs → PostgresObjectionMigrator-DPj2pOpX.mjs} +3 -2
- package/dist/PostgresObjectionMigrator-DPj2pOpX.mjs.map +1 -0
- package/dist/{PostgresObjectionMigrator-C69n7vzr.d.mts → PostgresObjectionMigrator-D_hCcrQu.d.mts} +3 -2
- package/dist/PostgresObjectionMigrator.d.mts +2 -2
- package/dist/PostgresObjectionMigrator.mjs +2 -2
- package/dist/VitestKyselyTransactionIsolator-BxjlD1YM.mjs +2 -1
- package/dist/VitestKyselyTransactionIsolator-BxjlD1YM.mjs.map +1 -0
- package/dist/{VitestKyselyTransactionIsolator-CnxpE9cH.d.mts → VitestKyselyTransactionIsolator-COCVfvfr.d.mts} +3 -2
- package/dist/VitestKyselyTransactionIsolator-Cst3vFjb.cjs +2 -1
- package/dist/VitestKyselyTransactionIsolator-Cst3vFjb.cjs.map +1 -0
- package/dist/VitestKyselyTransactionIsolator-DYUYVEh9.d.cts +2 -1
- package/dist/VitestKyselyTransactionIsolator.d.mts +2 -2
- package/dist/VitestObjectionTransactionIsolator-BU-jXEhz.mjs +2 -1
- package/dist/VitestObjectionTransactionIsolator-BU-jXEhz.mjs.map +1 -0
- package/dist/VitestObjectionTransactionIsolator-CJ4ds5Qv.d.cts +2 -1
- package/dist/VitestObjectionTransactionIsolator-DzeF4UAq.cjs +2 -1
- package/dist/VitestObjectionTransactionIsolator-DzeF4UAq.cjs.map +1 -0
- package/dist/{VitestObjectionTransactionIsolator-DIM79dCq.d.mts → VitestObjectionTransactionIsolator-b973r9O1.d.mts} +3 -2
- package/dist/VitestObjectionTransactionIsolator.d.mts +2 -2
- package/dist/VitestTransactionIsolator-BQ5FpLtC.cjs +2 -1
- package/dist/VitestTransactionIsolator-BQ5FpLtC.cjs.map +1 -0
- package/dist/{VitestTransactionIsolator-zdyiS_SY.d.mts → VitestTransactionIsolator-CsfJBxcb.d.mts} +2 -1
- package/dist/VitestTransactionIsolator-CskiiJbW.mjs +2 -1
- package/dist/VitestTransactionIsolator-CskiiJbW.mjs.map +1 -0
- package/dist/VitestTransactionIsolator-DdLNODZg.d.cts +2 -1
- package/dist/VitestTransactionIsolator.d.mts +1 -1
- package/dist/aws.cjs +126 -0
- package/dist/aws.cjs.map +1 -0
- package/dist/aws.d.cts +22 -0
- package/dist/aws.d.mts +22 -0
- package/dist/aws.mjs +123 -0
- package/dist/aws.mjs.map +1 -0
- package/dist/directory-B-Ozljzk.mjs +22 -0
- package/dist/directory-B-Ozljzk.mjs.map +1 -0
- package/dist/directory-B4oYx02C.d.mts +12 -0
- package/dist/directory-BUcnztHI.d.cts +12 -0
- package/dist/directory-BVC8g7cX.cjs +28 -0
- package/dist/directory-BVC8g7cX.cjs.map +1 -0
- package/dist/faker-B14IEMIN.cjs +2 -1
- package/dist/faker-B14IEMIN.cjs.map +1 -0
- package/dist/faker-BGKYFoCT.mjs +2 -1
- package/dist/faker-BGKYFoCT.mjs.map +1 -0
- package/dist/{faker-BSH1EMtg.d.cts → faker-Cg76aFNO.d.cts} +4 -3
- package/dist/{faker-C-Iuk_R1.d.mts → faker-DHh7xs4u.d.mts} +4 -3
- package/dist/faker.d.cts +1 -1
- package/dist/faker.d.mts +1 -1
- package/dist/helpers.cjs +48 -2
- package/dist/helpers.cjs.map +1 -0
- package/dist/helpers.d.cts +2 -1
- package/dist/helpers.d.mts +2 -1
- package/dist/helpers.mjs +47 -2
- package/dist/helpers.mjs.map +1 -0
- package/dist/kysely.cjs +65 -2
- package/dist/kysely.cjs.map +1 -0
- package/dist/kysely.d.cts +5 -4
- package/dist/kysely.d.mts +9 -8
- package/dist/kysely.mjs +67 -4
- package/dist/kysely.mjs.map +1 -0
- package/dist/logger.cjs +23 -0
- package/dist/logger.cjs.map +1 -0
- package/dist/logger.d.cts +11 -0
- package/dist/logger.d.mts +11 -0
- package/dist/logger.mjs +22 -0
- package/dist/logger.mjs.map +1 -0
- package/dist/objection.cjs +80 -2
- package/dist/objection.cjs.map +1 -0
- package/dist/objection.d.cts +5 -4
- package/dist/objection.d.mts +9 -8
- package/dist/objection.mjs +82 -4
- package/dist/objection.mjs.map +1 -0
- package/dist/os/directory.cjs +3 -0
- package/dist/os/directory.d.cts +2 -0
- package/dist/os/directory.d.mts +2 -0
- package/dist/os/directory.mjs +3 -0
- package/dist/os/index.cjs +3 -0
- package/dist/os/index.d.cts +2 -0
- package/dist/os/index.d.mts +2 -0
- package/dist/os/index.mjs +3 -0
- package/dist/timer.cjs +9 -0
- package/dist/timer.cjs.map +1 -0
- package/dist/timer.d.cts +5 -0
- package/dist/timer.d.mts +5 -0
- package/dist/timer.mjs +8 -0
- package/dist/timer.mjs.map +1 -0
- package/package.json +24 -2
- package/src/aws.ts +131 -0
- package/src/logger.ts +18 -0
- package/src/os/directory.ts +21 -0
- package/src/os/index.ts +1 -0
- package/src/timer.ts +3 -0
- package/dist/__tests__/Factory.spec.cjs +0 -139
- package/dist/__tests__/Factory.spec.d.cts +0 -1
- package/dist/__tests__/Factory.spec.d.mts +0 -1
- package/dist/__tests__/Factory.spec.mjs +0 -138
- package/dist/__tests__/KyselyFactory.spec.cjs +0 -235
- package/dist/__tests__/KyselyFactory.spec.d.cts +0 -1
- package/dist/__tests__/KyselyFactory.spec.d.mts +0 -1
- package/dist/__tests__/KyselyFactory.spec.mjs +0 -234
- package/dist/__tests__/ObjectionFactory.spec.cjs +0 -340
- package/dist/__tests__/ObjectionFactory.spec.d.cts +0 -1
- package/dist/__tests__/ObjectionFactory.spec.d.mts +0 -1
- package/dist/__tests__/ObjectionFactory.spec.mjs +0 -339
- package/dist/__tests__/PostgresKyselyMigrator.spec.cjs +0 -397
- package/dist/__tests__/PostgresKyselyMigrator.spec.d.cts +0 -1
- package/dist/__tests__/PostgresKyselyMigrator.spec.d.mts +0 -1
- package/dist/__tests__/PostgresKyselyMigrator.spec.mjs +0 -396
- package/dist/__tests__/PostgresMigrator.spec.cjs +0 -256
- package/dist/__tests__/PostgresMigrator.spec.d.cts +0 -1
- package/dist/__tests__/PostgresMigrator.spec.d.mts +0 -1
- package/dist/__tests__/PostgresMigrator.spec.mjs +0 -255
- package/dist/__tests__/PostgresObjectionMigrator.spec.cjs +0 -432
- package/dist/__tests__/PostgresObjectionMigrator.spec.d.cts +0 -1
- package/dist/__tests__/PostgresObjectionMigrator.spec.d.mts +0 -1
- package/dist/__tests__/PostgresObjectionMigrator.spec.mjs +0 -431
- package/dist/__tests__/VitestObjectionTransactionIsolator.spec.cjs +0 -122
- package/dist/__tests__/VitestObjectionTransactionIsolator.spec.d.cts +0 -1
- package/dist/__tests__/VitestObjectionTransactionIsolator.spec.d.mts +0 -1
- package/dist/__tests__/VitestObjectionTransactionIsolator.spec.mjs +0 -121
- package/dist/__tests__/faker.spec.cjs +0 -115
- package/dist/__tests__/faker.spec.d.cts +0 -1
- package/dist/__tests__/faker.spec.d.mts +0 -1
- package/dist/__tests__/faker.spec.mjs +0 -114
- package/dist/__tests__/integration.spec.cjs +0 -282
- package/dist/__tests__/integration.spec.d.cts +0 -1
- package/dist/__tests__/integration.spec.d.mts +0 -1
- package/dist/__tests__/integration.spec.mjs +0 -281
- package/dist/helpers-B4TXg3Wp.mjs +0 -86
- package/dist/helpers-Bf0nXhbu.cjs +0 -116
- package/dist/helpers-BuPmgzyQ.mjs +0 -47
- package/dist/helpers-nEUtQ7eo.cjs +0 -53
- package/dist/kysely-C3h7kitU.mjs +0 -67
- package/dist/kysely-VU3MwvMD.cjs +0 -72
- package/dist/objection-BI7F86qf.mjs +0 -82
- package/dist/objection-BpLv_ZfC.cjs +0 -87
|
@@ -1,139 +0,0 @@
|
|
|
1
|
-
const require_chunk = require('../chunk-CUT6urMc.cjs');
|
|
2
|
-
const require_Factory = require('../Factory-WMhTNZ9S.cjs');
|
|
3
|
-
const vitest = require_chunk.__toESM(require("vitest"));
|
|
4
|
-
|
|
5
|
-
//#region src/__tests__/Factory.spec.ts
|
|
6
|
-
var TestFactory = class extends require_Factory.Factory {
|
|
7
|
-
async insert(builderName, attrs) {
|
|
8
|
-
return Promise.resolve({
|
|
9
|
-
id: 1,
|
|
10
|
-
...attrs
|
|
11
|
-
});
|
|
12
|
-
}
|
|
13
|
-
async insertMany(count, builderName, attrs) {
|
|
14
|
-
const results = [];
|
|
15
|
-
for (let i = 0; i < count; i++) {
|
|
16
|
-
const newAttrs = typeof attrs === "function" ? attrs(i) : attrs;
|
|
17
|
-
results.push(await this.insert(builderName, newAttrs));
|
|
18
|
-
}
|
|
19
|
-
return results;
|
|
20
|
-
}
|
|
21
|
-
seed(seedName, attrs) {
|
|
22
|
-
return Promise.resolve({
|
|
23
|
-
seedResult: true,
|
|
24
|
-
...attrs
|
|
25
|
-
});
|
|
26
|
-
}
|
|
27
|
-
};
|
|
28
|
-
(0, vitest.describe)("Factory", () => {
|
|
29
|
-
(0, vitest.describe)("abstract class functionality", () => {
|
|
30
|
-
(0, vitest.it)("should be instantiable through concrete implementation", () => {
|
|
31
|
-
const factory = new TestFactory();
|
|
32
|
-
(0, vitest.expect)(factory).toBeInstanceOf(require_Factory.Factory);
|
|
33
|
-
(0, vitest.expect)(factory).toBeInstanceOf(TestFactory);
|
|
34
|
-
});
|
|
35
|
-
(0, vitest.it)("should have abstract methods defined", () => {
|
|
36
|
-
const factory = new TestFactory();
|
|
37
|
-
(0, vitest.expect)(typeof factory.insert).toBe("function");
|
|
38
|
-
(0, vitest.expect)(typeof factory.insertMany).toBe("function");
|
|
39
|
-
(0, vitest.expect)(typeof factory.seed).toBe("function");
|
|
40
|
-
});
|
|
41
|
-
});
|
|
42
|
-
(0, vitest.describe)("createSeed static method", () => {
|
|
43
|
-
(0, vitest.it)("should return the seed function unchanged", () => {
|
|
44
|
-
const seedFn = async (attrs, factory, db) => {
|
|
45
|
-
return {
|
|
46
|
-
id: 1,
|
|
47
|
-
name: "test"
|
|
48
|
-
};
|
|
49
|
-
};
|
|
50
|
-
const result = require_Factory.Factory.createSeed(seedFn);
|
|
51
|
-
(0, vitest.expect)(result).toBe(seedFn);
|
|
52
|
-
(0, vitest.expect)(typeof result).toBe("function");
|
|
53
|
-
});
|
|
54
|
-
(0, vitest.it)("should work with different seed function signatures", () => {
|
|
55
|
-
const simpleSeed = () => Promise.resolve({ simple: true });
|
|
56
|
-
const complexSeed = async (attrs, factory, db) => {
|
|
57
|
-
return {
|
|
58
|
-
name: attrs.name,
|
|
59
|
-
created: true
|
|
60
|
-
};
|
|
61
|
-
};
|
|
62
|
-
const result1 = require_Factory.Factory.createSeed(simpleSeed);
|
|
63
|
-
const result2 = require_Factory.Factory.createSeed(complexSeed);
|
|
64
|
-
(0, vitest.expect)(result1).toBe(simpleSeed);
|
|
65
|
-
(0, vitest.expect)(result2).toBe(complexSeed);
|
|
66
|
-
});
|
|
67
|
-
});
|
|
68
|
-
(0, vitest.describe)("concrete implementation behavior", () => {
|
|
69
|
-
let factory;
|
|
70
|
-
(0, vitest.beforeEach)(() => {
|
|
71
|
-
factory = new TestFactory();
|
|
72
|
-
});
|
|
73
|
-
(0, vitest.it)("should implement insert method", async () => {
|
|
74
|
-
const result = await factory.insert("testBuilder", { name: "test" });
|
|
75
|
-
(0, vitest.expect)(result).toEqual({
|
|
76
|
-
id: 1,
|
|
77
|
-
name: "test"
|
|
78
|
-
});
|
|
79
|
-
});
|
|
80
|
-
(0, vitest.it)("should implement insertMany method", async () => {
|
|
81
|
-
const results = await factory.insertMany(3, "testBuilder", { name: "test" });
|
|
82
|
-
(0, vitest.expect)(results).toHaveLength(3);
|
|
83
|
-
(0, vitest.expect)(results[0]).toEqual({
|
|
84
|
-
id: 1,
|
|
85
|
-
name: "test"
|
|
86
|
-
});
|
|
87
|
-
});
|
|
88
|
-
(0, vitest.it)("should implement insertMany with function attributes", async () => {
|
|
89
|
-
const results = await factory.insertMany(2, "testBuilder", (idx) => ({ name: `test${idx}` }));
|
|
90
|
-
(0, vitest.expect)(results).toHaveLength(2);
|
|
91
|
-
(0, vitest.expect)(results[0]).toEqual({
|
|
92
|
-
id: 1,
|
|
93
|
-
name: "test0"
|
|
94
|
-
});
|
|
95
|
-
(0, vitest.expect)(results[1]).toEqual({
|
|
96
|
-
id: 1,
|
|
97
|
-
name: "test1"
|
|
98
|
-
});
|
|
99
|
-
});
|
|
100
|
-
(0, vitest.it)("should implement seed method", async () => {
|
|
101
|
-
const result = await factory.seed("testSeed", { custom: "value" });
|
|
102
|
-
(0, vitest.expect)(result).toEqual({
|
|
103
|
-
seedResult: true,
|
|
104
|
-
custom: "value"
|
|
105
|
-
});
|
|
106
|
-
});
|
|
107
|
-
});
|
|
108
|
-
(0, vitest.describe)("type definitions", () => {
|
|
109
|
-
(0, vitest.it)("should properly type MixedFactoryBuilder", () => {
|
|
110
|
-
const syncBuilder = (attrs, factory, db) => ({ sync: true });
|
|
111
|
-
const asyncBuilder = async (attrs, factory, db) => ({ async: true });
|
|
112
|
-
(0, vitest.expect)(typeof syncBuilder).toBe("function");
|
|
113
|
-
(0, vitest.expect)(typeof asyncBuilder).toBe("function");
|
|
114
|
-
});
|
|
115
|
-
(0, vitest.it)("should properly type FactorySeed", () => {
|
|
116
|
-
const seed = async (attrs, factory, db) => ({ seeded: true });
|
|
117
|
-
(0, vitest.expect)(typeof seed).toBe("function");
|
|
118
|
-
});
|
|
119
|
-
});
|
|
120
|
-
});
|
|
121
|
-
(0, vitest.describe)("Factory types", () => {
|
|
122
|
-
(0, vitest.it)("should export MixedFactoryBuilder type", () => {
|
|
123
|
-
const builder = (attrs, factory, db) => {
|
|
124
|
-
return {
|
|
125
|
-
id: 1,
|
|
126
|
-
name: attrs.name
|
|
127
|
-
};
|
|
128
|
-
};
|
|
129
|
-
(0, vitest.expect)(typeof builder).toBe("function");
|
|
130
|
-
});
|
|
131
|
-
(0, vitest.it)("should export FactorySeed type", () => {
|
|
132
|
-
const seed = async (attrs, factory, db) => {
|
|
133
|
-
return { created: attrs.count };
|
|
134
|
-
};
|
|
135
|
-
(0, vitest.expect)(typeof seed).toBe("function");
|
|
136
|
-
});
|
|
137
|
-
});
|
|
138
|
-
|
|
139
|
-
//#endregion
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export { };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export { };
|
|
@@ -1,138 +0,0 @@
|
|
|
1
|
-
import { Factory } from "../Factory-z2m01hMj.mjs";
|
|
2
|
-
import { beforeEach, describe, expect, it } from "vitest";
|
|
3
|
-
|
|
4
|
-
//#region src/__tests__/Factory.spec.ts
|
|
5
|
-
var TestFactory = class extends Factory {
|
|
6
|
-
async insert(builderName, attrs) {
|
|
7
|
-
return Promise.resolve({
|
|
8
|
-
id: 1,
|
|
9
|
-
...attrs
|
|
10
|
-
});
|
|
11
|
-
}
|
|
12
|
-
async insertMany(count, builderName, attrs) {
|
|
13
|
-
const results = [];
|
|
14
|
-
for (let i = 0; i < count; i++) {
|
|
15
|
-
const newAttrs = typeof attrs === "function" ? attrs(i) : attrs;
|
|
16
|
-
results.push(await this.insert(builderName, newAttrs));
|
|
17
|
-
}
|
|
18
|
-
return results;
|
|
19
|
-
}
|
|
20
|
-
seed(seedName, attrs) {
|
|
21
|
-
return Promise.resolve({
|
|
22
|
-
seedResult: true,
|
|
23
|
-
...attrs
|
|
24
|
-
});
|
|
25
|
-
}
|
|
26
|
-
};
|
|
27
|
-
describe("Factory", () => {
|
|
28
|
-
describe("abstract class functionality", () => {
|
|
29
|
-
it("should be instantiable through concrete implementation", () => {
|
|
30
|
-
const factory = new TestFactory();
|
|
31
|
-
expect(factory).toBeInstanceOf(Factory);
|
|
32
|
-
expect(factory).toBeInstanceOf(TestFactory);
|
|
33
|
-
});
|
|
34
|
-
it("should have abstract methods defined", () => {
|
|
35
|
-
const factory = new TestFactory();
|
|
36
|
-
expect(typeof factory.insert).toBe("function");
|
|
37
|
-
expect(typeof factory.insertMany).toBe("function");
|
|
38
|
-
expect(typeof factory.seed).toBe("function");
|
|
39
|
-
});
|
|
40
|
-
});
|
|
41
|
-
describe("createSeed static method", () => {
|
|
42
|
-
it("should return the seed function unchanged", () => {
|
|
43
|
-
const seedFn = async (attrs, factory, db) => {
|
|
44
|
-
return {
|
|
45
|
-
id: 1,
|
|
46
|
-
name: "test"
|
|
47
|
-
};
|
|
48
|
-
};
|
|
49
|
-
const result = Factory.createSeed(seedFn);
|
|
50
|
-
expect(result).toBe(seedFn);
|
|
51
|
-
expect(typeof result).toBe("function");
|
|
52
|
-
});
|
|
53
|
-
it("should work with different seed function signatures", () => {
|
|
54
|
-
const simpleSeed = () => Promise.resolve({ simple: true });
|
|
55
|
-
const complexSeed = async (attrs, factory, db) => {
|
|
56
|
-
return {
|
|
57
|
-
name: attrs.name,
|
|
58
|
-
created: true
|
|
59
|
-
};
|
|
60
|
-
};
|
|
61
|
-
const result1 = Factory.createSeed(simpleSeed);
|
|
62
|
-
const result2 = Factory.createSeed(complexSeed);
|
|
63
|
-
expect(result1).toBe(simpleSeed);
|
|
64
|
-
expect(result2).toBe(complexSeed);
|
|
65
|
-
});
|
|
66
|
-
});
|
|
67
|
-
describe("concrete implementation behavior", () => {
|
|
68
|
-
let factory;
|
|
69
|
-
beforeEach(() => {
|
|
70
|
-
factory = new TestFactory();
|
|
71
|
-
});
|
|
72
|
-
it("should implement insert method", async () => {
|
|
73
|
-
const result = await factory.insert("testBuilder", { name: "test" });
|
|
74
|
-
expect(result).toEqual({
|
|
75
|
-
id: 1,
|
|
76
|
-
name: "test"
|
|
77
|
-
});
|
|
78
|
-
});
|
|
79
|
-
it("should implement insertMany method", async () => {
|
|
80
|
-
const results = await factory.insertMany(3, "testBuilder", { name: "test" });
|
|
81
|
-
expect(results).toHaveLength(3);
|
|
82
|
-
expect(results[0]).toEqual({
|
|
83
|
-
id: 1,
|
|
84
|
-
name: "test"
|
|
85
|
-
});
|
|
86
|
-
});
|
|
87
|
-
it("should implement insertMany with function attributes", async () => {
|
|
88
|
-
const results = await factory.insertMany(2, "testBuilder", (idx) => ({ name: `test${idx}` }));
|
|
89
|
-
expect(results).toHaveLength(2);
|
|
90
|
-
expect(results[0]).toEqual({
|
|
91
|
-
id: 1,
|
|
92
|
-
name: "test0"
|
|
93
|
-
});
|
|
94
|
-
expect(results[1]).toEqual({
|
|
95
|
-
id: 1,
|
|
96
|
-
name: "test1"
|
|
97
|
-
});
|
|
98
|
-
});
|
|
99
|
-
it("should implement seed method", async () => {
|
|
100
|
-
const result = await factory.seed("testSeed", { custom: "value" });
|
|
101
|
-
expect(result).toEqual({
|
|
102
|
-
seedResult: true,
|
|
103
|
-
custom: "value"
|
|
104
|
-
});
|
|
105
|
-
});
|
|
106
|
-
});
|
|
107
|
-
describe("type definitions", () => {
|
|
108
|
-
it("should properly type MixedFactoryBuilder", () => {
|
|
109
|
-
const syncBuilder = (attrs, factory, db) => ({ sync: true });
|
|
110
|
-
const asyncBuilder = async (attrs, factory, db) => ({ async: true });
|
|
111
|
-
expect(typeof syncBuilder).toBe("function");
|
|
112
|
-
expect(typeof asyncBuilder).toBe("function");
|
|
113
|
-
});
|
|
114
|
-
it("should properly type FactorySeed", () => {
|
|
115
|
-
const seed = async (attrs, factory, db) => ({ seeded: true });
|
|
116
|
-
expect(typeof seed).toBe("function");
|
|
117
|
-
});
|
|
118
|
-
});
|
|
119
|
-
});
|
|
120
|
-
describe("Factory types", () => {
|
|
121
|
-
it("should export MixedFactoryBuilder type", () => {
|
|
122
|
-
const builder = (attrs, factory, db) => {
|
|
123
|
-
return {
|
|
124
|
-
id: 1,
|
|
125
|
-
name: attrs.name
|
|
126
|
-
};
|
|
127
|
-
};
|
|
128
|
-
expect(typeof builder).toBe("function");
|
|
129
|
-
});
|
|
130
|
-
it("should export FactorySeed type", () => {
|
|
131
|
-
const seed = async (attrs, factory, db) => {
|
|
132
|
-
return { created: attrs.count };
|
|
133
|
-
};
|
|
134
|
-
expect(typeof seed).toBe("function");
|
|
135
|
-
});
|
|
136
|
-
});
|
|
137
|
-
|
|
138
|
-
//#endregion
|
|
@@ -1,235 +0,0 @@
|
|
|
1
|
-
const require_chunk = require('../chunk-CUT6urMc.cjs');
|
|
2
|
-
require('../Factory-WMhTNZ9S.cjs');
|
|
3
|
-
require('../faker-B14IEMIN.cjs');
|
|
4
|
-
const require_KyselyFactory = require('../KyselyFactory-Cf0o2YxO.cjs');
|
|
5
|
-
require('../PostgresMigrator-DFcNdCvD.cjs');
|
|
6
|
-
require('../PostgresKyselyMigrator-CfytARcA.cjs');
|
|
7
|
-
require('../VitestTransactionIsolator-BQ5FpLtC.cjs');
|
|
8
|
-
require('../VitestKyselyTransactionIsolator-Cst3vFjb.cjs');
|
|
9
|
-
const require_helpers = require('../helpers-nEUtQ7eo.cjs');
|
|
10
|
-
const require_kysely = require('../kysely-VU3MwvMD.cjs');
|
|
11
|
-
const require_helpers$1 = require('../helpers-Bf0nXhbu.cjs');
|
|
12
|
-
const pg = require_chunk.__toESM(require("pg"));
|
|
13
|
-
const vitest = require_chunk.__toESM(require("vitest"));
|
|
14
|
-
|
|
15
|
-
//#region src/__tests__/KyselyFactory.spec.ts
|
|
16
|
-
const db = () => require_helpers.createKyselyDb(require_helpers$1.TEST_DATABASE_CONFIG);
|
|
17
|
-
const itWithTransaction = require_kysely.wrapVitestKyselyTransaction(vitest.it, db, require_helpers$1.createTestTables);
|
|
18
|
-
const int8TypeId = 20;
|
|
19
|
-
pg.default.types.setTypeParser(int8TypeId, (val) => {
|
|
20
|
-
return parseInt(val, 10);
|
|
21
|
-
});
|
|
22
|
-
(0, vitest.describe)("KyselyFactory", () => {
|
|
23
|
-
(0, vitest.describe)("KyselyFactory.insert", () => {
|
|
24
|
-
itWithTransaction("should insert a record with defaults", async ({ trx }) => {
|
|
25
|
-
const userBuilder = require_KyselyFactory.KyselyFactory.createBuilder("users", async (attrs) => ({
|
|
26
|
-
name: "John Doe",
|
|
27
|
-
email: `user${Date.now()}@example.com`,
|
|
28
|
-
createdAt: /* @__PURE__ */ new Date()
|
|
29
|
-
}));
|
|
30
|
-
const builders = { user: userBuilder };
|
|
31
|
-
const factory = new require_KyselyFactory.KyselyFactory(builders, {}, trx);
|
|
32
|
-
const user = await factory.insert("user");
|
|
33
|
-
(0, vitest.expect)(user).toBeDefined();
|
|
34
|
-
(0, vitest.expect)(user.id).toBeDefined();
|
|
35
|
-
(0, vitest.expect)(user.name).toBe("John Doe");
|
|
36
|
-
(0, vitest.expect)(user.email).toContain("user");
|
|
37
|
-
(0, vitest.expect)(user.email).toContain("@example.com");
|
|
38
|
-
(0, vitest.expect)(user.createdAt).toBeInstanceOf(Date);
|
|
39
|
-
});
|
|
40
|
-
itWithTransaction("should override defaults with provided attributes", async ({ trx }) => {
|
|
41
|
-
const userBuilder = require_KyselyFactory.KyselyFactory.createBuilder("users", async (attrs) => ({
|
|
42
|
-
name: "John Doe",
|
|
43
|
-
email: `user${Date.now()}@example.com`,
|
|
44
|
-
createdAt: /* @__PURE__ */ new Date()
|
|
45
|
-
}));
|
|
46
|
-
const builders = { user: userBuilder };
|
|
47
|
-
const factory = new require_KyselyFactory.KyselyFactory(builders, {}, trx);
|
|
48
|
-
const customEmail = "custom@test.com";
|
|
49
|
-
const customName = "Jane Smith";
|
|
50
|
-
const user = await factory.insert("user", {
|
|
51
|
-
email: customEmail,
|
|
52
|
-
name: customName
|
|
53
|
-
});
|
|
54
|
-
(0, vitest.expect)(user.name).toBe(customName);
|
|
55
|
-
(0, vitest.expect)(user.email).toBe(customEmail);
|
|
56
|
-
});
|
|
57
|
-
itWithTransaction("should handle relations", async ({ trx }) => {
|
|
58
|
-
const userBuilder = require_KyselyFactory.KyselyFactory.createBuilder("users", async (attrs) => ({
|
|
59
|
-
name: "John Doe",
|
|
60
|
-
email: `user${Date.now()}@example.com`,
|
|
61
|
-
createdAt: /* @__PURE__ */ new Date()
|
|
62
|
-
}));
|
|
63
|
-
const postBuilder = require_KyselyFactory.KyselyFactory.createBuilder("posts", async (attrs, factory$1) => {
|
|
64
|
-
if (!attrs.userId) {
|
|
65
|
-
const user = await factory$1.insert("user");
|
|
66
|
-
return {
|
|
67
|
-
title: "Default Post",
|
|
68
|
-
content: "Default content",
|
|
69
|
-
userId: user.id,
|
|
70
|
-
createdAt: /* @__PURE__ */ new Date()
|
|
71
|
-
};
|
|
72
|
-
}
|
|
73
|
-
return {
|
|
74
|
-
title: "Default Post",
|
|
75
|
-
content: "Default content",
|
|
76
|
-
createdAt: /* @__PURE__ */ new Date()
|
|
77
|
-
};
|
|
78
|
-
});
|
|
79
|
-
const builders = {
|
|
80
|
-
user: userBuilder,
|
|
81
|
-
post: postBuilder
|
|
82
|
-
};
|
|
83
|
-
const factory = new require_KyselyFactory.KyselyFactory(builders, {}, trx);
|
|
84
|
-
const post = await factory.insert("post", { title: "Test Post" });
|
|
85
|
-
(0, vitest.expect)(post).toBeDefined();
|
|
86
|
-
(0, vitest.expect)(post.title).toBe("Test Post");
|
|
87
|
-
(0, vitest.expect)(post.userId).toBeDefined();
|
|
88
|
-
(0, vitest.expect)(typeof post.userId).toBe("number");
|
|
89
|
-
});
|
|
90
|
-
itWithTransaction("should throw error for non-existent builder", async ({ trx }) => {
|
|
91
|
-
const factory = new require_KyselyFactory.KyselyFactory({}, {}, trx);
|
|
92
|
-
await (0, vitest.expect)(factory.insert("nonExistent")).rejects.toThrow("Factory \"nonExistent\" does not exist");
|
|
93
|
-
});
|
|
94
|
-
});
|
|
95
|
-
(0, vitest.describe)("KyselyFactory.insertMany", () => {
|
|
96
|
-
itWithTransaction("should insert multiple records with same attributes", async ({ trx }) => {
|
|
97
|
-
const userBuilder = require_KyselyFactory.KyselyFactory.createBuilder("users", async (attrs) => ({
|
|
98
|
-
name: "John Doe",
|
|
99
|
-
email: `user${Date.now()}-${Math.random()}@example.com`,
|
|
100
|
-
createdAt: /* @__PURE__ */ new Date()
|
|
101
|
-
}));
|
|
102
|
-
const builders = { user: userBuilder };
|
|
103
|
-
const factory = new require_KyselyFactory.KyselyFactory(builders, {}, trx);
|
|
104
|
-
const users = await factory.insertMany(3, "user");
|
|
105
|
-
(0, vitest.expect)(users).toHaveLength(3);
|
|
106
|
-
users.forEach((user, index) => {
|
|
107
|
-
(0, vitest.expect)(user.id).toBeDefined();
|
|
108
|
-
(0, vitest.expect)(user.name).toBe("John Doe");
|
|
109
|
-
(0, vitest.expect)(user.email).toContain("@example.com");
|
|
110
|
-
});
|
|
111
|
-
});
|
|
112
|
-
itWithTransaction("should insert multiple records with dynamic attributes", async ({ trx }) => {
|
|
113
|
-
const userBuilder = require_KyselyFactory.KyselyFactory.createBuilder("users", async (attrs) => ({
|
|
114
|
-
email: `user${Date.now()}-${Math.random()}@example.com`,
|
|
115
|
-
createdAt: /* @__PURE__ */ new Date()
|
|
116
|
-
}));
|
|
117
|
-
const builders = { user: userBuilder };
|
|
118
|
-
const factory = new require_KyselyFactory.KyselyFactory(builders, {}, trx);
|
|
119
|
-
const users = await factory.insertMany(3, "user", (idx) => ({ name: `User ${idx}` }));
|
|
120
|
-
(0, vitest.expect)(users).toHaveLength(3);
|
|
121
|
-
users.forEach((user, index) => {
|
|
122
|
-
(0, vitest.expect)(user.name).toBe(`User ${index}`);
|
|
123
|
-
});
|
|
124
|
-
});
|
|
125
|
-
itWithTransaction("should throw error for non-existent builder", async ({ trx }) => {
|
|
126
|
-
const factory = new require_KyselyFactory.KyselyFactory({}, {}, trx);
|
|
127
|
-
await (0, vitest.expect)(factory.insertMany(2, "nonExistent")).rejects.toThrow("Builder \"nonExistent\" is not registered");
|
|
128
|
-
});
|
|
129
|
-
});
|
|
130
|
-
(0, vitest.describe)("KyselyFactory.createBuilder", () => {
|
|
131
|
-
itWithTransaction("should work with async defaults", async ({ trx }) => {
|
|
132
|
-
let counter = 0;
|
|
133
|
-
const userBuilder = require_KyselyFactory.KyselyFactory.createBuilder("users", async (attrs) => {
|
|
134
|
-
await new Promise((resolve) => setTimeout(resolve, 10));
|
|
135
|
-
counter++;
|
|
136
|
-
return {
|
|
137
|
-
name: `Async User ${counter}`,
|
|
138
|
-
email: `user${counter}@example.com`,
|
|
139
|
-
createdAt: /* @__PURE__ */ new Date()
|
|
140
|
-
};
|
|
141
|
-
});
|
|
142
|
-
const builders = { user: userBuilder };
|
|
143
|
-
const factory = new require_KyselyFactory.KyselyFactory(builders, {}, trx);
|
|
144
|
-
const user1 = await factory.insert("user");
|
|
145
|
-
const user2 = await factory.insert("user");
|
|
146
|
-
(0, vitest.expect)(user1.name).toBe("Async User 1");
|
|
147
|
-
(0, vitest.expect)(user2.name).toBe("Async User 2");
|
|
148
|
-
});
|
|
149
|
-
});
|
|
150
|
-
(0, vitest.describe)("KyselyFactory.seed", () => {
|
|
151
|
-
itWithTransaction("should execute seed functions", async ({ trx }) => {
|
|
152
|
-
const userBuilder = require_KyselyFactory.KyselyFactory.createBuilder("users", async (attrs) => ({
|
|
153
|
-
name: "John Doe",
|
|
154
|
-
email: `user${Date.now()}@example.com`,
|
|
155
|
-
createdAt: /* @__PURE__ */ new Date()
|
|
156
|
-
}));
|
|
157
|
-
const builders = { user: userBuilder };
|
|
158
|
-
const seeds = { createAdminUser: require_KyselyFactory.KyselyFactory.createSeed(async (attrs, factory$1, db$1) => {
|
|
159
|
-
return await factory$1.insert("user", {
|
|
160
|
-
name: attrs.name || "Admin User",
|
|
161
|
-
email: "admin@example.com"
|
|
162
|
-
});
|
|
163
|
-
}) };
|
|
164
|
-
const factory = new require_KyselyFactory.KyselyFactory(builders, seeds, trx);
|
|
165
|
-
const adminUser = await factory.seed("createAdminUser");
|
|
166
|
-
(0, vitest.expect)(adminUser).toBeDefined();
|
|
167
|
-
(0, vitest.expect)(adminUser.name).toBe("Admin User");
|
|
168
|
-
(0, vitest.expect)(adminUser.email).toBe("admin@example.com");
|
|
169
|
-
});
|
|
170
|
-
itWithTransaction("should pass attributes to seed functions", async ({ trx }) => {
|
|
171
|
-
const userBuilder = require_KyselyFactory.KyselyFactory.createBuilder("users", async (attrs) => ({
|
|
172
|
-
name: "John Doe",
|
|
173
|
-
email: `user${Date.now()}@example.com`,
|
|
174
|
-
createdAt: /* @__PURE__ */ new Date()
|
|
175
|
-
}));
|
|
176
|
-
const builders = { user: userBuilder };
|
|
177
|
-
const seeds = { createCustomUser: require_KyselyFactory.KyselyFactory.createSeed(async (attrs, factory$1, db$1) => {
|
|
178
|
-
return await factory$1.insert("user", attrs);
|
|
179
|
-
}) };
|
|
180
|
-
const factory = new require_KyselyFactory.KyselyFactory(builders, seeds, trx);
|
|
181
|
-
const customUser = await factory.seed("createCustomUser", {
|
|
182
|
-
name: "Custom User",
|
|
183
|
-
email: "custom@test.com"
|
|
184
|
-
});
|
|
185
|
-
(0, vitest.expect)(customUser.name).toBe("Custom User");
|
|
186
|
-
(0, vitest.expect)(customUser.email).toBe("custom@test.com");
|
|
187
|
-
});
|
|
188
|
-
itWithTransaction("should throw error for non-existent seed", async ({ trx }) => {
|
|
189
|
-
const factory = new require_KyselyFactory.KyselyFactory({}, {}, trx);
|
|
190
|
-
(0, vitest.expect)(() => factory.seed("nonExistent")).toThrow("Seed \"nonExistent\" is not registered");
|
|
191
|
-
});
|
|
192
|
-
});
|
|
193
|
-
(0, vitest.describe)("Factory integration", () => {
|
|
194
|
-
itWithTransaction("should work with controlled transactions", async ({ trx }) => {
|
|
195
|
-
const userBuilder = require_KyselyFactory.KyselyFactory.createBuilder("users", async (attrs) => ({
|
|
196
|
-
name: "John Doe",
|
|
197
|
-
email: `user${Date.now()}@example.com`,
|
|
198
|
-
createdAt: /* @__PURE__ */ new Date()
|
|
199
|
-
}));
|
|
200
|
-
const builders = { user: userBuilder };
|
|
201
|
-
const factory = new require_KyselyFactory.KyselyFactory(builders, {}, trx);
|
|
202
|
-
const user = await factory.insert("user");
|
|
203
|
-
const foundUser = await trx.selectFrom("users").selectAll().where("id", "=", user.id).executeTakeFirst();
|
|
204
|
-
(0, vitest.expect)(foundUser).toBeDefined();
|
|
205
|
-
(0, vitest.expect)(foundUser?.id).toBe(user.id);
|
|
206
|
-
});
|
|
207
|
-
itWithTransaction("should work with factory passed to defaults", async ({ trx }) => {
|
|
208
|
-
const userBuilder = require_KyselyFactory.KyselyFactory.createBuilder("users", async (attrs) => ({
|
|
209
|
-
name: "John Doe",
|
|
210
|
-
email: `user${Date.now()}@example.com`,
|
|
211
|
-
createdAt: /* @__PURE__ */ new Date()
|
|
212
|
-
}));
|
|
213
|
-
const postBuilder = require_KyselyFactory.KyselyFactory.createBuilder("posts", async (attrs, factory$1) => {
|
|
214
|
-
const user = await factory$1.insert("user");
|
|
215
|
-
return {
|
|
216
|
-
title: "Default Post",
|
|
217
|
-
content: "Default content",
|
|
218
|
-
userId: user.id,
|
|
219
|
-
createdAt: /* @__PURE__ */ new Date()
|
|
220
|
-
};
|
|
221
|
-
});
|
|
222
|
-
const builders = {
|
|
223
|
-
user: userBuilder,
|
|
224
|
-
post: postBuilder
|
|
225
|
-
};
|
|
226
|
-
const factory = new require_KyselyFactory.KyselyFactory(builders, {}, trx);
|
|
227
|
-
const post = await factory.insert("post");
|
|
228
|
-
(0, vitest.expect)(post.userId).toBeDefined();
|
|
229
|
-
const relatedUser = await trx.selectFrom("users").selectAll().where("id", "=", post.userId).executeTakeFirst();
|
|
230
|
-
(0, vitest.expect)(relatedUser).toBeDefined();
|
|
231
|
-
});
|
|
232
|
-
});
|
|
233
|
-
});
|
|
234
|
-
|
|
235
|
-
//#endregion
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export { };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export { };
|