@geekmidas/testkit 0.1.1 → 0.3.0

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.
Files changed (108) hide show
  1. package/dist/{Factory-z2m01hMj.mjs → Factory-BFVnMMCC.mjs} +2 -2
  2. package/dist/Factory-BFVnMMCC.mjs.map +1 -0
  3. package/dist/{Factory-DE3hE0WO.d.mts → Factory-BcGJjLc8.d.mts} +24 -10
  4. package/dist/{Factory-WMhTNZ9S.cjs → Factory-BhjUOBWN.cjs} +2 -2
  5. package/dist/Factory-BhjUOBWN.cjs.map +1 -0
  6. package/dist/{Factory-pNV7ZQ7-.d.cts → Factory-IdfEkOeT.d.cts} +24 -10
  7. package/dist/Factory.cjs +1 -1
  8. package/dist/Factory.d.cts +3 -3
  9. package/dist/Factory.d.mts +3 -3
  10. package/dist/Factory.mjs +1 -1
  11. package/dist/{KyselyFactory-DaaCykWP.cjs → KyselyFactory-BFqVIn_0.cjs} +21 -4
  12. package/dist/KyselyFactory-BFqVIn_0.cjs.map +1 -0
  13. package/dist/{KyselyFactory-CPZTUuMB.d.cts → KyselyFactory-Cj-EultY.d.mts} +18 -5
  14. package/dist/{KyselyFactory-CXY5gJk2.mjs → KyselyFactory-DMswpwji.mjs} +21 -4
  15. package/dist/KyselyFactory-DMswpwji.mjs.map +1 -0
  16. package/dist/{KyselyFactory-RAyvZ8Cj.d.mts → KyselyFactory-Dxhi_ZkA.d.cts} +18 -5
  17. package/dist/KyselyFactory.cjs +2 -2
  18. package/dist/KyselyFactory.d.cts +3 -3
  19. package/dist/KyselyFactory.d.mts +3 -3
  20. package/dist/KyselyFactory.mjs +2 -2
  21. package/dist/{ObjectionFactory-BlBicEia.d.mts → ObjectionFactory-BRAkAByP.d.cts} +18 -5
  22. package/dist/{ObjectionFactory-Eb04AOnv.cjs → ObjectionFactory-BeFBYcan.cjs} +21 -4
  23. package/dist/ObjectionFactory-BeFBYcan.cjs.map +1 -0
  24. package/dist/{ObjectionFactory-BwpN4gMX.d.cts → ObjectionFactory-DL4qkuF1.d.mts} +18 -5
  25. package/dist/{ObjectionFactory-zf2fLKrL.mjs → ObjectionFactory-QCJ7u0Ql.mjs} +21 -4
  26. package/dist/ObjectionFactory-QCJ7u0Ql.mjs.map +1 -0
  27. package/dist/ObjectionFactory.cjs +2 -2
  28. package/dist/ObjectionFactory.d.cts +3 -3
  29. package/dist/ObjectionFactory.d.mts +3 -3
  30. package/dist/ObjectionFactory.mjs +2 -2
  31. package/dist/{VitestKyselyTransactionIsolator-XDL3ngs_.mjs → VitestKyselyTransactionIsolator-CNURW8y6.mjs} +2 -2
  32. package/dist/{VitestKyselyTransactionIsolator-XDL3ngs_.mjs.map → VitestKyselyTransactionIsolator-CNURW8y6.mjs.map} +1 -1
  33. package/dist/{VitestKyselyTransactionIsolator-DiskaURs.d.mts → VitestKyselyTransactionIsolator-D3EZZhjZ.d.cts} +2 -2
  34. package/dist/{VitestKyselyTransactionIsolator-BqrZDeaT.d.cts → VitestKyselyTransactionIsolator-Dxlp1u0f.d.mts} +2 -2
  35. package/dist/{VitestKyselyTransactionIsolator-DX_VPKS-.cjs → VitestKyselyTransactionIsolator-EvDLk5zg.cjs} +2 -2
  36. package/dist/{VitestKyselyTransactionIsolator-DX_VPKS-.cjs.map → VitestKyselyTransactionIsolator-EvDLk5zg.cjs.map} +1 -1
  37. package/dist/VitestKyselyTransactionIsolator.cjs +2 -2
  38. package/dist/VitestKyselyTransactionIsolator.d.cts +2 -2
  39. package/dist/VitestKyselyTransactionIsolator.d.mts +2 -2
  40. package/dist/VitestKyselyTransactionIsolator.mjs +2 -2
  41. package/dist/{VitestObjectionTransactionIsolator-CD2ucJpH.d.cts → VitestObjectionTransactionIsolator-1TpsPqfG.d.cts} +2 -2
  42. package/dist/{VitestObjectionTransactionIsolator-D_tlOtq8.cjs → VitestObjectionTransactionIsolator-CM5KTAFA.cjs} +2 -2
  43. package/dist/{VitestObjectionTransactionIsolator-D_tlOtq8.cjs.map → VitestObjectionTransactionIsolator-CM5KTAFA.cjs.map} +1 -1
  44. package/dist/{VitestObjectionTransactionIsolator-DhQ8XGva.d.mts → VitestObjectionTransactionIsolator-i9jIgU8Q.d.mts} +2 -2
  45. package/dist/{VitestObjectionTransactionIsolator-_EhJKu_O.mjs → VitestObjectionTransactionIsolator-jQFaCz0u.mjs} +2 -2
  46. package/dist/{VitestObjectionTransactionIsolator-_EhJKu_O.mjs.map → VitestObjectionTransactionIsolator-jQFaCz0u.mjs.map} +1 -1
  47. package/dist/VitestObjectionTransactionIsolator.cjs +2 -2
  48. package/dist/VitestObjectionTransactionIsolator.d.cts +2 -2
  49. package/dist/VitestObjectionTransactionIsolator.d.mts +2 -2
  50. package/dist/VitestObjectionTransactionIsolator.mjs +2 -2
  51. package/dist/{VitestTransactionIsolator-DLdQlfZ5.d.mts → VitestTransactionIsolator-BvR19bYn.d.mts} +31 -14
  52. package/dist/{VitestTransactionIsolator-BKIrj3Uy.cjs → VitestTransactionIsolator-CMfJXZP8.cjs} +52 -36
  53. package/dist/VitestTransactionIsolator-CMfJXZP8.cjs.map +1 -0
  54. package/dist/{VitestTransactionIsolator-DfA80g2M.d.cts → VitestTransactionIsolator-CwQaxZLP.d.cts} +31 -14
  55. package/dist/{VitestTransactionIsolator-BIaMs4c2.mjs → VitestTransactionIsolator-DQ7tLqgV.mjs} +52 -36
  56. package/dist/VitestTransactionIsolator-DQ7tLqgV.mjs.map +1 -0
  57. package/dist/VitestTransactionIsolator.cjs +1 -1
  58. package/dist/VitestTransactionIsolator.d.cts +2 -2
  59. package/dist/VitestTransactionIsolator.d.mts +2 -2
  60. package/dist/VitestTransactionIsolator.mjs +1 -1
  61. package/dist/benchmark.cjs +49 -0
  62. package/dist/benchmark.cjs.map +1 -0
  63. package/dist/benchmark.d.cts +35 -0
  64. package/dist/benchmark.d.mts +35 -0
  65. package/dist/benchmark.mjs +45 -0
  66. package/dist/benchmark.mjs.map +1 -0
  67. package/dist/better-auth.d.cts +2 -2
  68. package/dist/better-auth.d.mts +2 -2
  69. package/dist/{directory-Q178x53k.d.mts → directory-BXavAeJZ.d.mts} +3 -3
  70. package/dist/{faker-BSH1EMtg.d.cts → faker-CbYiF-8_.d.cts} +3 -3
  71. package/dist/{faker-D9gz7KjY.d.mts → faker-DHh7xs4u.d.mts} +3 -3
  72. package/dist/faker.d.cts +1 -1
  73. package/dist/faker.d.mts +1 -1
  74. package/dist/kysely.cjs +25 -31
  75. package/dist/kysely.cjs.map +1 -1
  76. package/dist/kysely.d.cts +39 -34
  77. package/dist/kysely.d.mts +39 -34
  78. package/dist/kysely.mjs +25 -31
  79. package/dist/kysely.mjs.map +1 -1
  80. package/dist/objection.cjs +25 -49
  81. package/dist/objection.cjs.map +1 -1
  82. package/dist/objection.d.cts +39 -52
  83. package/dist/objection.d.mts +39 -52
  84. package/dist/objection.mjs +25 -49
  85. package/dist/objection.mjs.map +1 -1
  86. package/dist/os/directory.d.mts +1 -1
  87. package/dist/os/index.d.mts +1 -1
  88. package/package.json +6 -1
  89. package/src/Factory.ts +25 -11
  90. package/src/KyselyFactory.ts +21 -4
  91. package/src/ObjectionFactory.ts +21 -4
  92. package/src/VitestTransactionIsolator.ts +67 -16
  93. package/src/__tests__/Factory.spec.ts +16 -10
  94. package/src/__tests__/KyselyFactory.spec.ts +16 -11
  95. package/src/__tests__/ObjectionFactory.spec.ts +61 -53
  96. package/src/__tests__/VitestObjectionTransactionIsolator.spec.ts +6 -3
  97. package/src/__tests__/integration.spec.ts +24 -18
  98. package/src/benchmark.ts +48 -0
  99. package/src/kysely.ts +44 -33
  100. package/src/objection.ts +42 -51
  101. package/dist/Factory-WMhTNZ9S.cjs.map +0 -1
  102. package/dist/Factory-z2m01hMj.mjs.map +0 -1
  103. package/dist/KyselyFactory-CXY5gJk2.mjs.map +0 -1
  104. package/dist/KyselyFactory-DaaCykWP.cjs.map +0 -1
  105. package/dist/ObjectionFactory-Eb04AOnv.cjs.map +0 -1
  106. package/dist/ObjectionFactory-zf2fLKrL.mjs.map +0 -1
  107. package/dist/VitestTransactionIsolator-BIaMs4c2.mjs.map +0 -1
  108. package/dist/VitestTransactionIsolator-BKIrj3Uy.cjs.map +0 -1
