@geekmidas/testkit 0.0.9 → 0.0.11
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-B9LP1L18.d.cts +131 -0
- package/dist/Factory-DiZSNxC0.d.mts +131 -0
- package/dist/Factory.d.cts +3 -0
- package/dist/Factory.d.mts +3 -0
- package/dist/KyselyFactory-B-zlLbov.d.mts +200 -0
- package/dist/KyselyFactory-CrLWxJW4.d.cts +200 -0
- package/dist/KyselyFactory.d.cts +4 -0
- package/dist/KyselyFactory.d.mts +4 -0
- package/dist/ObjectionFactory-CJCpvwts.d.mts +213 -0
- package/dist/{ObjectionFactory-C47B03Ot.cjs → ObjectionFactory-Wq80ypMM.cjs} +82 -40
- package/dist/{ObjectionFactory-89p-FFEw.mjs → ObjectionFactory-aqM0dDW7.mjs} +82 -40
- package/dist/ObjectionFactory-vME-wNlq.d.cts +213 -0
- package/dist/ObjectionFactory.cjs +2 -1
- package/dist/ObjectionFactory.d.cts +4 -0
- package/dist/ObjectionFactory.d.mts +4 -0
- package/dist/ObjectionFactory.mjs +2 -1
- package/dist/{PostgresKyselyMigrator-ChIpZFYB.mjs → PostgresKyselyMigrator-Bdhl251C.mjs} +1 -1
- package/dist/PostgresKyselyMigrator-CQ3aUoy_.d.cts +67 -0
- package/dist/{PostgresKyselyMigrator-Bs31emFd.cjs → PostgresKyselyMigrator-CfytARcA.cjs} +1 -1
- package/dist/PostgresKyselyMigrator-_6yHZigp.d.mts +67 -0
- package/dist/PostgresKyselyMigrator.cjs +2 -2
- package/dist/PostgresKyselyMigrator.d.cts +3 -0
- package/dist/PostgresKyselyMigrator.d.mts +3 -0
- package/dist/PostgresKyselyMigrator.mjs +2 -2
- package/dist/PostgresMigrator-BlvuQl7d.d.mts +84 -0
- package/dist/PostgresMigrator-D5UkK1_K.d.cts +84 -0
- package/dist/{PostgresMigrator-BtAWdLss.cjs → PostgresMigrator-DFcNdCvD.cjs} +2 -1
- package/dist/{PostgresMigrator-BzqksJcW.mjs → PostgresMigrator-DxPC_gGu.mjs} +3 -2
- package/dist/PostgresMigrator.cjs +1 -1
- package/dist/PostgresMigrator.d.cts +2 -0
- package/dist/PostgresMigrator.d.mts +2 -0
- package/dist/PostgresMigrator.mjs +1 -1
- package/dist/{PostgresObjectionMigrator-B88aTT0m.cjs → PostgresObjectionMigrator-BG6ymgnt.cjs} +1 -1
- package/dist/PostgresObjectionMigrator-C69n7vzr.d.mts +77 -0
- package/dist/PostgresObjectionMigrator-CZHHcCOv.d.cts +77 -0
- package/dist/{PostgresObjectionMigrator-DydSgYFv.mjs → PostgresObjectionMigrator-G4h5FLvU.mjs} +1 -1
- package/dist/PostgresObjectionMigrator.cjs +2 -2
- package/dist/PostgresObjectionMigrator.d.cts +3 -0
- package/dist/PostgresObjectionMigrator.d.mts +3 -0
- package/dist/PostgresObjectionMigrator.mjs +2 -2
- package/dist/VitestKyselyTransactionIsolator-ClCazkBO.d.mts +56 -0
- package/dist/VitestKyselyTransactionIsolator-UE1J-UoP.d.cts +56 -0
- package/dist/VitestKyselyTransactionIsolator.d.cts +3 -0
- package/dist/VitestKyselyTransactionIsolator.d.mts +3 -0
- package/dist/VitestObjectionTransactionIsolator-CO2nTi9r.d.cts +57 -0
- package/dist/VitestObjectionTransactionIsolator-D264iuPy.d.mts +57 -0
- package/dist/VitestObjectionTransactionIsolator.d.cts +3 -0
- package/dist/VitestObjectionTransactionIsolator.d.mts +3 -0
- package/dist/VitestTransactionIsolator-DHf2MxmC.d.cts +118 -0
- package/dist/VitestTransactionIsolator-Xqyjlmw6.d.mts +118 -0
- package/dist/VitestTransactionIsolator.d.cts +2 -0
- package/dist/VitestTransactionIsolator.d.mts +2 -0
- package/dist/__tests__/Factory.spec.d.cts +1 -0
- package/dist/__tests__/Factory.spec.d.mts +1 -0
- package/dist/__tests__/KyselyFactory.spec.cjs +2 -2
- package/dist/__tests__/KyselyFactory.spec.d.cts +1 -0
- package/dist/__tests__/KyselyFactory.spec.d.mts +1 -0
- package/dist/__tests__/KyselyFactory.spec.mjs +2 -2
- package/dist/__tests__/ObjectionFactory.spec.cjs +117 -1
- package/dist/__tests__/ObjectionFactory.spec.d.cts +1 -0
- package/dist/__tests__/ObjectionFactory.spec.d.mts +1 -0
- package/dist/__tests__/ObjectionFactory.spec.mjs +117 -1
- package/dist/__tests__/PostgresMigrator.spec.cjs +1 -1
- package/dist/__tests__/PostgresMigrator.spec.d.cts +1 -0
- package/dist/__tests__/PostgresMigrator.spec.d.mts +1 -0
- package/dist/__tests__/PostgresMigrator.spec.mjs +1 -1
- package/dist/__tests__/PostgresObjectionMigrator.spec.cjs +2 -2
- package/dist/__tests__/PostgresObjectionMigrator.spec.d.cts +1 -0
- package/dist/__tests__/PostgresObjectionMigrator.spec.d.mts +1 -0
- package/dist/__tests__/PostgresObjectionMigrator.spec.mjs +2 -2
- package/dist/__tests__/VitestObjectionTransactionIsolator.spec.cjs +4 -3
- package/dist/__tests__/VitestObjectionTransactionIsolator.spec.d.cts +1 -0
- package/dist/__tests__/VitestObjectionTransactionIsolator.spec.d.mts +1 -0
- package/dist/__tests__/VitestObjectionTransactionIsolator.spec.mjs +4 -3
- package/dist/__tests__/faker.spec.d.cts +1 -0
- package/dist/__tests__/faker.spec.d.mts +1 -0
- package/dist/__tests__/integration.spec.cjs +2 -2
- package/dist/__tests__/integration.spec.d.cts +1 -0
- package/dist/__tests__/integration.spec.d.mts +1 -0
- package/dist/__tests__/integration.spec.mjs +2 -2
- package/dist/example.d.cts +26 -0
- package/dist/example.d.mts +26 -0
- package/dist/faker-DAiFK3T3.d.cts +155 -0
- package/dist/faker-nN9Ki6fn.d.mts +155 -0
- package/dist/faker.d.cts +2 -0
- package/dist/faker.d.mts +2 -0
- package/dist/helpers.d.cts +41 -0
- package/dist/helpers.d.mts +41 -0
- package/dist/kysely.cjs +2 -2
- package/dist/kysely.d.cts +73 -0
- package/dist/kysely.d.mts +73 -0
- package/dist/kysely.mjs +2 -2
- package/dist/objection.cjs +4 -3
- package/dist/objection.d.cts +88 -0
- package/dist/objection.d.mts +88 -0
- package/dist/objection.mjs +4 -3
- package/package.json +5 -5
- package/src/ObjectionFactory.ts +156 -13
- package/src/PostgresMigrator.ts +3 -1
- package/src/__tests__/ObjectionFactory.spec.ts +162 -0
- package/PostgresKyselyMigrator.spec +0 -471
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
|
@@ -2,8 +2,8 @@ const require_chunk = require('../chunk-CUT6urMc.cjs');
|
|
|
2
2
|
require('../Factory-WMhTNZ9S.cjs');
|
|
3
3
|
require('../faker-SMN4ira4.cjs');
|
|
4
4
|
const require_KyselyFactory = require('../KyselyFactory-Bdq1s1Go.cjs');
|
|
5
|
-
require('../PostgresMigrator-
|
|
6
|
-
require('../PostgresKyselyMigrator-
|
|
5
|
+
require('../PostgresMigrator-DFcNdCvD.cjs');
|
|
6
|
+
require('../PostgresKyselyMigrator-CfytARcA.cjs');
|
|
7
7
|
require('../VitestTransactionIsolator-CruLTRRi.cjs');
|
|
8
8
|
require('../VitestKyselyTransactionIsolator-CIlpIO78.cjs');
|
|
9
9
|
const require_helpers = require('../helpers-nEUtQ7eo.cjs');
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import "../Factory-z2m01hMj.mjs";
|
|
2
2
|
import "../faker-CxKkEeYi.mjs";
|
|
3
3
|
import { KyselyFactory } from "../KyselyFactory-ELiHgHVv.mjs";
|
|
4
|
-
import "../PostgresMigrator-
|
|
5
|
-
import "../PostgresKyselyMigrator-
|
|
4
|
+
import "../PostgresMigrator-DxPC_gGu.mjs";
|
|
5
|
+
import "../PostgresKyselyMigrator-Bdhl251C.mjs";
|
|
6
6
|
import "../VitestTransactionIsolator-BWwK-ca6.mjs";
|
|
7
7
|
import "../VitestKyselyTransactionIsolator-BKGT9nEG.mjs";
|
|
8
8
|
import { createKyselyDb } from "../helpers-BuPmgzyQ.mjs";
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
const require_chunk = require('../chunk-CUT6urMc.cjs');
|
|
2
2
|
require('../Factory-WMhTNZ9S.cjs');
|
|
3
|
-
const
|
|
3
|
+
const require_faker = require('../faker-SMN4ira4.cjs');
|
|
4
|
+
const require_ObjectionFactory = require('../ObjectionFactory-Wq80ypMM.cjs');
|
|
4
5
|
const require_helpers = require('../helpers-CNMBePuj.cjs');
|
|
5
6
|
const vitest = require_chunk.__toESM(require("vitest"));
|
|
6
7
|
const objection = require_chunk.__toESM(require("objection"));
|
|
@@ -286,6 +287,121 @@ vitest.describe.skip("ObjectionFactory", () => {
|
|
|
286
287
|
(0, vitest.expect)(result).toBe(seedFn);
|
|
287
288
|
});
|
|
288
289
|
});
|
|
290
|
+
(0, vitest.describe)("createBuilder static method", () => {
|
|
291
|
+
(0, vitest.it)("should create a builder function with auto-insert", async () => {
|
|
292
|
+
const userBuilder = require_ObjectionFactory.ObjectionFactory.createBuilder(User, (attrs, factory$1, db$1, faker$1) => ({
|
|
293
|
+
name: faker$1.person.fullName(),
|
|
294
|
+
email: faker$1.internet.email(),
|
|
295
|
+
role: "user",
|
|
296
|
+
createdAt: /* @__PURE__ */ new Date(),
|
|
297
|
+
updatedAt: /* @__PURE__ */ new Date(),
|
|
298
|
+
...attrs
|
|
299
|
+
}));
|
|
300
|
+
const builders = { user: userBuilder };
|
|
301
|
+
factory = new require_ObjectionFactory.ObjectionFactory(builders, {}, trx);
|
|
302
|
+
const result = await factory.insert("user", { name: "Test User" });
|
|
303
|
+
(0, vitest.expect)(result).toBeInstanceOf(User);
|
|
304
|
+
(0, vitest.expect)(result.name).toBe("Test User");
|
|
305
|
+
(0, vitest.expect)(result.email).toMatch(/@/);
|
|
306
|
+
(0, vitest.expect)(result.id).toBeDefined();
|
|
307
|
+
});
|
|
308
|
+
(0, vitest.it)("should create a builder function without auto-insert", async () => {
|
|
309
|
+
const userBuilder = require_ObjectionFactory.ObjectionFactory.createBuilder(User, (attrs) => ({
|
|
310
|
+
name: "No Insert User",
|
|
311
|
+
email: "noinsert@example.com",
|
|
312
|
+
role: "user",
|
|
313
|
+
createdAt: /* @__PURE__ */ new Date(),
|
|
314
|
+
updatedAt: /* @__PURE__ */ new Date(),
|
|
315
|
+
...attrs
|
|
316
|
+
}), false);
|
|
317
|
+
const builders = { user: userBuilder };
|
|
318
|
+
factory = new require_ObjectionFactory.ObjectionFactory(builders, {}, trx);
|
|
319
|
+
const result = await factory.insert("user");
|
|
320
|
+
(0, vitest.expect)(result).toBeInstanceOf(User);
|
|
321
|
+
(0, vitest.expect)(result.name).toBe("No Insert User");
|
|
322
|
+
(0, vitest.expect)(result.id).toBeDefined();
|
|
323
|
+
});
|
|
324
|
+
(0, vitest.it)("should pass all parameters to the item function", async () => {
|
|
325
|
+
let capturedFactory;
|
|
326
|
+
let capturedDb;
|
|
327
|
+
let capturedFaker;
|
|
328
|
+
const userBuilder = require_ObjectionFactory.ObjectionFactory.createBuilder(User, (attrs, factory$1, db$1, fakerInstance) => {
|
|
329
|
+
capturedFactory = factory$1;
|
|
330
|
+
capturedDb = db$1;
|
|
331
|
+
capturedFaker = fakerInstance;
|
|
332
|
+
return {
|
|
333
|
+
name: "Test User",
|
|
334
|
+
email: "test@example.com",
|
|
335
|
+
role: "user",
|
|
336
|
+
createdAt: /* @__PURE__ */ new Date(),
|
|
337
|
+
updatedAt: /* @__PURE__ */ new Date(),
|
|
338
|
+
...attrs
|
|
339
|
+
};
|
|
340
|
+
});
|
|
341
|
+
const builders = { user: userBuilder };
|
|
342
|
+
factory = new require_ObjectionFactory.ObjectionFactory(builders, {}, trx);
|
|
343
|
+
await factory.insert("user");
|
|
344
|
+
(0, vitest.expect)(capturedFactory).toBe(factory);
|
|
345
|
+
(0, vitest.expect)(capturedDb).toBe(trx);
|
|
346
|
+
(0, vitest.expect)(capturedFaker).toBe(require_faker.faker);
|
|
347
|
+
});
|
|
348
|
+
(0, vitest.it)("should handle async item functions", async () => {
|
|
349
|
+
const userBuilder = require_ObjectionFactory.ObjectionFactory.createBuilder(User, async (attrs, factory$1, db$1, faker$1) => {
|
|
350
|
+
await new Promise((resolve) => setTimeout(resolve, 10));
|
|
351
|
+
return {
|
|
352
|
+
name: "Async User",
|
|
353
|
+
email: faker$1.internet.email(),
|
|
354
|
+
role: "user",
|
|
355
|
+
createdAt: /* @__PURE__ */ new Date(),
|
|
356
|
+
updatedAt: /* @__PURE__ */ new Date(),
|
|
357
|
+
...attrs
|
|
358
|
+
};
|
|
359
|
+
});
|
|
360
|
+
const builders = { user: userBuilder };
|
|
361
|
+
factory = new require_ObjectionFactory.ObjectionFactory(builders, {}, trx);
|
|
362
|
+
const result = await factory.insert("user");
|
|
363
|
+
(0, vitest.expect)(result).toBeInstanceOf(User);
|
|
364
|
+
(0, vitest.expect)(result.name).toBe("Async User");
|
|
365
|
+
(0, vitest.expect)(result.id).toBeDefined();
|
|
366
|
+
});
|
|
367
|
+
(0, vitest.it)("should work without item function", async () => {
|
|
368
|
+
const userBuilder = require_ObjectionFactory.ObjectionFactory.createBuilder(User);
|
|
369
|
+
const builders = { user: userBuilder };
|
|
370
|
+
factory = new require_ObjectionFactory.ObjectionFactory(builders, {}, trx);
|
|
371
|
+
const attrs = {
|
|
372
|
+
name: "Manual User",
|
|
373
|
+
email: "manual@example.com",
|
|
374
|
+
role: "user",
|
|
375
|
+
createdAt: /* @__PURE__ */ new Date(),
|
|
376
|
+
updatedAt: /* @__PURE__ */ new Date()
|
|
377
|
+
};
|
|
378
|
+
const result = await factory.insert("user", attrs);
|
|
379
|
+
(0, vitest.expect)(result).toBeInstanceOf(User);
|
|
380
|
+
(0, vitest.expect)(result.name).toBe("Manual User");
|
|
381
|
+
(0, vitest.expect)(result.email).toBe("manual@example.com");
|
|
382
|
+
(0, vitest.expect)(result.id).toBeDefined();
|
|
383
|
+
});
|
|
384
|
+
(0, vitest.it)("should allow overriding default values", async () => {
|
|
385
|
+
const userBuilder = require_ObjectionFactory.ObjectionFactory.createBuilder(User, (attrs, factory$1, db$1, faker$1) => ({
|
|
386
|
+
name: "Default Name",
|
|
387
|
+
email: "default@example.com",
|
|
388
|
+
role: "user",
|
|
389
|
+
createdAt: /* @__PURE__ */ new Date(),
|
|
390
|
+
updatedAt: /* @__PURE__ */ new Date(),
|
|
391
|
+
...attrs
|
|
392
|
+
}));
|
|
393
|
+
const builders = { user: userBuilder };
|
|
394
|
+
factory = new require_ObjectionFactory.ObjectionFactory(builders, {}, trx);
|
|
395
|
+
const result = await factory.insert("user", {
|
|
396
|
+
name: "Override Name",
|
|
397
|
+
email: "override@example.com"
|
|
398
|
+
});
|
|
399
|
+
(0, vitest.expect)(result).toBeInstanceOf(User);
|
|
400
|
+
(0, vitest.expect)(result.name).toBe("Override Name");
|
|
401
|
+
(0, vitest.expect)(result.email).toBe("override@example.com");
|
|
402
|
+
(0, vitest.expect)(result.role).toBe("user");
|
|
403
|
+
});
|
|
404
|
+
});
|
|
289
405
|
(0, vitest.describe)("error handling", () => {
|
|
290
406
|
(0, vitest.it)("should handle builder errors gracefully", async () => {
|
|
291
407
|
const userBuilder = async (attrs, factory$1, db$1) => {
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import "../Factory-z2m01hMj.mjs";
|
|
2
|
-
import {
|
|
2
|
+
import { faker } from "../faker-CxKkEeYi.mjs";
|
|
3
|
+
import { ObjectionFactory } from "../ObjectionFactory-aqM0dDW7.mjs";
|
|
3
4
|
import { setupKnexTest } from "../helpers-BEmjyUVE.mjs";
|
|
4
5
|
import { afterAll, beforeAll, describe, expect, it } from "vitest";
|
|
5
6
|
import { Model } from "objection";
|
|
@@ -285,6 +286,121 @@ describe.skip("ObjectionFactory", () => {
|
|
|
285
286
|
expect(result).toBe(seedFn);
|
|
286
287
|
});
|
|
287
288
|
});
|
|
289
|
+
describe("createBuilder static method", () => {
|
|
290
|
+
it("should create a builder function with auto-insert", async () => {
|
|
291
|
+
const userBuilder = ObjectionFactory.createBuilder(User, (attrs, factory$1, db$1, faker$1) => ({
|
|
292
|
+
name: faker$1.person.fullName(),
|
|
293
|
+
email: faker$1.internet.email(),
|
|
294
|
+
role: "user",
|
|
295
|
+
createdAt: /* @__PURE__ */ new Date(),
|
|
296
|
+
updatedAt: /* @__PURE__ */ new Date(),
|
|
297
|
+
...attrs
|
|
298
|
+
}));
|
|
299
|
+
const builders = { user: userBuilder };
|
|
300
|
+
factory = new ObjectionFactory(builders, {}, trx);
|
|
301
|
+
const result = await factory.insert("user", { name: "Test User" });
|
|
302
|
+
expect(result).toBeInstanceOf(User);
|
|
303
|
+
expect(result.name).toBe("Test User");
|
|
304
|
+
expect(result.email).toMatch(/@/);
|
|
305
|
+
expect(result.id).toBeDefined();
|
|
306
|
+
});
|
|
307
|
+
it("should create a builder function without auto-insert", async () => {
|
|
308
|
+
const userBuilder = ObjectionFactory.createBuilder(User, (attrs) => ({
|
|
309
|
+
name: "No Insert User",
|
|
310
|
+
email: "noinsert@example.com",
|
|
311
|
+
role: "user",
|
|
312
|
+
createdAt: /* @__PURE__ */ new Date(),
|
|
313
|
+
updatedAt: /* @__PURE__ */ new Date(),
|
|
314
|
+
...attrs
|
|
315
|
+
}), false);
|
|
316
|
+
const builders = { user: userBuilder };
|
|
317
|
+
factory = new ObjectionFactory(builders, {}, trx);
|
|
318
|
+
const result = await factory.insert("user");
|
|
319
|
+
expect(result).toBeInstanceOf(User);
|
|
320
|
+
expect(result.name).toBe("No Insert User");
|
|
321
|
+
expect(result.id).toBeDefined();
|
|
322
|
+
});
|
|
323
|
+
it("should pass all parameters to the item function", async () => {
|
|
324
|
+
let capturedFactory;
|
|
325
|
+
let capturedDb;
|
|
326
|
+
let capturedFaker;
|
|
327
|
+
const userBuilder = ObjectionFactory.createBuilder(User, (attrs, factory$1, db$1, fakerInstance) => {
|
|
328
|
+
capturedFactory = factory$1;
|
|
329
|
+
capturedDb = db$1;
|
|
330
|
+
capturedFaker = fakerInstance;
|
|
331
|
+
return {
|
|
332
|
+
name: "Test User",
|
|
333
|
+
email: "test@example.com",
|
|
334
|
+
role: "user",
|
|
335
|
+
createdAt: /* @__PURE__ */ new Date(),
|
|
336
|
+
updatedAt: /* @__PURE__ */ new Date(),
|
|
337
|
+
...attrs
|
|
338
|
+
};
|
|
339
|
+
});
|
|
340
|
+
const builders = { user: userBuilder };
|
|
341
|
+
factory = new ObjectionFactory(builders, {}, trx);
|
|
342
|
+
await factory.insert("user");
|
|
343
|
+
expect(capturedFactory).toBe(factory);
|
|
344
|
+
expect(capturedDb).toBe(trx);
|
|
345
|
+
expect(capturedFaker).toBe(faker);
|
|
346
|
+
});
|
|
347
|
+
it("should handle async item functions", async () => {
|
|
348
|
+
const userBuilder = ObjectionFactory.createBuilder(User, async (attrs, factory$1, db$1, faker$1) => {
|
|
349
|
+
await new Promise((resolve) => setTimeout(resolve, 10));
|
|
350
|
+
return {
|
|
351
|
+
name: "Async User",
|
|
352
|
+
email: faker$1.internet.email(),
|
|
353
|
+
role: "user",
|
|
354
|
+
createdAt: /* @__PURE__ */ new Date(),
|
|
355
|
+
updatedAt: /* @__PURE__ */ new Date(),
|
|
356
|
+
...attrs
|
|
357
|
+
};
|
|
358
|
+
});
|
|
359
|
+
const builders = { user: userBuilder };
|
|
360
|
+
factory = new ObjectionFactory(builders, {}, trx);
|
|
361
|
+
const result = await factory.insert("user");
|
|
362
|
+
expect(result).toBeInstanceOf(User);
|
|
363
|
+
expect(result.name).toBe("Async User");
|
|
364
|
+
expect(result.id).toBeDefined();
|
|
365
|
+
});
|
|
366
|
+
it("should work without item function", async () => {
|
|
367
|
+
const userBuilder = ObjectionFactory.createBuilder(User);
|
|
368
|
+
const builders = { user: userBuilder };
|
|
369
|
+
factory = new ObjectionFactory(builders, {}, trx);
|
|
370
|
+
const attrs = {
|
|
371
|
+
name: "Manual User",
|
|
372
|
+
email: "manual@example.com",
|
|
373
|
+
role: "user",
|
|
374
|
+
createdAt: /* @__PURE__ */ new Date(),
|
|
375
|
+
updatedAt: /* @__PURE__ */ new Date()
|
|
376
|
+
};
|
|
377
|
+
const result = await factory.insert("user", attrs);
|
|
378
|
+
expect(result).toBeInstanceOf(User);
|
|
379
|
+
expect(result.name).toBe("Manual User");
|
|
380
|
+
expect(result.email).toBe("manual@example.com");
|
|
381
|
+
expect(result.id).toBeDefined();
|
|
382
|
+
});
|
|
383
|
+
it("should allow overriding default values", async () => {
|
|
384
|
+
const userBuilder = ObjectionFactory.createBuilder(User, (attrs, factory$1, db$1, faker$1) => ({
|
|
385
|
+
name: "Default Name",
|
|
386
|
+
email: "default@example.com",
|
|
387
|
+
role: "user",
|
|
388
|
+
createdAt: /* @__PURE__ */ new Date(),
|
|
389
|
+
updatedAt: /* @__PURE__ */ new Date(),
|
|
390
|
+
...attrs
|
|
391
|
+
}));
|
|
392
|
+
const builders = { user: userBuilder };
|
|
393
|
+
factory = new ObjectionFactory(builders, {}, trx);
|
|
394
|
+
const result = await factory.insert("user", {
|
|
395
|
+
name: "Override Name",
|
|
396
|
+
email: "override@example.com"
|
|
397
|
+
});
|
|
398
|
+
expect(result).toBeInstanceOf(User);
|
|
399
|
+
expect(result.name).toBe("Override Name");
|
|
400
|
+
expect(result.email).toBe("override@example.com");
|
|
401
|
+
expect(result.role).toBe("user");
|
|
402
|
+
});
|
|
403
|
+
});
|
|
288
404
|
describe("error handling", () => {
|
|
289
405
|
it("should handle builder errors gracefully", async () => {
|
|
290
406
|
const userBuilder = async (attrs, factory$1, db$1) => {
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
const require_chunk = require('../chunk-CUT6urMc.cjs');
|
|
2
|
-
const require_PostgresMigrator = require('../PostgresMigrator-
|
|
2
|
+
const require_PostgresMigrator = require('../PostgresMigrator-DFcNdCvD.cjs');
|
|
3
3
|
const require_helpers = require('../helpers-CNMBePuj.cjs');
|
|
4
4
|
const pg = require_chunk.__toESM(require("pg"));
|
|
5
5
|
const vitest = require_chunk.__toESM(require("vitest"));
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { PostgresMigrator } from "../PostgresMigrator-
|
|
1
|
+
import { PostgresMigrator } from "../PostgresMigrator-DxPC_gGu.mjs";
|
|
2
2
|
import { createTestDatabase } from "../helpers-BEmjyUVE.mjs";
|
|
3
3
|
import { Client } from "pg";
|
|
4
4
|
import { afterAll, afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest";
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
const require_chunk = require('../chunk-CUT6urMc.cjs');
|
|
2
|
-
require('../PostgresMigrator-
|
|
3
|
-
const require_PostgresObjectionMigrator = require('../PostgresObjectionMigrator-
|
|
2
|
+
require('../PostgresMigrator-DFcNdCvD.cjs');
|
|
3
|
+
const require_PostgresObjectionMigrator = require('../PostgresObjectionMigrator-BG6ymgnt.cjs');
|
|
4
4
|
const require_helpers = require('../helpers-CNMBePuj.cjs');
|
|
5
5
|
const pg = require_chunk.__toESM(require("pg"));
|
|
6
6
|
const vitest = require_chunk.__toESM(require("vitest"));
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import "../PostgresMigrator-
|
|
2
|
-
import { PostgresObjectionMigrator } from "../PostgresObjectionMigrator-
|
|
1
|
+
import "../PostgresMigrator-DxPC_gGu.mjs";
|
|
2
|
+
import { PostgresObjectionMigrator } from "../PostgresObjectionMigrator-G4h5FLvU.mjs";
|
|
3
3
|
import { createTestDatabase } from "../helpers-BEmjyUVE.mjs";
|
|
4
4
|
import { Client } from "pg";
|
|
5
5
|
import { afterAll, afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest";
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
const require_chunk = require('../chunk-CUT6urMc.cjs');
|
|
2
2
|
require('../Factory-WMhTNZ9S.cjs');
|
|
3
|
-
require('../
|
|
4
|
-
require('../
|
|
5
|
-
require('../
|
|
3
|
+
require('../faker-SMN4ira4.cjs');
|
|
4
|
+
require('../ObjectionFactory-Wq80ypMM.cjs');
|
|
5
|
+
require('../PostgresMigrator-DFcNdCvD.cjs');
|
|
6
|
+
require('../PostgresObjectionMigrator-BG6ymgnt.cjs');
|
|
6
7
|
require('../VitestTransactionIsolator-CruLTRRi.cjs');
|
|
7
8
|
require('../VitestObjectionTransactionIsolator-DyqLp_in.cjs');
|
|
8
9
|
const require_objection = require('../objection-CCD8fMLj.cjs');
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import "../Factory-z2m01hMj.mjs";
|
|
2
|
-
import "../
|
|
3
|
-
import "../
|
|
4
|
-
import "../
|
|
2
|
+
import "../faker-CxKkEeYi.mjs";
|
|
3
|
+
import "../ObjectionFactory-aqM0dDW7.mjs";
|
|
4
|
+
import "../PostgresMigrator-DxPC_gGu.mjs";
|
|
5
|
+
import "../PostgresObjectionMigrator-G4h5FLvU.mjs";
|
|
5
6
|
import "../VitestTransactionIsolator-BWwK-ca6.mjs";
|
|
6
7
|
import "../VitestObjectionTransactionIsolator-BPoLUFop.mjs";
|
|
7
8
|
import { wrapVitestObjectionTransaction } from "../objection-lsMgM5gP.mjs";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
|
@@ -2,8 +2,8 @@ const require_chunk = require('../chunk-CUT6urMc.cjs');
|
|
|
2
2
|
require('../Factory-WMhTNZ9S.cjs');
|
|
3
3
|
require('../faker-SMN4ira4.cjs');
|
|
4
4
|
const require_KyselyFactory = require('../KyselyFactory-Bdq1s1Go.cjs');
|
|
5
|
-
require('../PostgresMigrator-
|
|
6
|
-
require('../PostgresKyselyMigrator-
|
|
5
|
+
require('../PostgresMigrator-DFcNdCvD.cjs');
|
|
6
|
+
require('../PostgresKyselyMigrator-CfytARcA.cjs');
|
|
7
7
|
require('../VitestTransactionIsolator-CruLTRRi.cjs');
|
|
8
8
|
require('../VitestKyselyTransactionIsolator-CIlpIO78.cjs');
|
|
9
9
|
const require_helpers = require('../helpers-nEUtQ7eo.cjs');
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import "../Factory-z2m01hMj.mjs";
|
|
2
2
|
import "../faker-CxKkEeYi.mjs";
|
|
3
3
|
import { KyselyFactory } from "../KyselyFactory-ELiHgHVv.mjs";
|
|
4
|
-
import "../PostgresMigrator-
|
|
5
|
-
import "../PostgresKyselyMigrator-
|
|
4
|
+
import "../PostgresMigrator-DxPC_gGu.mjs";
|
|
5
|
+
import "../PostgresKyselyMigrator-Bdhl251C.mjs";
|
|
6
6
|
import "../VitestTransactionIsolator-BWwK-ca6.mjs";
|
|
7
7
|
import "../VitestKyselyTransactionIsolator-BKGT9nEG.mjs";
|
|
8
8
|
import { createKyselyDb } from "../helpers-BuPmgzyQ.mjs";
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { FakerFactory } from "./faker-DAiFK3T3.cjs";
|
|
2
|
+
import * as kysely0 from "kysely";
|
|
3
|
+
|
|
4
|
+
//#region src/example.d.ts
|
|
5
|
+
interface Database {
|
|
6
|
+
users: {
|
|
7
|
+
id: number;
|
|
8
|
+
name: string;
|
|
9
|
+
email: string;
|
|
10
|
+
createdAt: Date;
|
|
11
|
+
};
|
|
12
|
+
posts: {
|
|
13
|
+
id: number;
|
|
14
|
+
title: string;
|
|
15
|
+
content: string;
|
|
16
|
+
userId: number;
|
|
17
|
+
createdAt: Date;
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
declare const builders: {
|
|
21
|
+
user: (attrs: Partial<kysely0.Insertable<DB[TableName]>>, factory: any, db: kysely0.Kysely<Database>, faker: FakerFactory) => Promise<kysely0.Selectable<DB[TableName]>>;
|
|
22
|
+
};
|
|
23
|
+
type Builders = typeof builders;
|
|
24
|
+
type Seeds = Record<string, any>;
|
|
25
|
+
//#endregion
|
|
26
|
+
export { Builders, Seeds };
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { FakerFactory } from "./faker-nN9Ki6fn.mjs";
|
|
2
|
+
import * as kysely0 from "kysely";
|
|
3
|
+
|
|
4
|
+
//#region src/example.d.ts
|
|
5
|
+
interface Database {
|
|
6
|
+
users: {
|
|
7
|
+
id: number;
|
|
8
|
+
name: string;
|
|
9
|
+
email: string;
|
|
10
|
+
createdAt: Date;
|
|
11
|
+
};
|
|
12
|
+
posts: {
|
|
13
|
+
id: number;
|
|
14
|
+
title: string;
|
|
15
|
+
content: string;
|
|
16
|
+
userId: number;
|
|
17
|
+
createdAt: Date;
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
declare const builders: {
|
|
21
|
+
user: (attrs: Partial<kysely0.Insertable<DB[TableName]>>, factory: any, db: kysely0.Kysely<Database>, faker: FakerFactory) => Promise<kysely0.Selectable<DB[TableName]>>;
|
|
22
|
+
};
|
|
23
|
+
type Builders = typeof builders;
|
|
24
|
+
type Seeds = Record<string, any>;
|
|
25
|
+
//#endregion
|
|
26
|
+
export { Builders, Seeds };
|
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
import * as _faker_js_faker4 from "@faker-js/faker";
|
|
2
|
+
|
|
3
|
+
//#region src/faker.d.ts
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Generates random timestamp fields for database records.
|
|
7
|
+
* Creates a createdAt date in the past and an updatedAt date between creation and now.
|
|
8
|
+
* Milliseconds are set to 0 for cleaner database storage.
|
|
9
|
+
*
|
|
10
|
+
* @returns Object with createdAt and updatedAt Date fields
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* ```typescript
|
|
14
|
+
* const { createdAt, updatedAt } = timestamps();
|
|
15
|
+
* console.log(createdAt); // 2023-05-15T10:30:00.000Z
|
|
16
|
+
* console.log(updatedAt); // 2023-11-20T14:45:00.000Z
|
|
17
|
+
*
|
|
18
|
+
* // Use in factory
|
|
19
|
+
* const user = {
|
|
20
|
+
* name: 'John Doe',
|
|
21
|
+
* ...timestamps()
|
|
22
|
+
* };
|
|
23
|
+
* ```
|
|
24
|
+
*/
|
|
25
|
+
declare function timestamps(): Timestamps;
|
|
26
|
+
/**
|
|
27
|
+
* Generates a reverse domain name identifier.
|
|
28
|
+
* Useful for creating unique identifiers that follow domain naming conventions.
|
|
29
|
+
*
|
|
30
|
+
* @param suffix - Optional suffix to append to the identifier
|
|
31
|
+
* @returns A reverse domain name string (e.g., "com.example.feature123")
|
|
32
|
+
*
|
|
33
|
+
* @example
|
|
34
|
+
* ```typescript
|
|
35
|
+
* console.log(identifier()); // "com.example.widget1"
|
|
36
|
+
* console.log(identifier('user')); // "org.acme.user"
|
|
37
|
+
* console.log(identifier('api')); // "net.demo.api"
|
|
38
|
+
* ```
|
|
39
|
+
*/
|
|
40
|
+
declare function identifier(suffix?: string): string;
|
|
41
|
+
/**
|
|
42
|
+
* Generates sequential numbers for a named sequence.
|
|
43
|
+
* Useful for creating unique IDs or numbered test data.
|
|
44
|
+
* Each named sequence maintains its own counter.
|
|
45
|
+
*
|
|
46
|
+
* @param name - The sequence name (default: 'default')
|
|
47
|
+
* @returns The next number in the sequence
|
|
48
|
+
*
|
|
49
|
+
* @example
|
|
50
|
+
* ```typescript
|
|
51
|
+
* console.log(sequence()); // 1
|
|
52
|
+
* console.log(sequence()); // 2
|
|
53
|
+
* console.log(sequence('user')); // 1
|
|
54
|
+
* console.log(sequence('user')); // 2
|
|
55
|
+
* console.log(sequence()); // 3
|
|
56
|
+
*
|
|
57
|
+
* // Use in factories
|
|
58
|
+
* const email = `user${sequence('email')}@example.com`;
|
|
59
|
+
* ```
|
|
60
|
+
*/
|
|
61
|
+
declare function sequence(name?: string): number;
|
|
62
|
+
/**
|
|
63
|
+
* Resets a named sequence counter to a specific value.
|
|
64
|
+
* Useful for resetting sequences between test suites.
|
|
65
|
+
*
|
|
66
|
+
* @param name - The sequence name to reset (default: 'default')
|
|
67
|
+
* @param value - The new starting value (default: 0)
|
|
68
|
+
*
|
|
69
|
+
* @example
|
|
70
|
+
* ```typescript
|
|
71
|
+
* sequence('user'); // 1
|
|
72
|
+
* sequence('user'); // 2
|
|
73
|
+
* resetSequence('user');
|
|
74
|
+
* sequence('user'); // 1
|
|
75
|
+
*
|
|
76
|
+
* resetSequence('order', 1000);
|
|
77
|
+
* sequence('order'); // 1001
|
|
78
|
+
* ```
|
|
79
|
+
*/
|
|
80
|
+
declare function resetSequence(name?: string, value?: number): void;
|
|
81
|
+
/**
|
|
82
|
+
* Resets all sequence counters.
|
|
83
|
+
* Useful for cleaning up between test suites to ensure predictable sequences.
|
|
84
|
+
*
|
|
85
|
+
* @example
|
|
86
|
+
* ```typescript
|
|
87
|
+
* // In test setup
|
|
88
|
+
* beforeEach(() => {
|
|
89
|
+
* resetAllSequences();
|
|
90
|
+
* });
|
|
91
|
+
*
|
|
92
|
+
* it('starts sequences from 1', () => {
|
|
93
|
+
* expect(sequence()).toBe(1);
|
|
94
|
+
* expect(sequence('user')).toBe(1);
|
|
95
|
+
* });
|
|
96
|
+
* ```
|
|
97
|
+
*/
|
|
98
|
+
declare function resetAllSequences(): void;
|
|
99
|
+
/**
|
|
100
|
+
* Generates a random price as a number.
|
|
101
|
+
* Converts faker's string price to a numeric value.
|
|
102
|
+
*
|
|
103
|
+
* @returns A random price number
|
|
104
|
+
*
|
|
105
|
+
* @example
|
|
106
|
+
* ```typescript
|
|
107
|
+
* const productPrice = price(); // 29.99
|
|
108
|
+
* const total = price() * quantity; // Numeric calculation
|
|
109
|
+
* ```
|
|
110
|
+
*/
|
|
111
|
+
declare function price(): number;
|
|
112
|
+
/**
|
|
113
|
+
* Enhanced faker instance with additional utility methods for testing.
|
|
114
|
+
* Extends @faker-js/faker with custom methods for common test data generation patterns.
|
|
115
|
+
*
|
|
116
|
+
* @example
|
|
117
|
+
* ```typescript
|
|
118
|
+
* import { faker } from '@geekmidas/testkit';
|
|
119
|
+
*
|
|
120
|
+
* // Use standard faker methods
|
|
121
|
+
* const name = faker.person.fullName();
|
|
122
|
+
* const email = faker.internet.email();
|
|
123
|
+
*
|
|
124
|
+
* // Use custom extensions
|
|
125
|
+
* const { createdAt, updatedAt } = faker.timestamps();
|
|
126
|
+
* const id = faker.identifier('user');
|
|
127
|
+
* const orderNumber = faker.sequence('order');
|
|
128
|
+
* const productPrice = faker.price();
|
|
129
|
+
* ```
|
|
130
|
+
*/
|
|
131
|
+
declare const faker: Readonly<_faker_js_faker4.Faker & {
|
|
132
|
+
timestamps: typeof timestamps;
|
|
133
|
+
identifier: typeof identifier;
|
|
134
|
+
sequence: typeof sequence;
|
|
135
|
+
resetSequence: typeof resetSequence;
|
|
136
|
+
resetAllSequences: typeof resetAllSequences;
|
|
137
|
+
price: typeof price;
|
|
138
|
+
}>;
|
|
139
|
+
/**
|
|
140
|
+
* Type definition for timestamp fields.
|
|
141
|
+
* Used by the timestamps() function to generate date fields.
|
|
142
|
+
*/
|
|
143
|
+
type Timestamps = {
|
|
144
|
+
/** The creation date */
|
|
145
|
+
createdAt: Date;
|
|
146
|
+
/** The last update date */
|
|
147
|
+
updatedAt: Date;
|
|
148
|
+
};
|
|
149
|
+
/**
|
|
150
|
+
* Type definition for the enhanced faker factory.
|
|
151
|
+
* Includes all standard faker methods plus custom extensions.
|
|
152
|
+
*/
|
|
153
|
+
type FakerFactory = typeof faker;
|
|
154
|
+
//#endregion
|
|
155
|
+
export { FakerFactory, Timestamps, faker, identifier, resetAllSequences, resetSequence, sequence, timestamps };
|