@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,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_ObjectionFactory = require('./ObjectionFactory-Eb04AOnv.cjs');
3
+ const require_ObjectionFactory = require('./ObjectionFactory-BeFBYcan.cjs');
4
4
  require('./PostgresMigrator-DFcNdCvD.cjs');
5
5
  const require_PostgresObjectionMigrator = require('./PostgresObjectionMigrator-BG6ymgnt.cjs');
6
- const require_VitestTransactionIsolator = require('./VitestTransactionIsolator-BKIrj3Uy.cjs');
7
- const require_VitestObjectionTransactionIsolator = require('./VitestObjectionTransactionIsolator-D_tlOtq8.cjs');
6
+ const require_VitestTransactionIsolator = require('./VitestTransactionIsolator-CMfJXZP8.cjs');
7
+ const require_VitestObjectionTransactionIsolator = require('./VitestObjectionTransactionIsolator-CM5KTAFA.cjs');
8
8
 
9
9
  //#region src/objection.ts
10
10
  /**
@@ -12,10 +12,9 @@ const require_VitestObjectionTransactionIsolator = require('./VitestObjectionTra
12
12
  * Each test runs in an isolated database transaction that is rolled back after completion.
13
13
  * This ensures tests don't affect each other's data and run faster than truncating tables.
14
14
  *
15
+ * @template Extended - Additional fixtures to provide
15
16
  * @param api - The Vitest test API (usually `test` from vitest)
16
- * @param conn - The Knex database connection instance
17
- * @param setup - Optional setup function to run before each test in the transaction
18
- * @param level - Transaction isolation level (defaults to REPEATABLE_READ)
17
+ * @param options - Configuration options for transaction wrapping
19
18
  * @returns A wrapped test API that provides transaction isolation
20
19
  *
21
20
  * @example
@@ -23,10 +22,12 @@ const require_VitestObjectionTransactionIsolator = require('./VitestObjectionTra
23
22
  * import { test } from 'vitest';
24
23
  * import { wrapVitestObjectionTransaction } from '@geekmidas/testkit/objection';
25
24
  * import { knex } from './database';
26
- * import { User, Post } from './models';
25
+ * import { User } from './models';
27
26
  *
28
27
  * // Create isolated test with automatic rollback
29
- * const isolatedTest = wrapVitestObjectionTransaction(test, knex);
28
+ * const isolatedTest = wrapVitestObjectionTransaction(test, {
29
+ * connection: knex,
30
+ * });
30
31
  *
31
32
  * // Use in tests - each test gets its own transaction
32
33
  * isolatedTest('should create user', async ({ trx }) => {
@@ -34,53 +35,25 @@ const require_VitestObjectionTransactionIsolator = require('./VitestObjectionTra
34
35
  * .insert({ name: 'Test User', email: 'test@example.com' });
35
36
  *
36
37
  * expect(user).toBeDefined();
37
- * // User is automatically rolled back after test
38
38
  * });
39
39
  *
40
- * // With setup function for common test data
41
- * const testWithSetup = wrapVitestObjectionTransaction(
42
- * test,
43
- * knex,
44
- * async (trx) => {
45
- * // Create common test data
46
- * await knex('settings')
47
- * .transacting(trx)
48
- * .insert({ key: 'test_mode', value: 'true' });
49
- * }
50
- * );
51
- *
52
- * testWithSetup('should have test settings', async ({ trx }) => {
53
- * const setting = await knex('settings')
54
- * .transacting(trx)
55
- * .where('key', 'test_mode')
56
- * .first();
57
- *
58
- * expect(setting?.value).toBe('true');
40
+ * // With fixtures for factories
41
+ * const it = wrapVitestObjectionTransaction<{ factory: Factory }>(test, {
42
+ * connection: knex,
43
+ * fixtures: {
44
+ * factory: (trx) => new Factory(trx),
45
+ * },
59
46
  * });
60
47
  *
61
- * // Example with factory and transaction
62
- * const isolatedTest = wrapVitestObjectionTransaction(test, knex);
63
- * const factory = new ObjectionFactory(builders, seeds, knex);
64
- *
65
- * isolatedTest('creates related data', async ({ trx }) => {
66
- * // Factory can use the transaction
67
- * const user = await User.query(trx).insert({ name: 'Author' });
68
- * const posts = await Post.query(trx).insert([
69
- * { title: 'Post 1', userId: user.id },
70
- * { title: 'Post 2', userId: user.id }
71
- * ]);
72
- *
73
- * const userWithPosts = await User.query(trx)
74
- * .findById(user.id)
75
- * .withGraphFetched('posts');
76
- *
77
- * expect(userWithPosts.posts).toHaveLength(2);
48
+ * it('should create user with factory', async ({ trx, factory }) => {
49
+ * const user = await factory.insert('user', { name: 'Test' });
50
+ * expect(user.id).toBeDefined();
78
51
  * });
79
52
  * ```
80
53
  */