@@ -1,4 +1,4 @@
1
- import * as _faker_js_faker0 from "@faker-js/faker";
1
+ import * as _faker_js_faker3 from "@faker-js/faker";
2
2
 
3
3
  //#region src/faker.d.ts
4
4
 
@@ -134,7 +134,7 @@ declare function coordinateOutsideRadius(center: Coordinate, minRadiusMeters: nu
134
134
  * const productPrice = faker.price();
135
135
  * ```
136
136
  */
137
- declare const faker: Readonly<_faker_js_faker0.Faker & {
137
+ declare const faker: Readonly<_faker_js_faker3.Faker & {
138
138
  timestamps: typeof timestamps;
139
139
  identifier: typeof identifier;
140
140
  sequence: typeof sequence;
@@ -163,4 +163,4 @@ type Timestamps = {
163
163
  type FakerFactory = typeof faker;
164
164
  //#endregion
165
165
  export { FakerFactory, Timestamps, coordinateInRadius, faker, identifier, resetAllSequences, resetSequence, sequence, timestamps };
166
- //# sourceMappingURL=faker-BSH1EMtg.d.cts.map
166
+ //# sourceMappingURL=faker-CbYiF-8_.d.cts.map
@@ -1,4 +1,4 @@
1
- import * as _faker_js_faker0 from "@faker-js/faker";
1
+ import * as _faker_js_faker1 from "@faker-js/faker";
2
2
 
3
3
  //#region src/faker.d.ts
4
4
 
@@ -134,7 +134,7 @@ declare function coordinateOutsideRadius(center: Coordinate, minRadiusMeters: nu
134
134
  * const productPrice = faker.price();
135
135
  * ```
136
136
  */
137
- declare const faker$1: Readonly<_faker_js_faker0.Faker & {
137
+ declare const faker$1: Readonly<_faker_js_faker1.Faker & {
138
138
  timestamps: typeof timestamps;
139
139
  identifier: typeof identifier;
140
140
  sequence: typeof sequence;
@@ -163,4 +163,4 @@ type Timestamps = {
163
163
  type FakerFactory = typeof faker$1;
164
164
  //#endregion
165
165
  export { FakerFactory, Timestamps, coordinateInRadius, faker$1 as faker, identifier, resetAllSequences, resetSequence, sequence, timestamps };
166
- //# sourceMappingURL=faker-D9gz7KjY.d.mts.map
166
+ //# sourceMappingURL=faker-DHh7xs4u.d.mts.map
package/dist/faker.d.cts CHANGED
@@ -1,2 +1,2 @@
1
- import { FakerFactory, Timestamps, coordinateInRadius, faker, identifier, resetAllSequences, resetSequence, sequence, timestamps } from "./faker-BSH1EMtg.cjs";
1
+ import { FakerFactory, Timestamps, coordinateInRadius, faker, identifier, resetAllSequences, resetSequence, sequence, timestamps } from "./faker-CbYiF-8_.cjs";
2
2
  export { FakerFactory, Timestamps, coordinateInRadius, faker, identifier, resetAllSequences, resetSequence, sequence, timestamps };
package/dist/faker.d.mts CHANGED
@@ -1,2 +1,2 @@
1
- import { FakerFactory, Timestamps, coordinateInRadius, faker, identifier, resetAllSequences, resetSequence, sequence, timestamps } from "./faker-D9gz7KjY.mjs";
1
+ import { FakerFactory, Timestamps, coordinateInRadius, faker, identifier, resetAllSequences, resetSequence, sequence, timestamps } from "./faker-DHh7xs4u.mjs";
2
2
  export { FakerFactory, Timestamps, coordinateInRadius, faker, identifier, resetAllSequences, resetSequence, sequence, timestamps };
package/dist/kysely.cjs CHANGED
@@ -1,10 +1,10 @@
1
- require('./Factory-WMhTNZ9S.cjs');
1
+ require('./Factory-BhjUOBWN.cjs');
2
2
  const require_faker = require('./faker-B14IEMIN.cjs');
3
- const require_KyselyFactory = require('./KyselyFactory-DaaCykWP.cjs');
3
+ const require_KyselyFactory = require('./KyselyFactory-BFqVIn_0.cjs');
4
4
  require('./PostgresMigrator-DFcNdCvD.cjs');
5
5
  const require_PostgresKyselyMigrator = require('./PostgresKyselyMigrator-CfytARcA.cjs');
6
- const require_VitestTransactionIsolator = require('./VitestTransactionIsolator-BKIrj3Uy.cjs');
7
- const require_VitestKyselyTransactionIsolator = require('./VitestKyselyTransactionIsolator-DX_VPKS-.cjs');
6
+ const require_VitestTransactionIsolator = require('./VitestTransactionIsolator-CMfJXZP8.cjs');
7
+ const require_VitestKyselyTransactionIsolator = require('./VitestKyselyTransactionIsolator-EvDLk5zg.cjs');
8
8
 
9
9
  //#region src/kysely.ts
10
10
  /**
@@ -13,10 +13,9 @@ const require_VitestKyselyTransactionIsolator = require('./VitestKyselyTransacti
13
13
  * This ensures tests don't affect each other's data and run faster than truncating tables.
14
14
  *
15
15
  * @template Database - The database schema type
16
+ * @template Extended - Additional fixtures to provide
16
17
  * @param api - The Vitest test API (usually `test` from vitest)
17
- * @param db - The Kysely database instance
18
- * @param setup - Optional setup function to run before each test in the transaction
19
- * @param level - Transaction isolation level (defaults to REPEATABLE_READ)
18
+ * @param options - Configuration options for transaction wrapping
20
19
  * @returns A wrapped test API that provides transaction isolation
21
20
  *
22
21
  * @example
@@ -26,7 +25,9 @@ const require_VitestKyselyTransactionIsolator = require('./VitestKyselyTransacti
26
25
  * import { db } from './database';
27
26
  *
28
27
  * // Create isolated test with automatic rollback
29
- * const isolatedTest = wrapVitestKyselyTransaction(test, db);
28
+ * const isolatedTest = wrapVitestKyselyTransaction(test, {
29
+ * connection: db,
30
+ * });
30
31
  *
31
32
  * // Use in tests - each test gets its own transaction
32
33
  * isolatedTest('should create user', async ({ trx }) => {
@@ -37,35 +38,25 @@ const require_VitestKyselyTransactionIsolator = require('./VitestKyselyTransacti
37
38
  * .executeTakeFirst();
38
39
  *
39
40
  * expect(user).toBeDefined();
40
- * // User is automatically rolled back after test
41
41
  * });
42
42
  *
43
- * // With setup function for common test data
44
- * const testWithSetup = wrapVitestKyselyTransaction(
45
- * test,
46
- * db,
47
- * async (trx) => {
48
- * // Create common test data
49
- * await trx.insertInto('settings')
50
- * .values({ key: 'test_mode', value: 'true' })
51
- * .execute();
52
- * }
53
- * );
54
- *
55
- * testWithSetup('should have test settings', async ({ trx }) => {
56
- * const setting = await trx
57
- * .selectFrom('settings')
58
- * .where('key', '=', 'test_mode')
59
- * .selectAll()
60
- * .executeTakeFirst();
43
+ * // With fixtures for factories
44
+ * const it = wrapVitestKyselyTransaction<DB, { factory: Factory }>(test, {
45
+ * connection: db,
46
+ * fixtures: {
47
+ * factory: (trx) => new Factory(trx),
48
+ * },
49
+ * });
61
50
  *
62
- * expect(setting?.value).toBe('true');
51
+ * it('should create user with factory', async ({ trx, factory }) => {
52
+ * const user = await factory.insert('user', { name: 'Test' });
53
+ * expect(user.id).toBeDefined();
63
54
  * });
64
55
  * ```
65
56
  */
66
- function wrapVitestKyselyTransaction(api, connection, setup, level = require_VitestTransactionIsolator.IsolationLevel.REPEATABLE_READ) {
57
+ function wrapVitestKyselyTransaction(api, options) {
67
58
  const wrapper = new require_VitestKyselyTransactionIsolator.VitestKyselyTransactionIsolator(api);
68
- return wrapper.wrapVitestWithTransaction(connection, setup, level);
59
+ return wrapper.wrapVitestWithTransaction(options);
69
60
  }
70
61
  /**
71
62
  * Extends a Kysely transaction-wrapped test with additional fixtures.
@@ -91,7 +82,10 @@ function wrapVitestKyselyTransaction(api, connection, setup, level = require_Vit
91
82
  * };
92
83
  *
93
84
  * // Create base wrapped test
94
- * const baseTest = wrapVitestKyselyTransaction<DB>(test, db, createTestTables);
85
+ * const baseTest = wrapVitestKyselyTransaction<DB>(test, {
86
+ * connection: db,
87
+ * setup: createTestTables,
88
+ * });
95
89
  *
96
90
  * // Extend with fixtures - each fixture receives the transaction
97
91
  * const it = extendWithFixtures<DB, { factory: KyselyFactory<DB, typeof builders, {}> }>(
@@ -1 +1 @@
1
- {"version":3,"file":"kysely.cjs","names":["api: TestAPI","connection: DatabaseConnection<Kysely<Database>>","setup?: (trx: Transaction<Database>) => Promise<void>","level: IsolationLevel","IsolationLevel","VitestKyselyTransactionIsolator","extendWithFixtures","wrappedTest: T","fixtures: FixtureCreators<Transaction<Database>, Extended>"],"sources":["../src/kysely.ts"],"sourcesContent":["import type { Kysely, Transaction } from 'kysely';\nimport type { TestAPI } from 'vitest';\nimport { VitestKyselyTransactionIsolator } from './VitestKyselyTransactionIsolator';\nimport {\n type DatabaseConnection,\n type FixtureCreators,\n IsolationLevel,\n extendWithFixtures as baseExtendWithFixtures,\n} from './VitestTransactionIsolator';\n\n/**\n * Kysely-specific exports for test utilities.\n * Provides factories, migrators, and transaction isolators for Kysely ORM.\n */\n\nexport { KyselyFactory } from './KyselyFactory';\nexport { PostgresKyselyMigrator } from './PostgresKyselyMigrator';\nexport { VitestKyselyTransactionIsolator } from './VitestKyselyTransactionIsolator';\nexport { IsolationLevel } from './VitestTransactionIsolator';\nexport type {\n DatabaseFixtures,\n ExtendedDatabaseFixtures,\n FixtureCreators,\n TestWithExtendedFixtures,\n} from './VitestTransactionIsolator';\n\n// Re-export faker and FakerFactory for type portability in declaration files\nexport { faker, type FakerFactory } from './faker';\n\n/**\n * Creates a wrapped Vitest test API with automatic transaction rollback for Kysely.\n * Each test runs in an isolated database transaction that is rolled back after completion.\n * This ensures tests don't affect each other's data and run faster than truncating tables.\n *\n * @template Database - The database schema type\n * @param api - The Vitest test API (usually `test` from vitest)\n * @param db - The Kysely database instance\n * @param setup - Optional setup function to run before each test in the transaction\n * @param level - Transaction isolation level (defaults to REPEATABLE_READ)\n * @returns A wrapped test API that provides transaction isolation\n *\n * @example\n * ```typescript\n * import { test } from 'vitest';\n * import { wrapVitestKyselyTransaction } from '@geekmidas/testkit/kysely';\n * import { db } from './database';\n *\n * // Create isolated test with automatic rollback\n * const isolatedTest = wrapVitestKyselyTransaction(test, db);\n *\n * // Use in tests - each test gets its own transaction\n * isolatedTest('should create user', async ({ trx }) => {\n * const user = await trx\n * .insertInto('users')\n * .values({ name: 'Test User', email: 'test@example.com' })\n * .returningAll()\n * .executeTakeFirst();\n *\n * expect(user).toBeDefined();\n * // User is automatically rolled back after test\n * });\n *\n * // With setup function for common test data\n * const testWithSetup = wrapVitestKyselyTransaction(\n * test,\n * db,\n * async (trx) => {\n * // Create common test data\n * await trx.insertInto('settings')\n * .values({ key: 'test_mode', value: 'true' })\n * .execute();\n * }\n * );\n *\n * testWithSetup('should have test settings', async ({ trx }) => {\n * const setting = await trx\n * .selectFrom('settings')\n * .where('key', '=', 'test_mode')\n * .selectAll()\n * .executeTakeFirst();\n *\n * expect(setting?.value).toBe('true');\n * });\n * ```\n */\nexport function wrapVitestKyselyTransaction<Database>(\n api: TestAPI,\n connection: DatabaseConnection<Kysely<Database>>,\n setup?: (trx: Transaction<Database>) => Promise<void>,\n level: IsolationLevel = IsolationLevel.REPEATABLE_READ,\n) {\n const wrapper = new VitestKyselyTransactionIsolator<Database>(api);\n\n return wrapper.wrapVitestWithTransaction(connection, setup, level);\n}\n\n/**\n * Extends a Kysely transaction-wrapped test with additional fixtures.\n * Each fixture receives the transaction and can create dependencies like factories or repositories.\n *\n * @template Database - The database schema type\n * @template Extended - The type of additional fixtures to provide\n * @param wrappedTest - The base wrapped test from wrapVitestKyselyTransaction\n * @param fixtures - Object mapping fixture names to creator functions\n * @returns An extended test API with both trx and the additional fixtures\n *\n * @example\n * ```typescript\n * import { test } from 'vitest';\n * import { wrapVitestKyselyTransaction, extendWithFixtures, KyselyFactory } from '@geekmidas/testkit/kysely';\n *\n * // Define your builders\n * const builders = {\n * user: KyselyFactory.createBuilder<DB, 'users'>('users', ({ faker }) => ({\n * name: faker.person.fullName(),\n * email: faker.internet.email(),\n * })),\n * };\n *\n * // Create base wrapped test\n * const baseTest = wrapVitestKyselyTransaction<DB>(test, db, createTestTables);\n *\n * // Extend with fixtures - each fixture receives the transaction\n * const it = extendWithFixtures<DB, { factory: KyselyFactory<DB, typeof builders, {}> }>(\n * baseTest,\n * {\n * factory: (trx) => new KyselyFactory(builders, {}, trx),\n * }\n * );\n *\n * // Use in tests - both trx and factory are available\n * it('should create user with factory', async ({ trx, factory }) => {\n * const user = await factory.insert('user', { name: 'Test User' });\n * expect(user.id).toBeDefined();\n *\n * // Verify in database\n * const found = await trx\n * .selectFrom('users')\n * .where('id', '=', user.id)\n * .selectAll()\n * .executeTakeFirst();\n * expect(found?.name).toBe('Test User');\n * });\n * ```\n */\nexport function extendWithFixtures<\n Database,\n Extended extends Record<string, unknown>,\n T extends ReturnType<TestAPI['extend']> = ReturnType<TestAPI['extend']>,\n>(wrappedTest: T, fixtures: FixtureCreators<Transaction<Database>, Extended>) {\n return baseExtendWithFixtures<Transaction<Database>, Extended, T>(\n wrappedTest,\n fixtures,\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAqFA,SAAgB,4BACdA,KACAC,YACAC,OACAC,QAAwBC,iDAAe,iBACvC;CACA,MAAM,UAAU,IAAIC,wEAA0C;AAE9D,QAAO,QAAQ,0BAA0B,YAAY,OAAO,MAAM;AACnE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAmDD,SAAgBC,qBAIdC,aAAgBC,UAA4D;AAC5E,QAAO,qDACL,aACA,SACD;AACF"}
1
+ {"version":3,"file":"kysely.cjs","names":["api: TestAPI","options: KyselyTransactionOptions<Database, Extended>","VitestKyselyTransactionIsolator","extendWithFixtures","wrappedTest: T","fixtures: FixtureCreators<Transaction<Database>, Extended>"],"sources":["../src/kysely.ts"],"sourcesContent":["import type { Kysely, Transaction } from 'kysely';\nimport type { TestAPI } from 'vitest';\nimport { VitestKyselyTransactionIsolator } from './VitestKyselyTransactionIsolator';\nimport {\n type DatabaseConnection,\n type FixtureCreators,\n type IsolationLevel,\n extendWithFixtures as baseExtendWithFixtures,\n} from './VitestTransactionIsolator';\n\n/**\n * Kysely-specific exports for test utilities.\n * Provides factories, migrators, and transaction isolators for Kysely ORM.\n */\n\nexport { KyselyFactory } from './KyselyFactory';\nexport type { ExtractSeedAttrs, FactorySeed } from './Factory';\nexport { PostgresKyselyMigrator } from './PostgresKyselyMigrator';\nexport { VitestKyselyTransactionIsolator } from './VitestKyselyTransactionIsolator';\nexport { IsolationLevel } from './VitestTransactionIsolator';\nexport type {\n DatabaseFixtures,\n ExtendedDatabaseFixtures,\n FixtureCreators,\n TestWithExtendedFixtures,\n TransactionWrapperOptions,\n} from './VitestTransactionIsolator';\n\n/**\n * Kysely-specific options for transaction wrapping.\n */\nexport interface KyselyTransactionOptions<\n Database,\n Extended extends Record<string, unknown> = {},\n> {\n /** Function that creates or returns a Kysely database instance */\n connection: DatabaseConnection<Kysely<Database>>;\n /** Optional setup function to run within the transaction before each test */\n setup?: (trx: Transaction<Database>) => Promise<void>;\n /** Transaction isolation level (defaults to REPEATABLE_READ) */\n isolationLevel?: IsolationLevel;\n /** Additional fixtures that depend on the transaction */\n fixtures?: FixtureCreators<Transaction<Database>, Extended>;\n}\n\n// Re-export faker and FakerFactory for type portability in declaration files\nexport { faker, type FakerFactory } from './faker';\n\n/**\n * Creates a wrapped Vitest test API with automatic transaction rollback for Kysely.\n * Each test runs in an isolated database transaction that is rolled back after completion.\n * This ensures tests don't affect each other's data and run faster than truncating tables.\n *\n * @template Database - The database schema type\n * @template Extended - Additional fixtures to provide\n * @param api - The Vitest test API (usually `test` from vitest)\n * @param options - Configuration options for transaction wrapping\n * @returns A wrapped test API that provides transaction isolation\n *\n * @example\n * ```typescript\n * import { test } from 'vitest';\n * import { wrapVitestKyselyTransaction } from '@geekmidas/testkit/kysely';\n * import { db } from './database';\n *\n * // Create isolated test with automatic rollback\n * const isolatedTest = wrapVitestKyselyTransaction(test, {\n * connection: db,\n * });\n *\n * // Use in tests - each test gets its own transaction\n * isolatedTest('should create user', async ({ trx }) => {\n * const user = await trx\n * .insertInto('users')\n * .values({ name: 'Test User', email: 'test@example.com' })\n * .returningAll()\n * .executeTakeFirst();\n *\n * expect(user).toBeDefined();\n * });\n *\n * // With fixtures for factories\n * const it = wrapVitestKyselyTransaction<DB, { factory: Factory }>(test, {\n * connection: db,\n * fixtures: {\n * factory: (trx) => new Factory(trx),\n * },\n * });\n *\n * it('should create user with factory', async ({ trx, factory }) => {\n * const user = await factory.insert('user', { name: 'Test' });\n * expect(user.id).toBeDefined();\n * });\n * ```\n */\nexport function wrapVitestKyselyTransaction<\n Database,\n Extended extends Record<string, unknown> = {},\n>(api: TestAPI, options: KyselyTransactionOptions<Database, Extended>) {\n const wrapper = new VitestKyselyTransactionIsolator<Database>(api);\n\n return wrapper.wrapVitestWithTransaction(options);\n}\n\n/**\n * Extends a Kysely transaction-wrapped test with additional fixtures.\n * Each fixture receives the transaction and can create dependencies like factories or repositories.\n *\n * @template Database - The database schema type\n * @template Extended - The type of additional fixtures to provide\n * @param wrappedTest - The base wrapped test from wrapVitestKyselyTransaction\n * @param fixtures - Object mapping fixture names to creator functions\n * @returns An extended test API with both trx and the additional fixtures\n *\n * @example\n * ```typescript\n * import { test } from 'vitest';\n * import { wrapVitestKyselyTransaction, extendWithFixtures, KyselyFactory } from '@geekmidas/testkit/kysely';\n *\n * // Define your builders\n * const builders = {\n * user: KyselyFactory.createBuilder<DB, 'users'>('users', ({ faker }) => ({\n * name: faker.person.fullName(),\n * email: faker.internet.email(),\n * })),\n * };\n *\n * // Create base wrapped test\n * const baseTest = wrapVitestKyselyTransaction<DB>(test, {\n * connection: db,\n * setup: createTestTables,\n * });\n *\n * // Extend with fixtures - each fixture receives the transaction\n * const it = extendWithFixtures<DB, { factory: KyselyFactory<DB, typeof builders, {}> }>(\n * baseTest,\n * {\n * factory: (trx) => new KyselyFactory(builders, {}, trx),\n * }\n * );\n *\n * // Use in tests - both trx and factory are available\n * it('should create user with factory', async ({ trx, factory }) => {\n * const user = await factory.insert('user', { name: 'Test User' });\n * expect(user.id).toBeDefined();\n *\n * // Verify in database\n * const found = await trx\n * .selectFrom('users')\n * .where('id', '=', user.id)\n * .selectAll()\n * .executeTakeFirst();\n * expect(found?.name).toBe('Test User');\n * });\n * ```\n */\nexport function extendWithFixtures<\n Database,\n Extended extends Record<string, unknown>,\n T extends ReturnType<TestAPI['extend']> = ReturnType<TestAPI['extend']>,\n>(wrappedTest: T, fixtures: FixtureCreators<Transaction<Database>, Extended>) {\n return baseExtendWithFixtures<Transaction<Database>, Extended, T>(\n wrappedTest,\n fixtures,\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA+FA,SAAgB,4BAGdA,KAAcC,SAAuD;CACrE,MAAM,UAAU,IAAIC,wEAA0C;AAE9D,QAAO,QAAQ,0BAA0B,QAAQ;AAClD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAsDD,SAAgBC,qBAIdC,aAAgBC,UAA4D;AAC5E,QAAO,qDACL,aACA,SACD;AACF"}
package/dist/kysely.d.cts CHANGED
@@ -1,25 +1,37 @@
1
- import { FakerFactory, faker } from "./faker-BSH1EMtg.cjs";
2
- import "./Factory-pNV7ZQ7-.cjs";
3
- import { KyselyFactory } from "./KyselyFactory-CPZTUuMB.cjs";
1
+ import { FakerFactory, faker } from "./faker-CbYiF-8_.cjs";
2
+ import { ExtractSeedAttrs, FactorySeed } from "./Factory-IdfEkOeT.cjs";
3
+ import { KyselyFactory } from "./KyselyFactory-Dxhi_ZkA.cjs";
4
4
  import "./PostgresMigrator-D5UkK1_K.cjs";
5
5
  import { PostgresKyselyMigrator } from "./PostgresKyselyMigrator-CQ3aUoy_.cjs";
6
- import { DatabaseConnection, DatabaseFixtures, ExtendedDatabaseFixtures, FixtureCreators, IsolationLevel, TestWithExtendedFixtures } from "./VitestTransactionIsolator-DfA80g2M.cjs";
7
- import { VitestKyselyTransactionIsolator } from "./VitestKyselyTransactionIsolator-BqrZDeaT.cjs";
6
+ import { DatabaseConnection, DatabaseFixtures, ExtendedDatabaseFixtures, FixtureCreators, IsolationLevel, TestWithExtendedFixtures, TransactionWrapperOptions } from "./VitestTransactionIsolator-CwQaxZLP.cjs";
7
+ import { VitestKyselyTransactionIsolator } from "./VitestKyselyTransactionIsolator-D3EZZhjZ.cjs";
8
8
  import { Kysely, Transaction } from "kysely";
9
9
  import { TestAPI } from "vitest";
10
10
 
11
11
  //#region src/kysely.d.ts
12
12
 
13
+ /**
14
+ * Kysely-specific options for transaction wrapping.
15
+ */
16
+ interface KyselyTransactionOptions<Database, Extended extends Record<string, unknown> = {}> {
17
+ /** Function that creates or returns a Kysely database instance */
18
+ connection: DatabaseConnection<Kysely<Database>>;
19
+ /** Optional setup function to run within the transaction before each test */
20
+ setup?: (trx: Transaction<Database>) => Promise<void>;
21
+ /** Transaction isolation level (defaults to REPEATABLE_READ) */
22
+ isolationLevel?: IsolationLevel;
23
+ /** Additional fixtures that depend on the transaction */
24
+ fixtures?: FixtureCreators<Transaction<Database>, Extended>;
25
+ }
13
26
  /**
14
27
  * Creates a wrapped Vitest test API with automatic transaction rollback for Kysely.
15
28
  * Each test runs in an isolated database transaction that is rolled back after completion.
16
29
  * This ensures tests don't affect each other's data and run faster than truncating tables.
17
30
  *
18
31
  * @template Database - The database schema type
32
+ * @template Extended - Additional fixtures to provide
19
33
  * @param api - The Vitest test API (usually `test` from vitest)
20
- * @param db - The Kysely database instance
21
- * @param setup - Optional setup function to run before each test in the transaction
22
- * @param level - Transaction isolation level (defaults to REPEATABLE_READ)
34
+ * @param options - Configuration options for transaction wrapping
23
35
  * @returns A wrapped test API that provides transaction isolation
24
36
  *
25
37
  * @example
@@ -29,7 +41,9 @@ import { TestAPI } from "vitest";
29
41
  * import { db } from './database';
30
42
  *
31
43
  * // Create isolated test with automatic rollback
32
- * const isolatedTest = wrapVitestKyselyTransaction(test, db);
44
+ * const isolatedTest = wrapVitestKyselyTransaction(test, {
45
+ * connection: db,
46
+ * });
33
47
  *
34
48
  * // Use in tests - each test gets its own transaction
35
49
  * isolatedTest('should create user', async ({ trx }) => {
@@ -40,35 +54,23 @@ import { TestAPI } from "vitest";
40
54
  * .executeTakeFirst();
41
55
  *
42
56
  * expect(user).toBeDefined();
43
- * // User is automatically rolled back after test
44
57
  * });
45
58
  *
46
- * // With setup function for common test data
47
- * const testWithSetup = wrapVitestKyselyTransaction(
48
- * test,
49
- * db,
50
- * async (trx) => {
51
- * // Create common test data
52
- * await trx.insertInto('settings')
53
- * .values({ key: 'test_mode', value: 'true' })
54
- * .execute();
55
- * }
56
- * );
57
- *
58
- * testWithSetup('should have test settings', async ({ trx }) => {
59
- * const setting = await trx
60
- * .selectFrom('settings')
61
- * .where('key', '=', 'test_mode')
62
- * .selectAll()
63
- * .executeTakeFirst();
59
+ * // With fixtures for factories
60
+ * const it = wrapVitestKyselyTransaction<DB, { factory: Factory }>(test, {
61
+ * connection: db,
62
+ * fixtures: {
63
+ * factory: (trx) => new Factory(trx),
64
+ * },
65
+ * });
64
66
  *
65
- * expect(setting?.value).toBe('true');
67
+ * it('should create user with factory', async ({ trx, factory }) => {
68
+ * const user = await factory.insert('user', { name: 'Test' });
69
+ * expect(user.id).toBeDefined();
66
70
  * });
67
71
  * ```
68
72
  */
69
- declare function wrapVitestKyselyTransaction<Database>(api: TestAPI, connection: DatabaseConnection<Kysely<Database>>, setup?: (trx: Transaction<Database>) => Promise<void>, level?: IsolationLevel): TestAPI<{
70
- trx: Transaction<Database>;
71
- }>;
73
+ declare function wrapVitestKyselyTransaction<Database, Extended extends Record<string, unknown> = {}>(api: TestAPI, options: KyselyTransactionOptions<Database, Extended>): TestAPI<DatabaseFixtures<Transaction<Database>, object> & Extended>;
72
74
  /**
73
75
  * Extends a Kysely transaction-wrapped test with additional fixtures.
74
76
  * Each fixture receives the transaction and can create dependencies like factories or repositories.
@@ -93,7 +95,10 @@ declare function wrapVitestKyselyTransaction<Database>(api: TestAPI, connection:
93
95
  * };
94
96
  *
95
97
  * // Create base wrapped test
96
- * const baseTest = wrapVitestKyselyTransaction<DB>(test, db, createTestTables);
98
+ * const baseTest = wrapVitestKyselyTransaction<DB>(test, {
99
+ * connection: db,
100
+ * setup: createTestTables,
101
+ * });
97
102
  *
98
103
  * // Extend with fixtures - each fixture receives the transaction
99
104
  * const it = extendWithFixtures<DB, { factory: KyselyFactory<DB, typeof builders, {}> }>(
@@ -120,5 +125,5 @@ declare function wrapVitestKyselyTransaction<Database>(api: TestAPI, connection:
120
125
  */
121
126
  declare function extendWithFixtures<Database, Extended extends Record<string, unknown>, T extends ReturnType<TestAPI['extend']> = ReturnType<TestAPI['extend']>>(wrappedTest: T, fixtures: FixtureCreators<Transaction<Database>, Extended>): TestWithExtendedFixtures<Transaction<Database>, Extended, T>;
122
127
  //#endregion
123
- export { DatabaseFixtures, ExtendedDatabaseFixtures, FakerFactory, FixtureCreators, IsolationLevel, KyselyFactory, PostgresKyselyMigrator, TestWithExtendedFixtures, VitestKyselyTransactionIsolator, extendWithFixtures, faker, wrapVitestKyselyTransaction };
128
+ export { DatabaseFixtures, ExtendedDatabaseFixtures, ExtractSeedAttrs, FactorySeed, FakerFactory, FixtureCreators, IsolationLevel, KyselyFactory, KyselyTransactionOptions, PostgresKyselyMigrator, TestWithExtendedFixtures, TransactionWrapperOptions, VitestKyselyTransactionIsolator, extendWithFixtures, faker, wrapVitestKyselyTransaction };
124
129
  //# sourceMappingURL=kysely.d.cts.map
package/dist/kysely.d.mts CHANGED
@@ -1,25 +1,37 @@
1
- import { FakerFactory, faker } from "./faker-D9gz7KjY.mjs";
2
- import "./Factory-DE3hE0WO.mjs";
3
- import { KyselyFactory } from "./KyselyFactory-RAyvZ8Cj.mjs";
1
+ import { FakerFactory, faker } from "./faker-DHh7xs4u.mjs";
2
+ import { ExtractSeedAttrs, FactorySeed } from "./Factory-BcGJjLc8.mjs";
3
+ import { KyselyFactory } from "./KyselyFactory-Cj-EultY.mjs";
4
4
  import "./PostgresMigrator-DQaRxoaY.mjs";
5
5
  import { PostgresKyselyMigrator } from "./PostgresKyselyMigrator-CIx3AFSR.mjs";
6
- import { DatabaseConnection, DatabaseFixtures, ExtendedDatabaseFixtures, FixtureCreators, IsolationLevel, TestWithExtendedFixtures } from "./VitestTransactionIsolator-DLdQlfZ5.mjs";
7
- import { VitestKyselyTransactionIsolator } from "./VitestKyselyTransactionIsolator-DiskaURs.mjs";
6
+ import { DatabaseConnection, DatabaseFixtures, ExtendedDatabaseFixtures, FixtureCreators, IsolationLevel, TestWithExtendedFixtures, TransactionWrapperOptions } from "./VitestTransactionIsolator-BvR19bYn.mjs";
7
+ import { VitestKyselyTransactionIsolator } from "./VitestKyselyTransactionIsolator-Dxlp1u0f.mjs";
8
8
  import { Kysely, Transaction } from "kysely";
9
9
  import { TestAPI } from "vitest";
10
10
 
11
11
  //#region src/kysely.d.ts
12
12
 
13
+ /**
14
+ * Kysely-specific options for transaction wrapping.
15
+ */
16
+ interface KyselyTransactionOptions<Database, Extended extends Record<string, unknown> = {}> {
17
+ /** Function that creates or returns a Kysely database instance */
18
+ connection: DatabaseConnection<Kysely<Database>>;
19
+ /** Optional setup function to run within the transaction before each test */
20
+ setup?: (trx: Transaction<Database>) => Promise<void>;
21
+ /** Transaction isolation level (defaults to REPEATABLE_READ) */
22
+ isolationLevel?: IsolationLevel;
23
+ /** Additional fixtures that depend on the transaction */
24
+ fixtures?: FixtureCreators<Transaction<Database>, Extended>;
25
+ }
13
26
  /**
14
27
  * Creates a wrapped Vitest test API with automatic transaction rollback for Kysely.
15
28
  * Each test runs in an isolated database transaction that is rolled back after completion.
16
29
  * This ensures tests don't affect each other's data and run faster than truncating tables.
17
30
  *
18
31
  * @template Database - The database schema type
32
+ * @template Extended - Additional fixtures to provide
19
33
  * @param api - The Vitest test API (usually `test` from vitest)
20
- * @param db - The Kysely database instance
21
- * @param setup - Optional setup function to run before each test in the transaction
22
- * @param level - Transaction isolation level (defaults to REPEATABLE_READ)
34
+ * @param options - Configuration options for transaction wrapping
23
35
  * @returns A wrapped test API that provides transaction isolation
24
36
  *
25
37
  * @example
@@ -29,7 +41,9 @@ import { TestAPI } from "vitest";
29
41
  * import { db } from './database';
30
42
  *
31
43
  * // Create isolated test with automatic rollback
32
- * const isolatedTest = wrapVitestKyselyTransaction(test, db);
44
+ * const isolatedTest = wrapVitestKyselyTransaction(test, {
45
+ * connection: db,
46
+ * });
33
47
  *
34
48
  * // Use in tests - each test gets its own transaction
35
49
  * isolatedTest('should create user', async ({ trx }) => {
@@ -40,35 +54,23 @@ import { TestAPI } from "vitest";
40
54
  * .executeTakeFirst();
41
55
  *
42
56
  * expect(user).toBeDefined();
43
- * // User is automatically rolled back after test
44
57
  * });
45
58
  *
46
- * // With setup function for common test data
47
- * const testWithSetup = wrapVitestKyselyTransaction(
48
- * test,
49
- * db,
50
- * async (trx) => {
51
- * // Create common test data
52
- * await trx.insertInto('settings')
53
- * .values({ key: 'test_mode', value: 'true' })
54
- * .execute();
55
- * }
56
- * );
57
- *
58
- * testWithSetup('should have test settings', async ({ trx }) => {
59
- * const setting = await trx
60
- * .selectFrom('settings')
61
- * .where('key', '=', 'test_mode')
62
- * .selectAll()
63
- * .executeTakeFirst();
59
+ * // With fixtures for factories
60
+ * const it = wrapVitestKyselyTransaction<DB, { factory: Factory }>(test, {
61
+ * connection: db,
62
+ * fixtures: {
63
+ * factory: (trx) => new Factory(trx),
64
+ * },
65
+ * });
64
66
  *
65
- * expect(setting?.value).toBe('true');
67
+ * it('should create user with factory', async ({ trx, factory }) => {
68
+ * const user = await factory.insert('user', { name: 'Test' });
69
+ * expect(user.id).toBeDefined();
66
70
  * });
67
71
  * ```
68
72
  */
69
- declare function wrapVitestKyselyTransaction<Database>(api: TestAPI, connection: DatabaseConnection<Kysely<Database>>, setup?: (trx: Transaction<Database>) => Promise<void>, level?: IsolationLevel): TestAPI<{
70
- trx: Transaction<Database>;
71
- }>;
73
+ declare function wrapVitestKyselyTransaction<Database, Extended extends Record<string, unknown> = {}>(api: TestAPI, options: KyselyTransactionOptions<Database, Extended>): TestAPI<DatabaseFixtures<Transaction<Database>, object> & Extended>;
72
74
  /**
73
75
  * Extends a Kysely transaction-wrapped test with additional fixtures.
74
76
  * Each fixture receives the transaction and can create dependencies like factories or repositories.
@@ -93,7 +95,10 @@ declare function wrapVitestKyselyTransaction<Database>(api: TestAPI, connection:
93
95
  * };
94
96
  *
95
97
  * // Create base wrapped test
96
- * const baseTest = wrapVitestKyselyTransaction<DB>(test, db, createTestTables);
98
+ * const baseTest = wrapVitestKyselyTransaction<DB>(test, {
99
+ * connection: db,
100
+ * setup: createTestTables,
101
+ * });
97
102
  *
98
103
  * // Extend with fixtures - each fixture receives the transaction
99
104
  * const it = extendWithFixtures<DB, { factory: KyselyFactory<DB, typeof builders, {}> }>(
@@ -120,5 +125,5 @@ declare function wrapVitestKyselyTransaction<Database>(api: TestAPI, connection:
120
125
  */
121
126
  declare function extendWithFixtures<Database, Extended extends Record<string, unknown>, T extends ReturnType<TestAPI['extend']> = ReturnType<TestAPI['extend']>>(wrappedTest: T, fixtures: FixtureCreators<Transaction<Database>, Extended>): TestWithExtendedFixtures<Transaction<Database>, Extended, T>;
122
127
  //#endregion
123
- export { DatabaseFixtures, ExtendedDatabaseFixtures, FakerFactory, FixtureCreators, IsolationLevel, KyselyFactory, PostgresKyselyMigrator, TestWithExtendedFixtures, VitestKyselyTransactionIsolator, extendWithFixtures, faker, wrapVitestKyselyTransaction };
128
+ export { DatabaseFixtures, ExtendedDatabaseFixtures, ExtractSeedAttrs, FactorySeed, FakerFactory, FixtureCreators, IsolationLevel, KyselyFactory, KyselyTransactionOptions, PostgresKyselyMigrator, TestWithExtendedFixtures, TransactionWrapperOptions, VitestKyselyTransactionIsolator, extendWithFixtures, faker, wrapVitestKyselyTransaction };
124
129
  //# sourceMappingURL=kysely.d.mts.map
package/dist/kysely.mjs CHANGED
@@ -1,10 +1,10 @@
1
- import "./Factory-z2m01hMj.mjs";
1
+ import "./Factory-BFVnMMCC.mjs";
2
2
  import { faker } from "./faker-BGKYFoCT.mjs";
3
- import { KyselyFactory } from "./KyselyFactory-CXY5gJk2.mjs";
3
+ import { KyselyFactory } from "./KyselyFactory-DMswpwji.mjs";
4
4
  import "./PostgresMigrator-DbuJGAVy.mjs";
5
5
  import { PostgresKyselyMigrator } from "./PostgresKyselyMigrator-upT-hmrz.mjs";
6
- import { IsolationLevel, extendWithFixtures } from "./VitestTransactionIsolator-BIaMs4c2.mjs";
7
- import { VitestKyselyTransactionIsolator } from "./VitestKyselyTransactionIsolator-XDL3ngs_.mjs";
6
+ import { IsolationLevel, extendWithFixtures } from "./VitestTransactionIsolator-DQ7tLqgV.mjs";
7
+ import { VitestKyselyTransactionIsolator } from "./VitestKyselyTransactionIsolator-CNURW8y6.mjs";
8
8
 
9
9
  //#region src/kysely.ts
10
10
  /**
@@ -13,10 +13,9 @@ import { VitestKyselyTransactionIsolator } from "./VitestKyselyTransactionIsolat
13
13
  * This ensures tests don't affect each other's data and run faster than truncating tables.
14
14
  *
15
15
  * @template Database - The database schema type
16
+ * @template Extended - Additional fixtures to provide
16
17
  * @param api - The Vitest test API (usually `test` from vitest)
17
- * @param db - The Kysely database instance
18
- * @param setup - Optional setup function to run before each test in the transaction
19
- * @param level - Transaction isolation level (defaults to REPEATABLE_READ)
18
+ * @param options - Configuration options for transaction wrapping
20
19
  * @returns A wrapped test API that provides transaction isolation
21
20
  *
22
21
  * @example
@@ -26,7 +25,9 @@ import { VitestKyselyTransactionIsolator } from "./VitestKyselyTransactionIsolat
26
25
  * import { db } from './database';
27
26
  *
28
27
  * // Create isolated test with automatic rollback
29
- * const isolatedTest = wrapVitestKyselyTransaction(test, db);
28
+ * const isolatedTest = wrapVitestKyselyTransaction(test, {
29
+ * connection: db,
30
+ * });
30
31
  *
31
32
  * // Use in tests - each test gets its own transaction
32
33
  * isolatedTest('should create user', async ({ trx }) => {
@@ -37,35 +38,25 @@ import { VitestKyselyTransactionIsolator } from "./VitestKyselyTransactionIsolat
37
38
  * .executeTakeFirst();
38
39
  *
39
40
  * expect(user).toBeDefined();
40
- * // User is automatically rolled back after test
41
41
  * });
42
42
  *
43
- * // With setup function for common test data
44
- * const testWithSetup = wrapVitestKyselyTransaction(
45
- * test,
46
- * db,
47
- * async (trx) => {
48
- * // Create common test data
49
- * await trx.insertInto('settings')
50
- * .values({ key: 'test_mode', value: 'true' })
51
- * .execute();
52
- * }
53
- * );
54
- *
55
- * testWithSetup('should have test settings', async ({ trx }) => {
56
- * const setting = await trx
57
- * .selectFrom('settings')
58
- * .where('key', '=', 'test_mode')
59
- * .selectAll()
60
- * .executeTakeFirst();
43
+ * // With fixtures for factories
44
+ * const it = wrapVitestKyselyTransaction<DB, { factory: Factory }>(test, {
45
+ * connection: db,
46
+ * fixtures: {
47
+ * factory: (trx) => new Factory(trx),
48
+ * },
49
+ * });
61
50
  *
62
- * expect(setting?.value).toBe('true');
51
+ * it('should create user with factory', async ({ trx, factory }) => {
52
+ * const user = await factory.insert('user', { name: 'Test' });
53
+ * expect(user.id).toBeDefined();
63
54
  * });
64
55
  * ```
65
56
  */
66
- function wrapVitestKyselyTransaction(api, connection, setup, level = IsolationLevel.REPEATABLE_READ) {
57
+ function wrapVitestKyselyTransaction(api, options) {
67
58
  const wrapper = new VitestKyselyTransactionIsolator(api);
68
- return wrapper.wrapVitestWithTransaction(connection, setup, level);
59
+ return wrapper.wrapVitestWithTransaction(options);
69
60
  }
70
61
  /**
71
62
  * Extends a Kysely transaction-wrapped test with additional fixtures.
@@ -91,7 +82,10 @@ function wrapVitestKyselyTransaction(api, connection, setup, level = IsolationLe
91
82
  * };
92
83
  *
93
84
  * // Create base wrapped test
94
- * const baseTest = wrapVitestKyselyTransaction<DB>(test, db, createTestTables);
85
+ * const baseTest = wrapVitestKyselyTransaction<DB>(test, {
86
+ * connection: db,
87
+ * setup: createTestTables,
88
+ * });
95
89
  *
96
90
  * // Extend with fixtures - each fixture receives the transaction
97
91
  * const it = extendWithFixtures<DB, { factory: KyselyFactory<DB, typeof builders, {}> }>(
@@ -1 +1 @@
1
- {"version":3,"file":"kysely.mjs","names":["api: TestAPI","connection: DatabaseConnection<Kysely<Database>>","setup?: (trx: Transaction<Database>) => Promise<void>","level: IsolationLevel","extendWithFixtures","wrappedTest: T","fixtures: FixtureCreators<Transaction<Database>, Extended>"],"sources":["../src/kysely.ts"],"sourcesContent":["import type { Kysely, Transaction } from 'kysely';\nimport type { TestAPI } from 'vitest';\nimport { VitestKyselyTransactionIsolator } from './VitestKyselyTransactionIsolator';\nimport {\n type DatabaseConnection,\n type FixtureCreators,\n IsolationLevel,\n extendWithFixtures as baseExtendWithFixtures,\n} from './VitestTransactionIsolator';\n\n/**\n * Kysely-specific exports for test utilities.\n * Provides factories, migrators, and transaction isolators for Kysely ORM.\n */\n\nexport { KyselyFactory } from './KyselyFactory';\nexport { PostgresKyselyMigrator } from './PostgresKyselyMigrator';\nexport { VitestKyselyTransactionIsolator } from './VitestKyselyTransactionIsolator';\nexport { IsolationLevel } from './VitestTransactionIsolator';\nexport type {\n DatabaseFixtures,\n ExtendedDatabaseFixtures,\n FixtureCreators,\n TestWithExtendedFixtures,\n} from './VitestTransactionIsolator';\n\n// Re-export faker and FakerFactory for type portability in declaration files\nexport { faker, type FakerFactory } from './faker';\n\n/**\n * Creates a wrapped Vitest test API with automatic transaction rollback for Kysely.\n * Each test runs in an isolated database transaction that is rolled back after completion.\n * This ensures tests don't affect each other's data and run faster than truncating tables.\n *\n * @template Database - The database schema type\n * @param api - The Vitest test API (usually `test` from vitest)\n * @param db - The Kysely database instance\n * @param setup - Optional setup function to run before each test in the transaction\n * @param level - Transaction isolation level (defaults to REPEATABLE_READ)\n * @returns A wrapped test API that provides transaction isolation\n *\n * @example\n * ```typescript\n * import { test } from 'vitest';\n * import { wrapVitestKyselyTransaction } from '@geekmidas/testkit/kysely';\n * import { db } from './database';\n *\n * // Create isolated test with automatic rollback\n * const isolatedTest = wrapVitestKyselyTransaction(test, db);\n *\n * // Use in tests - each test gets its own transaction\n * isolatedTest('should create user', async ({ trx }) => {\n * const user = await trx\n * .insertInto('users')\n * .values({ name: 'Test User', email: 'test@example.com' })\n * .returningAll()\n * .executeTakeFirst();\n *\n * expect(user).toBeDefined();\n * // User is automatically rolled back after test\n * });\n *\n * // With setup function for common test data\n * const testWithSetup = wrapVitestKyselyTransaction(\n * test,\n * db,\n * async (trx) => {\n * // Create common test data\n * await trx.insertInto('settings')\n * .values({ key: 'test_mode', value: 'true' })\n * .execute();\n * }\n * );\n *\n * testWithSetup('should have test settings', async ({ trx }) => {\n * const setting = await trx\n * .selectFrom('settings')\n * .where('key', '=', 'test_mode')\n * .selectAll()\n * .executeTakeFirst();\n *\n * expect(setting?.value).toBe('true');\n * });\n * ```\n */\nexport function wrapVitestKyselyTransaction<Database>(\n api: TestAPI,\n connection: DatabaseConnection<Kysely<Database>>,\n setup?: (trx: Transaction<Database>) => Promise<void>,\n level: IsolationLevel = IsolationLevel.REPEATABLE_READ,\n) {\n const wrapper = new VitestKyselyTransactionIsolator<Database>(api);\n\n return wrapper.wrapVitestWithTransaction(connection, setup, level);\n}\n\n/**\n * Extends a Kysely transaction-wrapped test with additional fixtures.\n * Each fixture receives the transaction and can create dependencies like factories or repositories.\n *\n * @template Database - The database schema type\n * @template Extended - The type of additional fixtures to provide\n * @param wrappedTest - The base wrapped test from wrapVitestKyselyTransaction\n * @param fixtures - Object mapping fixture names to creator functions\n * @returns An extended test API with both trx and the additional fixtures\n *\n * @example\n * ```typescript\n * import { test } from 'vitest';\n * import { wrapVitestKyselyTransaction, extendWithFixtures, KyselyFactory } from '@geekmidas/testkit/kysely';\n *\n * // Define your builders\n * const builders = {\n * user: KyselyFactory.createBuilder<DB, 'users'>('users', ({ faker }) => ({\n * name: faker.person.fullName(),\n * email: faker.internet.email(),\n * })),\n * };\n *\n * // Create base wrapped test\n * const baseTest = wrapVitestKyselyTransaction<DB>(test, db, createTestTables);\n *\n * // Extend with fixtures - each fixture receives the transaction\n * const it = extendWithFixtures<DB, { factory: KyselyFactory<DB, typeof builders, {}> }>(\n * baseTest,\n * {\n * factory: (trx) => new KyselyFactory(builders, {}, trx),\n * }\n * );\n *\n * // Use in tests - both trx and factory are available\n * it('should create user with factory', async ({ trx, factory }) => {\n * const user = await factory.insert('user', { name: 'Test User' });\n * expect(user.id).toBeDefined();\n *\n * // Verify in database\n * const found = await trx\n * .selectFrom('users')\n * .where('id', '=', user.id)\n * .selectAll()\n * .executeTakeFirst();\n * expect(found?.name).toBe('Test User');\n * });\n * ```\n */\nexport function extendWithFixtures<\n Database,\n Extended extends Record<string, unknown>,\n T extends ReturnType<TestAPI['extend']> = ReturnType<TestAPI['extend']>,\n>(wrappedTest: T, fixtures: FixtureCreators<Transaction<Database>, Extended>) {\n return baseExtendWithFixtures<Transaction<Database>, Extended, T>(\n wrappedTest,\n fixtures,\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAqFA,SAAgB,4BACdA,KACAC,YACAC,OACAC,QAAwB,eAAe,iBACvC;CACA,MAAM,UAAU,IAAI,gCAA0C;AAE9D,QAAO,QAAQ,0BAA0B,YAAY,OAAO,MAAM;AACnE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAmDD,SAAgBC,qBAIdC,aAAgBC,UAA4D;AAC5E,QAAO,mBACL,aACA,SACD;AACF"}
1
+ {"version":3,"file":"kysely.mjs","names":["api: TestAPI","options: KyselyTransactionOptions<Database, Extended>","extendWithFixtures","wrappedTest: T","fixtures: FixtureCreators<Transaction<Database>, Extended>"],"sources":["../src/kysely.ts"],"sourcesContent":["import type { Kysely, Transaction } from 'kysely';\nimport type { TestAPI } from 'vitest';\nimport { VitestKyselyTransactionIsolator } from './VitestKyselyTransactionIsolator';\nimport {\n type DatabaseConnection,\n type FixtureCreators,\n type IsolationLevel,\n extendWithFixtures as baseExtendWithFixtures,\n} from './VitestTransactionIsolator';\n\n/**\n * Kysely-specific exports for test utilities.\n * Provides factories, migrators, and transaction isolators for Kysely ORM.\n */\n\nexport { KyselyFactory } from './KyselyFactory';\nexport type { ExtractSeedAttrs, FactorySeed } from './Factory';\nexport { PostgresKyselyMigrator } from './PostgresKyselyMigrator';\nexport { VitestKyselyTransactionIsolator } from './VitestKyselyTransactionIsolator';\nexport { IsolationLevel } from './VitestTransactionIsolator';\nexport type {\n DatabaseFixtures,\n ExtendedDatabaseFixtures,\n FixtureCreators,\n TestWithExtendedFixtures,\n TransactionWrapperOptions,\n} from './VitestTransactionIsolator';\n\n/**\n * Kysely-specific options for transaction wrapping.\n */\nexport interface KyselyTransactionOptions<\n Database,\n Extended extends Record<string, unknown> = {},\n> {\n /** Function that creates or returns a Kysely database instance */\n connection: DatabaseConnection<Kysely<Database>>;\n /** Optional setup function to run within the transaction before each test */\n setup?: (trx: Transaction<Database>) => Promise<void>;\n /** Transaction isolation level (defaults to REPEATABLE_READ) */\n isolationLevel?: IsolationLevel;\n /** Additional fixtures that depend on the transaction */\n fixtures?: FixtureCreators<Transaction<Database>, Extended>;\n}\n\n// Re-export faker and FakerFactory for type portability in declaration files\nexport { faker, type FakerFactory } from './faker';\n\n/**\n * Creates a wrapped Vitest test API with automatic transaction rollback for Kysely.\n * Each test runs in an isolated database transaction that is rolled back after completion.\n * This ensures tests don't affect each other's data and run faster than truncating tables.\n *\n * @template Database - The database schema type\n * @template Extended - Additional fixtures to provide\n * @param api - The Vitest test API (usually `test` from vitest)\n * @param options - Configuration options for transaction wrapping\n * @returns A wrapped test API that provides transaction isolation\n *\n * @example\n * ```typescript\n * import { test } from 'vitest';\n * import { wrapVitestKyselyTransaction } from '@geekmidas/testkit/kysely';\n * import { db } from './database';\n *\n * // Create isolated test with automatic rollback\n * const isolatedTest = wrapVitestKyselyTransaction(test, {\n * connection: db,\n * });\n *\n * // Use in tests - each test gets its own transaction\n * isolatedTest('should create user', async ({ trx }) => {\n * const user = await trx\n * .insertInto('users')\n * .values({ name: 'Test User', email: 'test@example.com' })\n * .returningAll()\n * .executeTakeFirst();\n *\n * expect(user).toBeDefined();\n * });\n *\n * // With fixtures for factories\n * const it = wrapVitestKyselyTransaction<DB, { factory: Factory }>(test, {\n * connection: db,\n * fixtures: {\n * factory: (trx) => new Factory(trx),\n * },\n * });\n *\n * it('should create user with factory', async ({ trx, factory }) => {\n * const user = await factory.insert('user', { name: 'Test' });\n * expect(user.id).toBeDefined();\n * });\n * ```\n */\nexport function wrapVitestKyselyTransaction<\n Database,\n Extended extends Record<string, unknown> = {},\n>(api: TestAPI, options: KyselyTransactionOptions<Database, Extended>) {\n const wrapper = new VitestKyselyTransactionIsolator<Database>(api);\n\n return wrapper.wrapVitestWithTransaction(options);\n}\n\n/**\n * Extends a Kysely transaction-wrapped test with additional fixtures.\n * Each fixture receives the transaction and can create dependencies like factories or repositories.\n *\n * @template Database - The database schema type\n * @template Extended - The type of additional fixtures to provide\n * @param wrappedTest - The base wrapped test from wrapVitestKyselyTransaction\n * @param fixtures - Object mapping fixture names to creator functions\n * @returns An extended test API with both trx and the additional fixtures\n *\n * @example\n * ```typescript\n * import { test } from 'vitest';\n * import { wrapVitestKyselyTransaction, extendWithFixtures, KyselyFactory } from '@geekmidas/testkit/kysely';\n *\n * // Define your builders\n * const builders = {\n * user: KyselyFactory.createBuilder<DB, 'users'>('users', ({ faker }) => ({\n * name: faker.person.fullName(),\n * email: faker.internet.email(),\n * })),\n * };\n *\n * // Create base wrapped test\n * const baseTest = wrapVitestKyselyTransaction<DB>(test, {\n * connection: db,\n * setup: createTestTables,\n * });\n *\n * // Extend with fixtures - each fixture receives the transaction\n * const it = extendWithFixtures<DB, { factory: KyselyFactory<DB, typeof builders, {}> }>(\n * baseTest,\n * {\n * factory: (trx) => new KyselyFactory(builders, {}, trx),\n * }\n * );\n *\n * // Use in tests - both trx and factory are available\n * it('should create user with factory', async ({ trx, factory }) => {\n * const user = await factory.insert('user', { name: 'Test User' });\n * expect(user.id).toBeDefined();\n *\n * // Verify in database\n * const found = await trx\n * .selectFrom('users')\n * .where('id', '=', user.id)\n * .selectAll()\n * .executeTakeFirst();\n * expect(found?.name).toBe('Test User');\n * });\n * ```\n */\nexport function extendWithFixtures<\n Database,\n Extended extends Record<string, unknown>,\n T extends ReturnType<TestAPI['extend']> = ReturnType<TestAPI['extend']>,\n>(wrappedTest: T, fixtures: FixtureCreators<Transaction<Database>, Extended>) {\n return baseExtendWithFixtures<Transaction<Database>, Extended, T>(\n wrappedTest,\n fixtures,\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA+FA,SAAgB,4BAGdA,KAAcC,SAAuD;CACrE,MAAM,UAAU,IAAI,gCAA0C;AAE9D,QAAO,QAAQ,0BAA0B,QAAQ;AAClD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAsDD,SAAgBC,qBAIdC,aAAgBC,UAA4D;AAC5E,QAAO,mBACL,aACA,SACD;AACF"}