81
- function wrapVitestObjectionTransaction(api, conn, setup, level = require_VitestTransactionIsolator.IsolationLevel.REPEATABLE_READ) {
54
+ function wrapVitestObjectionTransaction(api, options) {
82
55
  const wrapper = new require_VitestObjectionTransactionIsolator.VitestObjectionTransactionIsolator(api);
83
- return wrapper.wrapVitestWithTransaction(conn, setup, level);
56
+ return wrapper.wrapVitestWithTransaction(options);
84
57
  }
85
58
  /**
86
59
  * Extends an Objection.js transaction-wrapped test with additional fixtures.
@@ -106,7 +79,10 @@ function wrapVitestObjectionTransaction(api, conn, setup, level = require_Vitest
106
79
  * };
107
80
  *
108
81
  * // Create base wrapped test
109
- * const baseTest = wrapVitestObjectionTransaction(test, knex, createTestTables);
82
+ * const baseTest = wrapVitestObjectionTransaction(test, {
83
+ * connection: knex,
84
+ * setup: createTestTables,
85
+ * });
110
86
  *
111
87
  * // Extend with fixtures - each fixture receives the transaction
112
88
  * const it = extendWithFixtures<{ factory: ObjectionFactory<typeof builders, {}> }>(
@@ -1 +1 @@
1
- {"version":3,"file":"objection.cjs","names":["api: TestAPI","conn: DatabaseConnection<Knex>","setup?: (trx: Knex.Transaction) => Promise<void>","level: IsolationLevel","IsolationLevel","VitestObjectionTransactionIsolator","extendWithFixtures","wrappedTest: T","fixtures: FixtureCreators<Knex.Transaction, Extended>"],"sources":["../src/objection.ts"],"sourcesContent":["import type { Knex } from 'knex';\nimport type { TestAPI } from 'vitest';\nimport { VitestObjectionTransactionIsolator } from './VitestObjectionTransactionIsolator';\nimport {\n type DatabaseConnection,\n type FixtureCreators,\n IsolationLevel,\n extendWithFixtures as baseExtendWithFixtures,\n} from './VitestTransactionIsolator';\n\n/**\n * Objection.js-specific exports for test utilities.\n * Provides factory implementation for creating test data with Objection.js ORM\n * and transaction isolation for test suites.\n */\n\nexport { ObjectionFactory } from './ObjectionFactory';\nexport { VitestObjectionTransactionIsolator } from './VitestObjectionTransactionIsolator';\nexport { IsolationLevel } from './VitestTransactionIsolator';\nexport { PostgresObjectionMigrator } from './PostgresObjectionMigrator';\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 Objection.js.\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 * @param api - The Vitest test API (usually `test` from vitest)\n * @param conn - The Knex database connection 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 { wrapVitestObjectionTransaction } from '@geekmidas/testkit/objection';\n * import { knex } from './database';\n * import { User, Post } from './models';\n *\n * // Create isolated test with automatic rollback\n * const isolatedTest = wrapVitestObjectionTransaction(test, knex);\n *\n * // Use in tests - each test gets its own transaction\n * isolatedTest('should create user', async ({ trx }) => {\n * const user = await User.query(trx)\n * .insert({ name: 'Test User', email: 'test@example.com' });\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 = wrapVitestObjectionTransaction(\n * test,\n * knex,\n * async (trx) => {\n * // Create common test data\n * await knex('settings')\n * .transacting(trx)\n * .insert({ key: 'test_mode', value: 'true' });\n * }\n * );\n *\n * testWithSetup('should have test settings', async ({ trx }) => {\n * const setting = await knex('settings')\n * .transacting(trx)\n * .where('key', 'test_mode')\n * .first();\n *\n * expect(setting?.value).toBe('true');\n * });\n *\n * // Example with factory and transaction\n * const isolatedTest = wrapVitestObjectionTransaction(test, knex);\n * const factory = new ObjectionFactory(builders, seeds, knex);\n *\n * isolatedTest('creates related data', async ({ trx }) => {\n * // Factory can use the transaction\n * const user = await User.query(trx).insert({ name: 'Author' });\n * const posts = await Post.query(trx).insert([\n * { title: 'Post 1', userId: user.id },\n * { title: 'Post 2', userId: user.id }\n * ]);\n *\n * const userWithPosts = await User.query(trx)\n * .findById(user.id)\n * .withGraphFetched('posts');\n *\n * expect(userWithPosts.posts).toHaveLength(2);\n * });\n * ```\n */\nexport function wrapVitestObjectionTransaction(\n api: TestAPI,\n conn: DatabaseConnection<Knex>,\n setup?: (trx: Knex.Transaction) => Promise<void>,\n level: IsolationLevel = IsolationLevel.REPEATABLE_READ,\n) {\n const wrapper = new VitestObjectionTransactionIsolator(api);\n\n return wrapper.wrapVitestWithTransaction(conn, setup, level);\n}\n\n/**\n * Extends an Objection.js transaction-wrapped test with additional fixtures.\n * Each fixture receives the transaction and can create dependencies like factories or repositories.\n *\n * @template Extended - The type of additional fixtures to provide\n * @param wrappedTest - The base wrapped test from wrapVitestObjectionTransaction\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 { wrapVitestObjectionTransaction, extendWithFixtures, ObjectionFactory } from '@geekmidas/testkit/objection';\n * import { User } from './models';\n *\n * // Define your builders\n * const builders = {\n * user: ObjectionFactory.createBuilder(User, ({ faker }) => ({\n * name: faker.person.fullName(),\n * email: faker.internet.email(),\n * })),\n * };\n *\n * // Create base wrapped test\n * const baseTest = wrapVitestObjectionTransaction(test, knex, createTestTables);\n *\n * // Extend with fixtures - each fixture receives the transaction\n * const it = extendWithFixtures<{ factory: ObjectionFactory<typeof builders, {}> }>(\n * baseTest,\n * {\n * factory: (trx) => new ObjectionFactory(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 User.query(trx).findById(user.id);\n * expect(found?.name).toBe('Test User');\n * });\n * ```\n */\nexport function extendWithFixtures<\n Extended extends Record<string, unknown>,\n T extends ReturnType<TestAPI['extend']> = ReturnType<TestAPI['extend']>,\n>(wrappedTest: T, fixtures: FixtureCreators<Knex.Transaction, Extended>) {\n return baseExtendWithFixtures<Knex.Transaction, Extended, T>(\n wrappedTest,\n fixtures,\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAqGA,SAAgB,+BACdA,KACAC,MACAC,OACAC,QAAwBC,iDAAe,iBACvC;CACA,MAAM,UAAU,IAAIC,8EAAmC;AAEvD,QAAO,QAAQ,0BAA0B,MAAM,OAAO,MAAM;AAC7D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA+CD,SAAgBC,qBAGdC,aAAgBC,UAAuD;AACvE,QAAO,qDACL,aACA,SACD;AACF"}
1
+ {"version":3,"file":"objection.cjs","names":["api: TestAPI","options: ObjectionTransactionOptions<Extended>","VitestObjectionTransactionIsolator","extendWithFixtures","wrappedTest: T","fixtures: FixtureCreators<Knex.Transaction, Extended>"],"sources":["../src/objection.ts"],"sourcesContent":["import type { Knex } from 'knex';\nimport type { TestAPI } from 'vitest';\nimport { VitestObjectionTransactionIsolator } from './VitestObjectionTransactionIsolator';\nimport {\n type DatabaseConnection,\n type FixtureCreators,\n type IsolationLevel,\n extendWithFixtures as baseExtendWithFixtures,\n} from './VitestTransactionIsolator';\n\n/**\n * Objection.js-specific exports for test utilities.\n * Provides factory implementation for creating test data with Objection.js ORM\n * and transaction isolation for test suites.\n */\n\nexport { ObjectionFactory } from './ObjectionFactory';\nexport type { ExtractSeedAttrs, FactorySeed } from './Factory';\nexport { VitestObjectionTransactionIsolator } from './VitestObjectionTransactionIsolator';\nexport { IsolationLevel } from './VitestTransactionIsolator';\nexport { PostgresObjectionMigrator } from './PostgresObjectionMigrator';\nexport type {\n DatabaseFixtures,\n ExtendedDatabaseFixtures,\n FixtureCreators,\n TestWithExtendedFixtures,\n TransactionWrapperOptions,\n} from './VitestTransactionIsolator';\n\n/**\n * Objection.js-specific options for transaction wrapping.\n */\nexport interface ObjectionTransactionOptions<\n Extended extends Record<string, unknown> = {},\n> {\n /** Function that creates or returns a Knex database connection */\n connection: DatabaseConnection<Knex>;\n /** Optional setup function to run within the transaction before each test */\n setup?: (trx: Knex.Transaction) => Promise<void>;\n /** Transaction isolation level (defaults to REPEATABLE_READ) */\n isolationLevel?: IsolationLevel;\n /** Additional fixtures that depend on the transaction */\n fixtures?: FixtureCreators<Knex.Transaction, 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 Objection.js.\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 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 { wrapVitestObjectionTransaction } from '@geekmidas/testkit/objection';\n * import { knex } from './database';\n * import { User } from './models';\n *\n * // Create isolated test with automatic rollback\n * const isolatedTest = wrapVitestObjectionTransaction(test, {\n * connection: knex,\n * });\n *\n * // Use in tests - each test gets its own transaction\n * isolatedTest('should create user', async ({ trx }) => {\n * const user = await User.query(trx)\n * .insert({ name: 'Test User', email: 'test@example.com' });\n *\n * expect(user).toBeDefined();\n * });\n *\n * // With fixtures for factories\n * const it = wrapVitestObjectionTransaction<{ factory: Factory }>(test, {\n * connection: knex,\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 wrapVitestObjectionTransaction<\n Extended extends Record<string, unknown> = {},\n>(api: TestAPI, options: ObjectionTransactionOptions<Extended>) {\n const wrapper = new VitestObjectionTransactionIsolator(api);\n\n return wrapper.wrapVitestWithTransaction(options);\n}\n\n/**\n * Extends an Objection.js transaction-wrapped test with additional fixtures.\n * Each fixture receives the transaction and can create dependencies like factories or repositories.\n *\n * @template Extended - The type of additional fixtures to provide\n * @param wrappedTest - The base wrapped test from wrapVitestObjectionTransaction\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 { wrapVitestObjectionTransaction, extendWithFixtures, ObjectionFactory } from '@geekmidas/testkit/objection';\n * import { User } from './models';\n *\n * // Define your builders\n * const builders = {\n * user: ObjectionFactory.createBuilder(User, ({ faker }) => ({\n * name: faker.person.fullName(),\n * email: faker.internet.email(),\n * })),\n * };\n *\n * // Create base wrapped test\n * const baseTest = wrapVitestObjectionTransaction(test, {\n * connection: knex,\n * setup: createTestTables,\n * });\n *\n * // Extend with fixtures - each fixture receives the transaction\n * const it = extendWithFixtures<{ factory: ObjectionFactory<typeof builders, {}> }>(\n * baseTest,\n * {\n * factory: (trx) => new ObjectionFactory(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 User.query(trx).findById(user.id);\n * expect(found?.name).toBe('Test User');\n * });\n * ```\n */\nexport function extendWithFixtures<\n Extended extends Record<string, unknown>,\n T extends ReturnType<TestAPI['extend']> = ReturnType<TestAPI['extend']>,\n>(wrappedTest: T, fixtures: FixtureCreators<Knex.Transaction, Extended>) {\n return baseExtendWithFixtures<Knex.Transaction, Extended, T>(\n wrappedTest,\n fixtures,\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA4FA,SAAgB,+BAEdA,KAAcC,SAAgD;CAC9D,MAAM,UAAU,IAAIC,8EAAmC;AAEvD,QAAO,QAAQ,0BAA0B,QAAQ;AAClD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAkDD,SAAgBC,qBAGdC,aAAgBC,UAAuD;AACvE,QAAO,qDACL,aACA,SACD;AACF"}
@@ -1,24 +1,36 @@
1
- import { FakerFactory, faker } from "./faker-BSH1EMtg.cjs";
2
- import "./Factory-pNV7ZQ7-.cjs";
3
- import { ObjectionFactory } from "./ObjectionFactory-BwpN4gMX.cjs";
1
+ import { FakerFactory, faker } from "./faker-CbYiF-8_.cjs";
2
+ import { ExtractSeedAttrs, FactorySeed } from "./Factory-IdfEkOeT.cjs";
3
+ import { ObjectionFactory } from "./ObjectionFactory-BRAkAByP.cjs";
4
4
  import "./PostgresMigrator-D5UkK1_K.cjs";
5
5
  import { PostgresObjectionMigrator } from "./PostgresObjectionMigrator-CZHHcCOv.cjs";
6
- import { DatabaseConnection, DatabaseFixtures, ExtendedDatabaseFixtures, FixtureCreators, IsolationLevel, TestWithExtendedFixtures } from "./VitestTransactionIsolator-DfA80g2M.cjs";
7
- import { VitestObjectionTransactionIsolator } from "./VitestObjectionTransactionIsolator-CD2ucJpH.cjs";
6
+ import { DatabaseConnection, DatabaseFixtures, ExtendedDatabaseFixtures, FixtureCreators, IsolationLevel, TestWithExtendedFixtures, TransactionWrapperOptions } from "./VitestTransactionIsolator-CwQaxZLP.cjs";
7
+ import { VitestObjectionTransactionIsolator } from "./VitestObjectionTransactionIsolator-1TpsPqfG.cjs";
8
8
  import { Knex } from "knex";
9
9
  import { TestAPI } from "vitest";
10
10
 
11
11
  //#region src/objection.d.ts
12
12
 
13
+ /**
14
+ * Objection.js-specific options for transaction wrapping.
15
+ */
16
+ interface ObjectionTransactionOptions<Extended extends Record<string, unknown> = {}> {
17
+ /** Function that creates or returns a Knex database connection */
18
+ connection: DatabaseConnection<Knex>;
19
+ /** Optional setup function to run within the transaction before each test */
20
+ setup?: (trx: Knex.Transaction) => Promise<void>;
21
+ /** Transaction isolation level (defaults to REPEATABLE_READ) */
22
+ isolationLevel?: IsolationLevel;
23
+ /** Additional fixtures that depend on the transaction */
24
+ fixtures?: FixtureCreators<Knex.Transaction, Extended>;
25
+ }
13
26
  /**
14
27
  * Creates a wrapped Vitest test API with automatic transaction rollback for Objection.js.
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
  *
31
+ * @template Extended - Additional fixtures to provide
18
32
  * @param api - The Vitest test API (usually `test` from vitest)
19
- * @param conn - The Knex database connection instance
20
- * @param setup - Optional setup function to run before each test in the transaction
21
- * @param level - Transaction isolation level (defaults to REPEATABLE_READ)
33
+ * @param options - Configuration options for transaction wrapping
22
34
  * @returns A wrapped test API that provides transaction isolation
23
35
  *
24
36
  * @example
@@ -26,10 +38,12 @@ import { TestAPI } from "vitest";
26
38
  * import { test } from 'vitest';
27
39
  * import { wrapVitestObjectionTransaction } from '@geekmidas/testkit/objection';
28
40
  * import { knex } from './database';
29
- * import { User, Post } from './models';
41
+ * import { User } from './models';
30
42
  *
31
43
  * // Create isolated test with automatic rollback
32
- * const isolatedTest = wrapVitestObjectionTransaction(test, knex);
44
+ * const isolatedTest = wrapVitestObjectionTransaction(test, {
45
+ * connection: knex,
46
+ * });
33
47
  *
34
48
  * // Use in tests - each test gets its own transaction
35
49
  * isolatedTest('should create user', async ({ trx }) => {
@@ -37,53 +51,23 @@ import { TestAPI } from "vitest";
37
51
  * .insert({ name: 'Test User', email: 'test@example.com' });
38
52
  *
39
53
  * expect(user).toBeDefined();
40
- * // User is automatically rolled back after test
41
54
  * });
42
55
  *
43
- * // With setup function for common test data
44
- * const testWithSetup = wrapVitestObjectionTransaction(
45
- * test,
46
- * knex,
47
- * async (trx) => {
48
- * // Create common test data
49
- * await knex('settings')
50
- * .transacting(trx)
51
- * .insert({ key: 'test_mode', value: 'true' });
52
- * }
53
- * );
54
- *
55
- * testWithSetup('should have test settings', async ({ trx }) => {
56
- * const setting = await knex('settings')
57
- * .transacting(trx)
58
- * .where('key', 'test_mode')
59
- * .first();
60
- *
61
- * expect(setting?.value).toBe('true');
56
+ * // With fixtures for factories
57
+ * const it = wrapVitestObjectionTransaction<{ factory: Factory }>(test, {
58
+ * connection: knex,
59
+ * fixtures: {
60
+ * factory: (trx) => new Factory(trx),
61
+ * },
62
62
  * });
63
63
  *
64
- * // Example with factory and transaction
65
- * const isolatedTest = wrapVitestObjectionTransaction(test, knex);
66
- * const factory = new ObjectionFactory(builders, seeds, knex);
67
- *
68
- * isolatedTest('creates related data', async ({ trx }) => {
69
- * // Factory can use the transaction
70
- * const user = await User.query(trx).insert({ name: 'Author' });
71
- * const posts = await Post.query(trx).insert([
72
- * { title: 'Post 1', userId: user.id },
73
- * { title: 'Post 2', userId: user.id }
74
- * ]);
75
- *
76
- * const userWithPosts = await User.query(trx)
77
- * .findById(user.id)
78
- * .withGraphFetched('posts');
79
- *
80
- * expect(userWithPosts.posts).toHaveLength(2);
64
+ * it('should create user with factory', async ({ trx, factory }) => {
65
+ * const user = await factory.insert('user', { name: 'Test' });
66
+ * expect(user.id).toBeDefined();
81
67
  * });
82
68
  * ```
83
69
  */
84
- declare function wrapVitestObjectionTransaction(api: TestAPI, conn: DatabaseConnection<Knex>, setup?: (trx: Knex.Transaction) => Promise<void>, level?: IsolationLevel): TestAPI<{
85
- trx: Knex.Transaction<any, any[]>;
86
- }>;
70
+ declare function wrapVitestObjectionTransaction<Extended extends Record<string, unknown> = {}>(api: TestAPI, options: ObjectionTransactionOptions<Extended>): TestAPI<DatabaseFixtures<Knex.Transaction<any, any[]>, object> & Extended>;
87
71
  /**
88
72
  * Extends an Objection.js transaction-wrapped test with additional fixtures.
89
73
  * Each fixture receives the transaction and can create dependencies like factories or repositories.
@@ -108,7 +92,10 @@ declare function wrapVitestObjectionTransaction(api: TestAPI, conn: DatabaseConn
108
92
  * };
109
93
  *
110
94
  * // Create base wrapped test
111
- * const baseTest = wrapVitestObjectionTransaction(test, knex, createTestTables);
95
+ * const baseTest = wrapVitestObjectionTransaction(test, {
96
+ * connection: knex,
97
+ * setup: createTestTables,
98
+ * });
112
99
  *
113
100
  * // Extend with fixtures - each fixture receives the transaction
114
101
  * const it = extendWithFixtures<{ factory: ObjectionFactory<typeof builders, {}> }>(
@@ -131,5 +118,5 @@ declare function wrapVitestObjectionTransaction(api: TestAPI, conn: DatabaseConn
131
118
  */
132
119
  declare function extendWithFixtures<Extended extends Record<string, unknown>, T extends ReturnType<TestAPI['extend']> = ReturnType<TestAPI['extend']>>(wrappedTest: T, fixtures: FixtureCreators<Knex.Transaction, Extended>): TestWithExtendedFixtures<Knex.Transaction<any, any[]>, Extended, T>;
133
120
  //#endregion
134
- export { DatabaseFixtures, ExtendedDatabaseFixtures, FakerFactory, FixtureCreators, IsolationLevel, ObjectionFactory, PostgresObjectionMigrator, TestWithExtendedFixtures, VitestObjectionTransactionIsolator, extendWithFixtures, faker, wrapVitestObjectionTransaction };
121
+ export { DatabaseFixtures, ExtendedDatabaseFixtures, ExtractSeedAttrs, FactorySeed, FakerFactory, FixtureCreators, IsolationLevel, ObjectionFactory, ObjectionTransactionOptions, PostgresObjectionMigrator, TestWithExtendedFixtures, TransactionWrapperOptions, VitestObjectionTransactionIsolator, extendWithFixtures, faker, wrapVitestObjectionTransaction };
135
122
  //# sourceMappingURL=objection.d.cts.map
@@ -1,24 +1,36 @@
1
- import { FakerFactory, faker } from "./faker-D9gz7KjY.mjs";
2
- import "./Factory-DE3hE0WO.mjs";
3
- import { ObjectionFactory } from "./ObjectionFactory-BlBicEia.mjs";
1
+ import { FakerFactory, faker } from "./faker-DHh7xs4u.mjs";
2
+ import { ExtractSeedAttrs, FactorySeed } from "./Factory-BcGJjLc8.mjs";
3
+ import { ObjectionFactory } from "./ObjectionFactory-DL4qkuF1.mjs";
4
4
  import "./PostgresMigrator-DQaRxoaY.mjs";
5
5
  import { PostgresObjectionMigrator } from "./PostgresObjectionMigrator-D_hCcrQu.mjs";
6
- import { DatabaseConnection, DatabaseFixtures, ExtendedDatabaseFixtures, FixtureCreators, IsolationLevel, TestWithExtendedFixtures } from "./VitestTransactionIsolator-DLdQlfZ5.mjs";
7
- import { VitestObjectionTransactionIsolator } from "./VitestObjectionTransactionIsolator-DhQ8XGva.mjs";
6
+ import { DatabaseConnection, DatabaseFixtures, ExtendedDatabaseFixtures, FixtureCreators, IsolationLevel, TestWithExtendedFixtures, TransactionWrapperOptions } from "./VitestTransactionIsolator-BvR19bYn.mjs";
7
+ import { VitestObjectionTransactionIsolator } from "./VitestObjectionTransactionIsolator-i9jIgU8Q.mjs";
8
8
  import { TestAPI } from "vitest";
9
9
  import { Knex } from "knex";
10
10
 
11
11
  //#region src/objection.d.ts
12
12
 
13
+ /**
14
+ * Objection.js-specific options for transaction wrapping.
15
+ */
16
+ interface ObjectionTransactionOptions<Extended extends Record<string, unknown> = {}> {
17
+ /** Function that creates or returns a Knex database connection */
18
+ connection: DatabaseConnection<Knex>;
19
+ /** Optional setup function to run within the transaction before each test */
20
+ setup?: (trx: Knex.Transaction) => Promise<void>;
21
+ /** Transaction isolation level (defaults to REPEATABLE_READ) */
22
+ isolationLevel?: IsolationLevel;
23
+ /** Additional fixtures that depend on the transaction */
24
+ fixtures?: FixtureCreators<Knex.Transaction, Extended>;
25
+ }
13
26
  /**
14
27
  * Creates a wrapped Vitest test API with automatic transaction rollback for Objection.js.
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
  *
31
+ * @template Extended - Additional fixtures to provide
18
32
  * @param api - The Vitest test API (usually `test` from vitest)
19
- * @param conn - The Knex database connection instance
20
- * @param setup - Optional setup function to run before each test in the transaction
21
- * @param level - Transaction isolation level (defaults to REPEATABLE_READ)
33
+ * @param options - Configuration options for transaction wrapping
22
34
  * @returns A wrapped test API that provides transaction isolation
23
35
  *
24
36
  * @example
@@ -26,10 +38,12 @@ import { Knex } from "knex";
26
38
  * import { test } from 'vitest';
27
39
  * import { wrapVitestObjectionTransaction } from '@geekmidas/testkit/objection';
28
40
  * import { knex } from './database';
29
- * import { User, Post } from './models';
41
+ * import { User } from './models';
30
42
  *
31
43
  * // Create isolated test with automatic rollback
32
- * const isolatedTest = wrapVitestObjectionTransaction(test, knex);
44
+ * const isolatedTest = wrapVitestObjectionTransaction(test, {
45
+ * connection: knex,
46
+ * });
33
47
  *
34
48
  * // Use in tests - each test gets its own transaction
35
49
  * isolatedTest('should create user', async ({ trx }) => {
@@ -37,53 +51,23 @@ import { Knex } from "knex";
37
51
  * .insert({ name: 'Test User', email: 'test@example.com' });
38
52
  *
39
53
  * expect(user).toBeDefined();
40
- * // User is automatically rolled back after test
41
54
  * });
42
55
  *
43
- * // With setup function for common test data
44
- * const testWithSetup = wrapVitestObjectionTransaction(
45
- * test,
46
- * knex,
47
- * async (trx) => {
48
- * // Create common test data
49
- * await knex('settings')
50
- * .transacting(trx)
51
- * .insert({ key: 'test_mode', value: 'true' });
52
- * }
53
- * );
54
- *
55
- * testWithSetup('should have test settings', async ({ trx }) => {
56
- * const setting = await knex('settings')
57
- * .transacting(trx)
58
- * .where('key', 'test_mode')
59
- * .first();
60
- *
61
- * expect(setting?.value).toBe('true');
56
+ * // With fixtures for factories
57
+ * const it = wrapVitestObjectionTransaction<{ factory: Factory }>(test, {
58
+ * connection: knex,
59
+ * fixtures: {
60
+ * factory: (trx) => new Factory(trx),
61
+ * },
62
62
  * });
63
63
  *
64
- * // Example with factory and transaction
65
- * const isolatedTest = wrapVitestObjectionTransaction(test, knex);
66
- * const factory = new ObjectionFactory(builders, seeds, knex);
67
- *
68
- * isolatedTest('creates related data', async ({ trx }) => {
69
- * // Factory can use the transaction
70
- * const user = await User.query(trx).insert({ name: 'Author' });
71
- * const posts = await Post.query(trx).insert([
72
- * { title: 'Post 1', userId: user.id },
73
- * { title: 'Post 2', userId: user.id }
74
- * ]);
75
- *
76
- * const userWithPosts = await User.query(trx)
77
- * .findById(user.id)
78
- * .withGraphFetched('posts');
79
- *
80
- * expect(userWithPosts.posts).toHaveLength(2);
64
+ * it('should create user with factory', async ({ trx, factory }) => {
65
+ * const user = await factory.insert('user', { name: 'Test' });
66
+ * expect(user.id).toBeDefined();
81
67
  * });
82
68
  * ```
83
69
  */
84
- declare function wrapVitestObjectionTransaction(api: TestAPI, conn: DatabaseConnection<Knex>, setup?: (trx: Knex.Transaction) => Promise<void>, level?: IsolationLevel): TestAPI<{
85
- trx: Knex.Transaction<any, any[]>;
86
- }>;
70
+ declare function wrapVitestObjectionTransaction<Extended extends Record<string, unknown> = {}>(api: TestAPI, options: ObjectionTransactionOptions<Extended>): TestAPI<DatabaseFixtures<Knex.Transaction<any, any[]>, object> & Extended>;
87
71
  /**
88
72
  * Extends an Objection.js transaction-wrapped test with additional fixtures.
89
73
  * Each fixture receives the transaction and can create dependencies like factories or repositories.
@@ -108,7 +92,10 @@ declare function wrapVitestObjectionTransaction(api: TestAPI, conn: DatabaseConn
108
92
  * };
109
93
  *
110
94
  * // Create base wrapped test
111
- * const baseTest = wrapVitestObjectionTransaction(test, knex, createTestTables);
95
+ * const baseTest = wrapVitestObjectionTransaction(test, {
96
+ * connection: knex,
97
+ * setup: createTestTables,
98
+ * });
112
99
  *
113
100
  * // Extend with fixtures - each fixture receives the transaction
114
101
  * const it = extendWithFixtures<{ factory: ObjectionFactory<typeof builders, {}> }>(
@@ -131,5 +118,5 @@ declare function wrapVitestObjectionTransaction(api: TestAPI, conn: DatabaseConn
131
118
  */
132
119
  declare function extendWithFixtures<Extended extends Record<string, unknown>, T extends ReturnType<TestAPI['extend']> = ReturnType<TestAPI['extend']>>(wrappedTest: T, fixtures: FixtureCreators<Knex.Transaction, Extended>): TestWithExtendedFixtures<Knex.Transaction<any, any[]>, Extended, T>;
133
120
  //#endregion
134
- export { DatabaseFixtures, ExtendedDatabaseFixtures, FakerFactory, FixtureCreators, IsolationLevel, ObjectionFactory, PostgresObjectionMigrator, TestWithExtendedFixtures, VitestObjectionTransactionIsolator, extendWithFixtures, faker, wrapVitestObjectionTransaction };
121
+ export { DatabaseFixtures, ExtendedDatabaseFixtures, ExtractSeedAttrs, FactorySeed, FakerFactory, FixtureCreators, IsolationLevel, ObjectionFactory, ObjectionTransactionOptions, PostgresObjectionMigrator, TestWithExtendedFixtures, TransactionWrapperOptions, VitestObjectionTransactionIsolator, extendWithFixtures, faker, wrapVitestObjectionTransaction };
135
122
  //# sourceMappingURL=objection.d.mts.map
@@ -1,10 +1,10 @@
1
- import "./Factory-z2m01hMj.mjs";
1
+ import "./Factory-BFVnMMCC.mjs";
2
2
  import { faker } from "./faker-BGKYFoCT.mjs";
3
- import { ObjectionFactory } from "./ObjectionFactory-zf2fLKrL.mjs";
3
+ import { ObjectionFactory } from "./ObjectionFactory-QCJ7u0Ql.mjs";
4
4
  import "./PostgresMigrator-DbuJGAVy.mjs";
5
5
  import { PostgresObjectionMigrator } from "./PostgresObjectionMigrator-DPj2pOpX.mjs";
6
- import { IsolationLevel, extendWithFixtures } from "./VitestTransactionIsolator-BIaMs4c2.mjs";
7
- import { VitestObjectionTransactionIsolator } from "./VitestObjectionTransactionIsolator-_EhJKu_O.mjs";
6
+ import { IsolationLevel, extendWithFixtures } from "./VitestTransactionIsolator-DQ7tLqgV.mjs";
7
+ import { VitestObjectionTransactionIsolator } from "./VitestObjectionTransactionIsolator-jQFaCz0u.mjs";
8
8
 
9
9
  //#region src/objection.ts
10
10
  /**
@@ -12,10 +12,9 @@ import { VitestObjectionTransactionIsolator } from "./VitestObjectionTransaction
12
12
  * Each test runs in an isolated database transaction that is rolled back after completion.
13
13
  * This ensures tests don't affect each other's data and run faster than truncating tables.
14
14
  *
15
+ * @template Extended - Additional fixtures to provide
15
16
  * @param api - The Vitest test API (usually `test` from vitest)
16
- * @param conn - The Knex database connection instance
17
- * @param setup - Optional setup function to run before each test in the transaction
18
- * @param level - Transaction isolation level (defaults to REPEATABLE_READ)
17
+ * @param options - Configuration options for transaction wrapping
19
18
  * @returns A wrapped test API that provides transaction isolation
20
19
  *
21
20
  * @example
@@ -23,10 +22,12 @@ import { VitestObjectionTransactionIsolator } from "./VitestObjectionTransaction
23
22
  * import { test } from 'vitest';
24
23
  * import { wrapVitestObjectionTransaction } from '@geekmidas/testkit/objection';
25
24
  * import { knex } from './database';
26
- * import { User, Post } from './models';
25
+ * import { User } from './models';
27
26
  *
28
27
  * // Create isolated test with automatic rollback
29
- * const isolatedTest = wrapVitestObjectionTransaction(test, knex);
28
+ * const isolatedTest = wrapVitestObjectionTransaction(test, {
29
+ * connection: knex,
30
+ * });
30
31
  *
31
32
  * // Use in tests - each test gets its own transaction
32
33
  * isolatedTest('should create user', async ({ trx }) => {
@@ -34,53 +35,25 @@ import { VitestObjectionTransactionIsolator } from "./VitestObjectionTransaction
34
35
  * .insert({ name: 'Test User', email: 'test@example.com' });
35
36
  *
36
37
  * expect(user).toBeDefined();
37
- * // User is automatically rolled back after test
38
38
  * });
39
39
  *
40
- * // With setup function for common test data
41
- * const testWithSetup = wrapVitestObjectionTransaction(
42
- * test,
43
- * knex,
44
- * async (trx) => {
45
- * // Create common test data
46
- * await knex('settings')
47
- * .transacting(trx)
48
- * .insert({ key: 'test_mode', value: 'true' });
49
- * }
50
- * );
51
- *
52
- * testWithSetup('should have test settings', async ({ trx }) => {
53
- * const setting = await knex('settings')
54
- * .transacting(trx)
55
- * .where('key', 'test_mode')
56
- * .first();
57
- *
58
- * expect(setting?.value).toBe('true');
40
+ * // With fixtures for factories
41
+ * const it = wrapVitestObjectionTransaction<{ factory: Factory }>(test, {
42
+ * connection: knex,
43
+ * fixtures: {
44
+ * factory: (trx) => new Factory(trx),
45
+ * },
59
46
  * });
60
47
  *
61
- * // Example with factory and transaction
62
- * const isolatedTest = wrapVitestObjectionTransaction(test, knex);
63
- * const factory = new ObjectionFactory(builders, seeds, knex);
64
- *
65
- * isolatedTest('creates related data', async ({ trx }) => {
66
- * // Factory can use the transaction
67
- * const user = await User.query(trx).insert({ name: 'Author' });
68
- * const posts = await Post.query(trx).insert([
69
- * { title: 'Post 1', userId: user.id },
70
- * { title: 'Post 2', userId: user.id }
71
- * ]);
72
- *
73
- * const userWithPosts = await User.query(trx)
74
- * .findById(user.id)
75
- * .withGraphFetched('posts');
76
- *
77
- * expect(userWithPosts.posts).toHaveLength(2);
48
+ * it('should create user with factory', async ({ trx, factory }) => {
49
+ * const user = await factory.insert('user', { name: 'Test' });
50
+ * expect(user.id).toBeDefined();
78
51
  * });
79
52
  * ```
80
53
  */
81
- function wrapVitestObjectionTransaction(api, conn, setup, level = IsolationLevel.REPEATABLE_READ) {
54
+ function wrapVitestObjectionTransaction(api, options) {
82
55
  const wrapper = new VitestObjectionTransactionIsolator(api);
83
- return wrapper.wrapVitestWithTransaction(conn, setup, level);
56
+ return wrapper.wrapVitestWithTransaction(options);
84
57
  }
85
58
  /**
86
59
  * Extends an Objection.js transaction-wrapped test with additional fixtures.
@@ -106,7 +79,10 @@ function wrapVitestObjectionTransaction(api, conn, setup, level = IsolationLevel
106
79
  * };
107
80
  *
108
81
  * // Create base wrapped test
109
- * const baseTest = wrapVitestObjectionTransaction(test, knex, createTestTables);
82
+ * const baseTest = wrapVitestObjectionTransaction(test, {
83
+ * connection: knex,
84
+ * setup: createTestTables,
85
+ * });
110
86
  *
111
87
  * // Extend with fixtures - each fixture receives the transaction
112
88
  * const it = extendWithFixtures<{ factory: ObjectionFactory<typeof builders, {}> }>(
@@ -1 +1 @@
1
- {"version":3,"file":"objection.mjs","names":["api: TestAPI","conn: DatabaseConnection<Knex>","setup?: (trx: Knex.Transaction) => Promise<void>","level: IsolationLevel","extendWithFixtures","wrappedTest: T","fixtures: FixtureCreators<Knex.Transaction, Extended>"],"sources":["../src/objection.ts"],"sourcesContent":["import type { Knex } from 'knex';\nimport type { TestAPI } from 'vitest';\nimport { VitestObjectionTransactionIsolator } from './VitestObjectionTransactionIsolator';\nimport {\n type DatabaseConnection,\n type FixtureCreators,\n IsolationLevel,\n extendWithFixtures as baseExtendWithFixtures,\n} from './VitestTransactionIsolator';\n\n/**\n * Objection.js-specific exports for test utilities.\n * Provides factory implementation for creating test data with Objection.js ORM\n * and transaction isolation for test suites.\n */\n\nexport { ObjectionFactory } from './ObjectionFactory';\nexport { VitestObjectionTransactionIsolator } from './VitestObjectionTransactionIsolator';\nexport { IsolationLevel } from './VitestTransactionIsolator';\nexport { PostgresObjectionMigrator } from './PostgresObjectionMigrator';\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 Objection.js.\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 * @param api - The Vitest test API (usually `test` from vitest)\n * @param conn - The Knex database connection 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 { wrapVitestObjectionTransaction } from '@geekmidas/testkit/objection';\n * import { knex } from './database';\n * import { User, Post } from './models';\n *\n * // Create isolated test with automatic rollback\n * const isolatedTest = wrapVitestObjectionTransaction(test, knex);\n *\n * // Use in tests - each test gets its own transaction\n * isolatedTest('should create user', async ({ trx }) => {\n * const user = await User.query(trx)\n * .insert({ name: 'Test User', email: 'test@example.com' });\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 = wrapVitestObjectionTransaction(\n * test,\n * knex,\n * async (trx) => {\n * // Create common test data\n * await knex('settings')\n * .transacting(trx)\n * .insert({ key: 'test_mode', value: 'true' });\n * }\n * );\n *\n * testWithSetup('should have test settings', async ({ trx }) => {\n * const setting = await knex('settings')\n * .transacting(trx)\n * .where('key', 'test_mode')\n * .first();\n *\n * expect(setting?.value).toBe('true');\n * });\n *\n * // Example with factory and transaction\n * const isolatedTest = wrapVitestObjectionTransaction(test, knex);\n * const factory = new ObjectionFactory(builders, seeds, knex);\n *\n * isolatedTest('creates related data', async ({ trx }) => {\n * // Factory can use the transaction\n * const user = await User.query(trx).insert({ name: 'Author' });\n * const posts = await Post.query(trx).insert([\n * { title: 'Post 1', userId: user.id },\n * { title: 'Post 2', userId: user.id }\n * ]);\n *\n * const userWithPosts = await User.query(trx)\n * .findById(user.id)\n * .withGraphFetched('posts');\n *\n * expect(userWithPosts.posts).toHaveLength(2);\n * });\n * ```\n */\nexport function wrapVitestObjectionTransaction(\n api: TestAPI,\n conn: DatabaseConnection<Knex>,\n setup?: (trx: Knex.Transaction) => Promise<void>,\n level: IsolationLevel = IsolationLevel.REPEATABLE_READ,\n) {\n const wrapper = new VitestObjectionTransactionIsolator(api);\n\n return wrapper.wrapVitestWithTransaction(conn, setup, level);\n}\n\n/**\n * Extends an Objection.js transaction-wrapped test with additional fixtures.\n * Each fixture receives the transaction and can create dependencies like factories or repositories.\n *\n * @template Extended - The type of additional fixtures to provide\n * @param wrappedTest - The base wrapped test from wrapVitestObjectionTransaction\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 { wrapVitestObjectionTransaction, extendWithFixtures, ObjectionFactory } from '@geekmidas/testkit/objection';\n * import { User } from './models';\n *\n * // Define your builders\n * const builders = {\n * user: ObjectionFactory.createBuilder(User, ({ faker }) => ({\n * name: faker.person.fullName(),\n * email: faker.internet.email(),\n * })),\n * };\n *\n * // Create base wrapped test\n * const baseTest = wrapVitestObjectionTransaction(test, knex, createTestTables);\n *\n * // Extend with fixtures - each fixture receives the transaction\n * const it = extendWithFixtures<{ factory: ObjectionFactory<typeof builders, {}> }>(\n * baseTest,\n * {\n * factory: (trx) => new ObjectionFactory(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 User.query(trx).findById(user.id);\n * expect(found?.name).toBe('Test User');\n * });\n * ```\n */\nexport function extendWithFixtures<\n Extended extends Record<string, unknown>,\n T extends ReturnType<TestAPI['extend']> = ReturnType<TestAPI['extend']>,\n>(wrappedTest: T, fixtures: FixtureCreators<Knex.Transaction, Extended>) {\n return baseExtendWithFixtures<Knex.Transaction, Extended, T>(\n wrappedTest,\n fixtures,\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAqGA,SAAgB,+BACdA,KACAC,MACAC,OACAC,QAAwB,eAAe,iBACvC;CACA,MAAM,UAAU,IAAI,mCAAmC;AAEvD,QAAO,QAAQ,0BAA0B,MAAM,OAAO,MAAM;AAC7D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA+CD,SAAgBC,qBAGdC,aAAgBC,UAAuD;AACvE,QAAO,mBACL,aACA,SACD;AACF"}
1
+ {"version":3,"file":"objection.mjs","names":["api: TestAPI","options: ObjectionTransactionOptions<Extended>","extendWithFixtures","wrappedTest: T","fixtures: FixtureCreators<Knex.Transaction, Extended>"],"sources":["../src/objection.ts"],"sourcesContent":["import type { Knex } from 'knex';\nimport type { TestAPI } from 'vitest';\nimport { VitestObjectionTransactionIsolator } from './VitestObjectionTransactionIsolator';\nimport {\n type DatabaseConnection,\n type FixtureCreators,\n type IsolationLevel,\n extendWithFixtures as baseExtendWithFixtures,\n} from './VitestTransactionIsolator';\n\n/**\n * Objection.js-specific exports for test utilities.\n * Provides factory implementation for creating test data with Objection.js ORM\n * and transaction isolation for test suites.\n */\n\nexport { ObjectionFactory } from './ObjectionFactory';\nexport type { ExtractSeedAttrs, FactorySeed } from './Factory';\nexport { VitestObjectionTransactionIsolator } from './VitestObjectionTransactionIsolator';\nexport { IsolationLevel } from './VitestTransactionIsolator';\nexport { PostgresObjectionMigrator } from './PostgresObjectionMigrator';\nexport type {\n DatabaseFixtures,\n ExtendedDatabaseFixtures,\n FixtureCreators,\n TestWithExtendedFixtures,\n TransactionWrapperOptions,\n} from './VitestTransactionIsolator';\n\n/**\n * Objection.js-specific options for transaction wrapping.\n */\nexport interface ObjectionTransactionOptions<\n Extended extends Record<string, unknown> = {},\n> {\n /** Function that creates or returns a Knex database connection */\n connection: DatabaseConnection<Knex>;\n /** Optional setup function to run within the transaction before each test */\n setup?: (trx: Knex.Transaction) => Promise<void>;\n /** Transaction isolation level (defaults to REPEATABLE_READ) */\n isolationLevel?: IsolationLevel;\n /** Additional fixtures that depend on the transaction */\n fixtures?: FixtureCreators<Knex.Transaction, 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 Objection.js.\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 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 { wrapVitestObjectionTransaction } from '@geekmidas/testkit/objection';\n * import { knex } from './database';\n * import { User } from './models';\n *\n * // Create isolated test with automatic rollback\n * const isolatedTest = wrapVitestObjectionTransaction(test, {\n * connection: knex,\n * });\n *\n * // Use in tests - each test gets its own transaction\n * isolatedTest('should create user', async ({ trx }) => {\n * const user = await User.query(trx)\n * .insert({ name: 'Test User', email: 'test@example.com' });\n *\n * expect(user).toBeDefined();\n * });\n *\n * // With fixtures for factories\n * const it = wrapVitestObjectionTransaction<{ factory: Factory }>(test, {\n * connection: knex,\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 wrapVitestObjectionTransaction<\n Extended extends Record<string, unknown> = {},\n>(api: TestAPI, options: ObjectionTransactionOptions<Extended>) {\n const wrapper = new VitestObjectionTransactionIsolator(api);\n\n return wrapper.wrapVitestWithTransaction(options);\n}\n\n/**\n * Extends an Objection.js transaction-wrapped test with additional fixtures.\n * Each fixture receives the transaction and can create dependencies like factories or repositories.\n *\n * @template Extended - The type of additional fixtures to provide\n * @param wrappedTest - The base wrapped test from wrapVitestObjectionTransaction\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 { wrapVitestObjectionTransaction, extendWithFixtures, ObjectionFactory } from '@geekmidas/testkit/objection';\n * import { User } from './models';\n *\n * // Define your builders\n * const builders = {\n * user: ObjectionFactory.createBuilder(User, ({ faker }) => ({\n * name: faker.person.fullName(),\n * email: faker.internet.email(),\n * })),\n * };\n *\n * // Create base wrapped test\n * const baseTest = wrapVitestObjectionTransaction(test, {\n * connection: knex,\n * setup: createTestTables,\n * });\n *\n * // Extend with fixtures - each fixture receives the transaction\n * const it = extendWithFixtures<{ factory: ObjectionFactory<typeof builders, {}> }>(\n * baseTest,\n * {\n * factory: (trx) => new ObjectionFactory(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 User.query(trx).findById(user.id);\n * expect(found?.name).toBe('Test User');\n * });\n * ```\n */\nexport function extendWithFixtures<\n Extended extends Record<string, unknown>,\n T extends ReturnType<TestAPI['extend']> = ReturnType<TestAPI['extend']>,\n>(wrappedTest: T, fixtures: FixtureCreators<Knex.Transaction, Extended>) {\n return baseExtendWithFixtures<Knex.Transaction, Extended, T>(\n wrappedTest,\n fixtures,\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA4FA,SAAgB,+BAEdA,KAAcC,SAAgD;CAC9D,MAAM,UAAU,IAAI,mCAAmC;AAEvD,QAAO,QAAQ,0BAA0B,QAAQ;AAClD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAkDD,SAAgBC,qBAGdC,aAAgBC,UAAuD;AACvE,QAAO,mBACL,aACA,SACD;AACF"}
@@ -1,2 +1,2 @@
1
- import { DirectoryFixtures, itWithDir } from "../directory-Q178x53k.mjs";
1
+ import { DirectoryFixtures, itWithDir } from "../directory-BXavAeJZ.mjs";
2
2
  export { DirectoryFixtures, itWithDir };
@@ -1,2 +1,2 @@
1
- import { itWithDir } from "../directory-Q178x53k.mjs";
1
+ import { itWithDir } from "../directory-BXavAeJZ.mjs";
2
2
  export { itWithDir };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@geekmidas/testkit",
3
- "version": "0.1.1",
3
+ "version": "0.3.0",
4
4
  "private": false,
5
5
  "type": "module",
6
6
  "exports": {
@@ -43,6 +43,11 @@
43
43
  "types": "./dist/better-auth.d.ts",
44
44
  "import": "./dist/better-auth.mjs",
45
45
  "require": "./dist/better-auth.cjs"
46
+ },
47
+ "./benchmark": {
48
+ "types": "./dist/benchmark.d.ts",
49
+ "import": "./dist/benchmark.mjs",
50
+ "require": "./dist/benchmark.cjs"
46
51
  }
47
52
  },
48
53
  "dependencies": {