@ductape/sdk 0.0.4-v59 → 0.0.4-v60

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 (251) hide show
  1. package/dist/agents/agents.service.d.ts +8 -2
  2. package/dist/agents/agents.service.js +5 -0
  3. package/dist/agents/agents.service.js.map +1 -1
  4. package/dist/agents/types/agents.types.d.ts +2 -0
  5. package/dist/agents/types/agents.types.js.map +1 -1
  6. package/dist/agents/vector-store-adapter.js +5 -5
  7. package/dist/agents/vector-store-adapter.js.map +1 -1
  8. package/dist/api/services/appApi.service.d.ts +3 -3
  9. package/dist/api/services/appApi.service.js.map +1 -1
  10. package/dist/api/services/productsApi.service.d.ts +1 -1
  11. package/dist/api/services/productsApi.service.js +20 -13
  12. package/dist/api/services/productsApi.service.js.map +1 -1
  13. package/dist/api/services/secretsApi.service.d.ts +12 -0
  14. package/dist/api/services/secretsApi.service.js +30 -2
  15. package/dist/api/services/secretsApi.service.js.map +1 -1
  16. package/dist/api/services/workspaceApi.service.d.ts +8 -0
  17. package/dist/api/services/workspaceApi.service.js +20 -0
  18. package/dist/api/services/workspaceApi.service.js.map +1 -1
  19. package/dist/api/urls.d.ts +2 -0
  20. package/dist/api/urls.js +10 -15
  21. package/dist/api/urls.js.map +1 -1
  22. package/dist/api/utils/auth.utils.d.ts +1 -3
  23. package/dist/api/utils/auth.utils.js.map +1 -1
  24. package/dist/apps/utils/oauth-manager.js +27 -3
  25. package/dist/apps/utils/oauth-manager.js.map +1 -1
  26. package/dist/brokers/brokers.service.d.ts +8 -0
  27. package/dist/brokers/brokers.service.js +50 -4
  28. package/dist/brokers/brokers.service.js.map +1 -1
  29. package/dist/brokers/types/index.d.ts +26 -0
  30. package/dist/brokers/utils/providers/kafka.service.d.ts +7 -0
  31. package/dist/brokers/utils/providers/kafka.service.js +102 -23
  32. package/dist/brokers/utils/providers/kafka.service.js.map +1 -1
  33. package/dist/brokers/utils/providers/rabbitmq.service.d.ts +2 -1
  34. package/dist/brokers/utils/providers/rabbitmq.service.js +99 -15
  35. package/dist/brokers/utils/providers/rabbitmq.service.js.map +1 -1
  36. package/dist/database/adapters/cassandra.adapter.d.ts +1 -0
  37. package/dist/database/adapters/cassandra.adapter.js +100 -44
  38. package/dist/database/adapters/cassandra.adapter.js.map +1 -1
  39. package/dist/database/adapters/dynamodb.adapter.d.ts +1 -0
  40. package/dist/database/adapters/dynamodb.adapter.js +89 -20
  41. package/dist/database/adapters/dynamodb.adapter.js.map +1 -1
  42. package/dist/database/adapters/mongodb.adapter.d.ts +1 -0
  43. package/dist/database/adapters/mongodb.adapter.js +123 -45
  44. package/dist/database/adapters/mongodb.adapter.js.map +1 -1
  45. package/dist/database/adapters/mysql.adapter.d.ts +1 -0
  46. package/dist/database/adapters/mysql.adapter.js +125 -48
  47. package/dist/database/adapters/mysql.adapter.js.map +1 -1
  48. package/dist/database/adapters/postgresql.adapter.d.ts +5 -0
  49. package/dist/database/adapters/postgresql.adapter.js +151 -50
  50. package/dist/database/adapters/postgresql.adapter.js.map +1 -1
  51. package/dist/database/databases.service.d.ts +15 -1
  52. package/dist/database/databases.service.js +143 -2
  53. package/dist/database/databases.service.js.map +1 -1
  54. package/dist/database/operators/aggregation-builder.d.ts +11 -8
  55. package/dist/database/operators/aggregation-builder.js +184 -89
  56. package/dist/database/operators/aggregation-builder.js.map +1 -1
  57. package/dist/database/operators/query-builder.d.ts +23 -19
  58. package/dist/database/operators/query-builder.js +77 -45
  59. package/dist/database/operators/query-builder.js.map +1 -1
  60. package/dist/database/types/aggregation.interface.d.ts +21 -15
  61. package/dist/database/types/query.interface.d.ts +27 -21
  62. package/dist/database/types/write.interface.d.ts +20 -12
  63. package/dist/graph/adapters/arangodb.adapter.js +61 -22
  64. package/dist/graph/adapters/arangodb.adapter.js.map +1 -1
  65. package/dist/graph/adapters/memgraph.adapter.js +22 -16
  66. package/dist/graph/adapters/memgraph.adapter.js.map +1 -1
  67. package/dist/graph/adapters/neo4j.adapter.js +51 -21
  68. package/dist/graph/adapters/neo4j.adapter.js.map +1 -1
  69. package/dist/graph/adapters/neptune.adapter.js +32 -16
  70. package/dist/graph/adapters/neptune.adapter.js.map +1 -1
  71. package/dist/graph/graphs.service.d.ts +24 -2
  72. package/dist/graph/graphs.service.js +238 -28
  73. package/dist/graph/graphs.service.js.map +1 -1
  74. package/dist/graph/types/connection.interface.d.ts +8 -0
  75. package/dist/graph/types/query.interface.d.ts +21 -14
  76. package/dist/index.d.ts +367 -20
  77. package/dist/index.js +510 -48
  78. package/dist/index.js.map +1 -1
  79. package/dist/inputs/inputs.service.d.ts +1 -1
  80. package/dist/notifications/notifications.service.d.ts +7 -2
  81. package/dist/notifications/notifications.service.js +2 -0
  82. package/dist/notifications/notifications.service.js.map +1 -1
  83. package/dist/processor/services/processor.service.d.ts +5 -1
  84. package/dist/processor/services/processor.service.js +35 -2
  85. package/dist/processor/services/processor.service.js.map +1 -1
  86. package/dist/products/services/products.service.d.ts +76 -2
  87. package/dist/products/services/products.service.js +984 -27
  88. package/dist/products/services/products.service.js.map +1 -1
  89. package/dist/products/validators/joi-validators/create.productAgent.validator.js +52 -4
  90. package/dist/products/validators/joi-validators/create.productAgent.validator.js.map +1 -1
  91. package/dist/products/validators/joi-validators/create.productGraph.validator.js +2 -0
  92. package/dist/products/validators/joi-validators/create.productGraph.validator.js.map +1 -1
  93. package/dist/products/validators/joi-validators/create.productMessageBrokers.validator.js +1 -7
  94. package/dist/products/validators/joi-validators/create.productMessageBrokers.validator.js.map +1 -1
  95. package/dist/products/validators/joi-validators/create.productVector.validator.js +4 -4
  96. package/dist/products/validators/joi-validators/create.productVector.validator.js.map +1 -1
  97. package/dist/products/validators/joi-validators/update.productGraph.validator.js +2 -0
  98. package/dist/products/validators/joi-validators/update.productGraph.validator.js.map +1 -1
  99. package/dist/resilience/fallback.service.d.ts +4 -1
  100. package/dist/resilience/fallback.service.js +8 -10
  101. package/dist/resilience/fallback.service.js.map +1 -1
  102. package/dist/resilience/healthcheck.service.d.ts +6 -1
  103. package/dist/resilience/healthcheck.service.js +9 -0
  104. package/dist/resilience/healthcheck.service.js.map +1 -1
  105. package/dist/resilience/quota.service.d.ts +4 -1
  106. package/dist/resilience/quota.service.js +2 -0
  107. package/dist/resilience/quota.service.js.map +1 -1
  108. package/dist/resilience/resilience.service.d.ts +4 -1
  109. package/dist/resilience/resilience.service.js.map +1 -1
  110. package/dist/secrets/secrets.service.d.ts +11 -1
  111. package/dist/secrets/secrets.service.js +109 -10
  112. package/dist/secrets/secrets.service.js.map +1 -1
  113. package/dist/storage/storage.service.d.ts +4 -1
  114. package/dist/storage/storage.service.js +6 -1
  115. package/dist/storage/storage.service.js.map +1 -1
  116. package/dist/test/index.js +1 -3
  117. package/dist/test/index.js.map +1 -1
  118. package/dist/test/test.broker.kafka.d.ts +1 -0
  119. package/dist/test/test.broker.kafka.js +172 -0
  120. package/dist/test/test.broker.kafka.js.map +1 -0
  121. package/dist/test/test.broker.nats.d.ts +1 -0
  122. package/dist/test/test.broker.nats.js +193 -0
  123. package/dist/test/test.broker.nats.js.map +1 -0
  124. package/dist/test/test.broker.pubsub.d.ts +1 -0
  125. package/dist/test/test.broker.pubsub.js +171 -0
  126. package/dist/test/test.broker.pubsub.js.map +1 -0
  127. package/dist/test/test.broker.rabbitmq.d.ts +1 -0
  128. package/dist/test/test.broker.rabbitmq.js +164 -0
  129. package/dist/test/test.broker.rabbitmq.js.map +1 -0
  130. package/dist/test/test.broker.redis.d.ts +1 -0
  131. package/dist/test/test.broker.redis.js +168 -0
  132. package/dist/test/test.broker.redis.js.map +1 -0
  133. package/dist/test/test.broker.sqs.d.ts +1 -0
  134. package/dist/test/test.broker.sqs.js +158 -0
  135. package/dist/test/test.broker.sqs.js.map +1 -0
  136. package/dist/test/test.caches.d.ts +1 -0
  137. package/dist/test/test.caches.js +231 -0
  138. package/dist/test/test.caches.js.map +1 -0
  139. package/dist/test/test.database.dynamo.d.ts +1 -0
  140. package/dist/test/test.database.dynamo.js +265 -0
  141. package/dist/test/test.database.dynamo.js.map +1 -0
  142. package/dist/test/test.database.js +2 -2
  143. package/dist/test/test.database.js.map +1 -1
  144. package/dist/test/test.database.mongo.d.ts +1 -0
  145. package/dist/test/test.database.mongo.js +371 -0
  146. package/dist/test/test.database.mongo.js.map +1 -0
  147. package/dist/test/test.database.mysql.d.ts +1 -0
  148. package/dist/test/test.database.mysql.js +415 -0
  149. package/dist/test/test.database.mysql.js.map +1 -0
  150. package/dist/test/test.database.postgres.d.ts +1 -0
  151. package/dist/test/test.database.postgres.js +412 -0
  152. package/dist/test/test.database.postgres.js.map +1 -0
  153. package/dist/test/test.email.brevo.d.ts +1 -0
  154. package/dist/test/test.email.brevo.js +326 -0
  155. package/dist/test/test.email.brevo.js.map +1 -0
  156. package/dist/test/test.email.mailgun.d.ts +1 -0
  157. package/dist/test/test.email.mailgun.js +352 -0
  158. package/dist/test/test.email.mailgun.js.map +1 -0
  159. package/dist/test/test.email.postmark.d.ts +1 -0
  160. package/dist/test/test.email.postmark.js +316 -0
  161. package/dist/test/test.email.postmark.js.map +1 -0
  162. package/dist/test/test.email.sendgrid.d.ts +1 -0
  163. package/dist/test/test.email.sendgrid.js +365 -0
  164. package/dist/test/test.email.sendgrid.js.map +1 -0
  165. package/dist/test/test.email.smtp.d.ts +1 -0
  166. package/dist/test/test.email.smtp.js +323 -0
  167. package/dist/test/test.email.smtp.js.map +1 -0
  168. package/dist/test/test.graph.arangodb.d.ts +1 -0
  169. package/dist/test/test.graph.arangodb.js +358 -0
  170. package/dist/test/test.graph.arangodb.js.map +1 -0
  171. package/dist/test/test.graph.memgraph.d.ts +1 -0
  172. package/dist/test/test.graph.memgraph.js +320 -0
  173. package/dist/test/test.graph.memgraph.js.map +1 -0
  174. package/dist/test/test.graph.neo4j.d.ts +1 -0
  175. package/dist/test/test.graph.neo4j.js +218 -0
  176. package/dist/test/test.graph.neo4j.js.map +1 -0
  177. package/dist/test/test.graph.neptune.d.ts +1 -0
  178. package/dist/test/test.graph.neptune.js +331 -0
  179. package/dist/test/test.graph.neptune.js.map +1 -0
  180. package/dist/test/test.notifications.d.ts +1 -0
  181. package/dist/test/test.notifications.js +198 -0
  182. package/dist/test/test.notifications.js.map +1 -0
  183. package/dist/test/test.push.expo.d.ts +1 -0
  184. package/dist/test/test.push.expo.js +442 -0
  185. package/dist/test/test.push.expo.js.map +1 -0
  186. package/dist/test/test.push.firebase.d.ts +1 -0
  187. package/dist/test/test.push.firebase.js +409 -0
  188. package/dist/test/test.push.firebase.js.map +1 -0
  189. package/dist/test/test.session.d.ts +1 -0
  190. package/dist/test/test.session.js +299 -0
  191. package/dist/test/test.session.js.map +1 -0
  192. package/dist/test/test.sms.nexmo.d.ts +1 -0
  193. package/dist/test/test.sms.nexmo.js +278 -0
  194. package/dist/test/test.sms.nexmo.js.map +1 -0
  195. package/dist/test/test.sms.twilio.d.ts +1 -0
  196. package/dist/test/test.sms.twilio.js +275 -0
  197. package/dist/test/test.sms.twilio.js.map +1 -0
  198. package/dist/test/test.storage.js +169 -299
  199. package/dist/test/test.storage.js.map +1 -1
  200. package/dist/test/test.vector.pinecone.d.ts +1 -0
  201. package/dist/test/test.vector.pinecone.js +238 -0
  202. package/dist/test/test.vector.pinecone.js.map +1 -0
  203. package/dist/test/test.vector.qdrant.d.ts +1 -0
  204. package/dist/test/test.vector.qdrant.js +307 -0
  205. package/dist/test/test.vector.qdrant.js.map +1 -0
  206. package/dist/test/test.vector.weaviate.d.ts +1 -0
  207. package/dist/test/test.vector.weaviate.js +325 -0
  208. package/dist/test/test.vector.weaviate.js.map +1 -0
  209. package/dist/types/appBuilder.types.d.ts +6 -2
  210. package/dist/types/enums.d.ts +2 -0
  211. package/dist/types/enums.js +2 -0
  212. package/dist/types/enums.js.map +1 -1
  213. package/dist/types/index.types.d.ts +2 -4
  214. package/dist/types/index.types.js +0 -1
  215. package/dist/types/index.types.js.map +1 -1
  216. package/dist/types/processor.types.d.ts +18 -0
  217. package/dist/types/productsBuilder.types.d.ts +19 -15
  218. package/dist/types/productsBuilder.types.js.map +1 -1
  219. package/dist/types/requests.types.d.ts +2 -0
  220. package/dist/utils/index.js +23 -4
  221. package/dist/utils/index.js.map +1 -1
  222. package/dist/vector/adapters/base.adapter.d.ts +1 -1
  223. package/dist/vector/adapters/memory.adapter.d.ts +1 -1
  224. package/dist/vector/adapters/memory.adapter.js +1 -1
  225. package/dist/vector/adapters/memory.adapter.js.map +1 -1
  226. package/dist/vector/adapters/pinecone.adapter.d.ts +1 -1
  227. package/dist/vector/adapters/pinecone.adapter.js +1 -1
  228. package/dist/vector/adapters/pinecone.adapter.js.map +1 -1
  229. package/dist/vector/adapters/qdrant.adapter.d.ts +1 -1
  230. package/dist/vector/adapters/qdrant.adapter.js +1 -1
  231. package/dist/vector/adapters/qdrant.adapter.js.map +1 -1
  232. package/dist/vector/adapters/weaviate.adapter.d.ts +1 -1
  233. package/dist/vector/adapters/weaviate.adapter.js +1 -1
  234. package/dist/vector/adapters/weaviate.adapter.js.map +1 -1
  235. package/dist/vector/index.d.ts +2 -2
  236. package/dist/vector/index.js +2 -2
  237. package/dist/vector/utils/vector-error.js +0 -1
  238. package/dist/vector/utils/vector-error.js.map +1 -1
  239. package/dist/vector/vector-database.service.d.ts +9 -6
  240. package/dist/vector/vector-database.service.js +7 -6
  241. package/dist/vector/vector-database.service.js.map +1 -1
  242. package/dist/vector/vector.service.d.ts +3 -3
  243. package/dist/vector/vector.service.js +12 -9
  244. package/dist/vector/vector.service.js.map +1 -1
  245. package/dist/workflows/workflow-executor.d.ts +4 -1
  246. package/dist/workflows/workflow-executor.js +10 -2
  247. package/dist/workflows/workflow-executor.js.map +1 -1
  248. package/dist/workflows/workflows.service.d.ts +8 -2
  249. package/dist/workflows/workflows.service.js +66 -41
  250. package/dist/workflows/workflows.service.js.map +1 -1
  251. package/package.json +29 -4
@@ -0,0 +1,415 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const database_1 = require("../database");
7
+ const index_1 = __importDefault(require("./index"));
8
+ /**
9
+ * MySQL Database Tests
10
+ *
11
+ * Comprehensive tests for MySQL database operations:
12
+ * - Connection management
13
+ * - Schema operations (create, alter, drop tables)
14
+ * - CRUD operations (insert, query, update, delete)
15
+ * - Aggregations (count, sum, avg, min, max)
16
+ * - Transactions
17
+ * - Pre-save operations (trim, hash, encrypt, normalize)
18
+ * - Raw queries
19
+ * - Migrations
20
+ */
21
+ const { databases } = index_1.default;
22
+ // Start timing
23
+ const startTime = performance.now();
24
+ console.log(`[${new Date().toISOString()}] Starting MySQL database operations...`);
25
+ databases.create({
26
+ product: 'ductape:rematch',
27
+ name: 'MySQLDB',
28
+ tag: 'mysql-db',
29
+ type: database_1.DatabaseType.MYSQL,
30
+ envs: [{
31
+ slug: 'prd',
32
+ connection_url: 'mysql://avnadmin:AVNS_PN0sY_jbg5uepQYX81H@mysql-292180ef-ductapetech-postgres.e.aivencloud.com:24999/rematch-prd?ssl-mode=REQUIRED'
33
+ }, {
34
+ slug: 'dev',
35
+ connection_url: 'mysql://avnadmin:AVNS_PN0sY_jbg5uepQYX81H@mysql-292180ef-ductapetech-postgres.e.aivencloud.com:24999/rematch-dev?ssl-mode=REQUIRED'
36
+ }]
37
+ }).then(() => {
38
+ console.log('MySQL database created');
39
+ });
40
+ databases
41
+ .connect({
42
+ env: 'prd',
43
+ product: 'ductape:rematch',
44
+ database: 'mysql-db', // Your MySQL database tag
45
+ })
46
+ .then(async (connection) => {
47
+ const connectTime = performance.now();
48
+ console.log(`[TIMING] Connect: ${(connectTime - startTime).toFixed(2)}ms`);
49
+ console.log('MySQL connection established:', connection);
50
+ // ==================== SCHEMA OPERATIONS ====================
51
+ console.log('\n--- Schema Operations ---');
52
+ // List existing tables
53
+ const listStart = performance.now();
54
+ const tables = await databases.schema.list();
55
+ console.log(`[TIMING] Schema list: ${(performance.now() - listStart).toFixed(2)}ms`);
56
+ console.log('Existing tables:', tables);
57
+ // Drop test table if exists
58
+ if (tables.includes('test_users')) {
59
+ console.log('Dropping existing "test_users" table...');
60
+ await databases.schema.drop('test_users');
61
+ }
62
+ // Create table with MySQL-specific types
63
+ console.log('Creating table "test_users"...');
64
+ const createStart = performance.now();
65
+ await databases.schema.create('test_users', {
66
+ id: { type: 'INT', primaryKey: true, autoIncrement: true },
67
+ uuid: { type: 'CHAR(36)', default: '(UUID())' },
68
+ name: { type: 'VARCHAR(255)', nullable: false },
69
+ email: { type: 'VARCHAR(255)', unique: true, nullable: false },
70
+ password: { type: 'VARCHAR(255)' },
71
+ age: { type: 'INT' },
72
+ balance: { type: 'DECIMAL(10,2)', default: '0.00' },
73
+ metadata: { type: 'JSON' },
74
+ bio: { type: 'TEXT' },
75
+ status: { type: "ENUM('active', 'inactive', 'pending')", default: "'active'" },
76
+ active: { type: 'BOOLEAN', default: true },
77
+ created_at: { type: 'TIMESTAMP', default: 'CURRENT_TIMESTAMP' },
78
+ updated_at: { type: 'TIMESTAMP', default: 'CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP' },
79
+ });
80
+ console.log(`[TIMING] Schema create: ${(performance.now() - createStart).toFixed(2)}ms`);
81
+ // Get table schema
82
+ const schemaStart = performance.now();
83
+ const tableSchema = await databases.schema.describe('test_users');
84
+ console.log(`[TIMING] Schema describe: ${(performance.now() - schemaStart).toFixed(2)}ms`);
85
+ console.log('Table schema:', JSON.stringify(tableSchema, null, 2));
86
+ // Create index
87
+ console.log('Creating index on email...');
88
+ const indexStart = performance.now();
89
+ await databases.schema.createIndex('test_users', {
90
+ name: 'idx_test_users_email',
91
+ columns: ['email'],
92
+ unique: true,
93
+ });
94
+ console.log(`[TIMING] Create index: ${(performance.now() - indexStart).toFixed(2)}ms`);
95
+ // Create composite index
96
+ console.log('Creating composite index on name and age...');
97
+ const compIndexStart = performance.now();
98
+ await databases.schema.createIndex('test_users', {
99
+ name: 'idx_test_users_name_age',
100
+ columns: ['name', 'age'],
101
+ });
102
+ console.log(`[TIMING] Create composite index: ${(performance.now() - compIndexStart).toFixed(2)}ms`);
103
+ // ==================== INSERT OPERATIONS ====================
104
+ console.log('\n--- Insert Operations ---');
105
+ // Generate unique test data
106
+ const timestamp = Date.now();
107
+ const testEmail = `test.user.${timestamp}@example.com`;
108
+ // Insert with pre-save operations
109
+ console.log('Inserting user with pre-save operations...');
110
+ const insertStart = performance.now();
111
+ const insertResult = await databases.insert({
112
+ table: 'test_users',
113
+ data: {
114
+ name: ' John Doe ',
115
+ email: testEmail.toUpperCase(),
116
+ password: 'password123',
117
+ age: 30,
118
+ balance: 1000.50,
119
+ metadata: JSON.stringify({ role: 'admin', preferences: { theme: 'dark' } }),
120
+ bio: 'Senior software developer with 10 years of experience.',
121
+ status: 'active',
122
+ },
123
+ returning: true,
124
+ preSave: [
125
+ database_1.PreSave.trim('name'),
126
+ database_1.PreSave.normalizeEmail('email'),
127
+ database_1.PreSave.hash('password', { algorithm: 'sha256' }),
128
+ ],
129
+ });
130
+ console.log(`[TIMING] Insert: ${(performance.now() - insertStart).toFixed(2)}ms`);
131
+ console.log('Inserted user:', JSON.stringify(insertResult, null, 2));
132
+ // Bulk insert
133
+ console.log('Bulk inserting users...');
134
+ const bulkStart = performance.now();
135
+ const bulkResult = await databases.insert({
136
+ table: 'test_users',
137
+ data: [
138
+ { name: 'Jane Smith', email: `jane.${timestamp}@example.com`, age: 25, balance: 500.00, status: 'active' },
139
+ { name: 'Bob Wilson', email: `bob.${timestamp}@example.com`, age: 35, balance: 1500.75, status: 'active' },
140
+ { name: 'Alice Brown', email: `alice.${timestamp}@example.com`, age: 28, balance: 750.25, status: 'pending' },
141
+ { name: 'Charlie Davis', email: `charlie.${timestamp}@example.com`, age: 32, balance: 900.00, status: 'inactive' },
142
+ ],
143
+ returning: true,
144
+ });
145
+ console.log(`[TIMING] Bulk insert: ${(performance.now() - bulkStart).toFixed(2)}ms`);
146
+ console.log(`Inserted ${bulkResult.count} users`);
147
+ // Upsert (ON DUPLICATE KEY UPDATE)
148
+ console.log('Testing upsert (ON DUPLICATE KEY UPDATE)...');
149
+ const upsertStart = performance.now();
150
+ const upsertResult = await databases.insert({
151
+ table: 'test_users',
152
+ data: { name: 'John Doe Updated', email: testEmail, age: 31 },
153
+ onConflict: {
154
+ columns: ['email'],
155
+ action: 'update',
156
+ update: ['name', 'age'],
157
+ },
158
+ returning: true,
159
+ });
160
+ console.log(`[TIMING] Upsert: ${(performance.now() - upsertStart).toFixed(2)}ms`);
161
+ console.log('Upsert result:', JSON.stringify(upsertResult, null, 2));
162
+ // ==================== QUERY OPERATIONS ====================
163
+ console.log('\n--- Query Operations ---');
164
+ // Simple query
165
+ console.log('Querying all users...');
166
+ const queryStart = performance.now();
167
+ const allUsers = await databases.query({
168
+ table: 'test_users',
169
+ orderBy: [{ column: 'created_at', order: 'DESC' }],
170
+ });
171
+ console.log(`[TIMING] Query all: ${(performance.now() - queryStart).toFixed(2)}ms`);
172
+ console.log(`Found ${allUsers.data.length} users`);
173
+ // Query with where clause
174
+ console.log('Querying users with age > 27...');
175
+ const whereStart = performance.now();
176
+ const filteredUsers = await databases.query({
177
+ table: 'test_users',
178
+ where: { age: database_1.Operators.gt(27) },
179
+ select: ['id', 'name', 'email', 'age', 'status'],
180
+ });
181
+ console.log(`[TIMING] Query with where: ${(performance.now() - whereStart).toFixed(2)}ms`);
182
+ console.log('Filtered users:', JSON.stringify(filteredUsers.data, null, 2));
183
+ // Query with ENUM filter
184
+ console.log('Querying active users...');
185
+ const enumStart = performance.now();
186
+ const activeUsers = await databases.query({
187
+ table: 'test_users',
188
+ where: { status: 'active' },
189
+ });
190
+ console.log(`[TIMING] ENUM query: ${(performance.now() - enumStart).toFixed(2)}ms`);
191
+ console.log(`Found ${activeUsers.data.length} active users`);
192
+ // Query with complex operators
193
+ console.log('Complex query with multiple conditions...');
194
+ const complexStart = performance.now();
195
+ const complexQuery = await databases.query({
196
+ table: 'test_users',
197
+ where: {
198
+ $and: [
199
+ { age: database_1.Operators.between(25, 35) },
200
+ { balance: database_1.Operators.gte(500) },
201
+ { status: database_1.Operators.in(['active', 'pending']) },
202
+ ],
203
+ },
204
+ orderBy: [{ column: 'balance', order: 'DESC' }],
205
+ limit: 10,
206
+ });
207
+ console.log(`[TIMING] Complex query: ${(performance.now() - complexStart).toFixed(2)}ms`);
208
+ console.log('Complex query results:', complexQuery.data.length);
209
+ // Query with LIKE
210
+ console.log('Query with LIKE operator...');
211
+ const likeStart = performance.now();
212
+ const likeQuery = await databases.query({
213
+ table: 'test_users',
214
+ where: { name: database_1.Operators.like('%Smith%') },
215
+ });
216
+ console.log(`[TIMING] LIKE query: ${(performance.now() - likeStart).toFixed(2)}ms`);
217
+ console.log('LIKE query results:', likeQuery.data.length);
218
+ // Query with pagination
219
+ console.log('Query with pagination...');
220
+ const pageStart = performance.now();
221
+ const pagedQuery = await databases.query({
222
+ table: 'test_users',
223
+ orderBy: [{ column: 'id', order: 'ASC' }],
224
+ limit: 2,
225
+ offset: 2,
226
+ });
227
+ console.log(`[TIMING] Paginated query: ${(performance.now() - pageStart).toFixed(2)}ms`);
228
+ console.log('Page results:', pagedQuery.data.length);
229
+ // ==================== UPDATE OPERATIONS ====================
230
+ console.log('\n--- Update Operations ---');
231
+ // Simple update
232
+ console.log('Updating user balance...');
233
+ const updateStart = performance.now();
234
+ const updateResult = await databases.update({
235
+ table: 'test_users',
236
+ data: { balance: 2000.00 },
237
+ where: { email: testEmail },
238
+ returning: true,
239
+ });
240
+ console.log(`[TIMING] Update: ${(performance.now() - updateStart).toFixed(2)}ms`);
241
+ console.log('Update result:', JSON.stringify(updateResult, null, 2));
242
+ // Increment update
243
+ console.log('Incrementing all active balances by 100...');
244
+ const incStart = performance.now();
245
+ const incResult = await databases.update({
246
+ table: 'test_users',
247
+ data: { balance: database_1.Operators.increment(100) },
248
+ where: { status: 'active' },
249
+ });
250
+ console.log(`[TIMING] Increment update: ${(performance.now() - incStart).toFixed(2)}ms`);
251
+ console.log(`Updated ${incResult.count} rows`);
252
+ // Update with multiple conditions
253
+ console.log('Update with multiple conditions...');
254
+ const multiUpdateStart = performance.now();
255
+ const multiUpdateResult = await databases.update({
256
+ table: 'test_users',
257
+ data: { status: 'active' },
258
+ where: {
259
+ $and: [
260
+ { status: 'pending' },
261
+ { age: database_1.Operators.gte(25) },
262
+ ],
263
+ },
264
+ });
265
+ console.log(`[TIMING] Multi-condition update: ${(performance.now() - multiUpdateStart).toFixed(2)}ms`);
266
+ console.log(`Updated ${multiUpdateResult.count} rows`);
267
+ // ==================== AGGREGATION OPERATIONS ====================
268
+ console.log('\n--- Aggregation Operations ---');
269
+ // Count
270
+ const countStart = performance.now();
271
+ const count = await databases.count({ table: 'test_users' });
272
+ console.log(`[TIMING] Count: ${(performance.now() - countStart).toFixed(2)}ms`);
273
+ console.log('Total users:', count);
274
+ // Count with where
275
+ const countWhereStart = performance.now();
276
+ const activeCount = await databases.count({
277
+ table: 'test_users',
278
+ where: { status: 'active' },
279
+ });
280
+ console.log(`[TIMING] Count with where: ${(performance.now() - countWhereStart).toFixed(2)}ms`);
281
+ console.log('Active users:', activeCount);
282
+ // Sum
283
+ const sumStart = performance.now();
284
+ const totalBalance = await databases.sum({
285
+ table: 'test_users',
286
+ column: 'balance',
287
+ });
288
+ console.log(`[TIMING] Sum: ${(performance.now() - sumStart).toFixed(2)}ms`);
289
+ console.log('Total balance:', totalBalance);
290
+ // Average
291
+ const avgStart = performance.now();
292
+ const avgAge = await databases.avg({
293
+ table: 'test_users',
294
+ column: 'age',
295
+ });
296
+ console.log(`[TIMING] Avg: ${(performance.now() - avgStart).toFixed(2)}ms`);
297
+ console.log('Average age:', avgAge);
298
+ // Min/Max
299
+ const minStart = performance.now();
300
+ const minAge = await databases.min({ table: 'test_users', column: 'age' });
301
+ console.log(`[TIMING] Min: ${(performance.now() - minStart).toFixed(2)}ms`);
302
+ console.log('Minimum age:', minAge);
303
+ const maxStart = performance.now();
304
+ const maxBalance = await databases.max({ table: 'test_users', column: 'balance' });
305
+ console.log(`[TIMING] Max: ${(performance.now() - maxStart).toFixed(2)}ms`);
306
+ console.log('Maximum balance:', maxBalance);
307
+ // Group by aggregation
308
+ const groupStart = performance.now();
309
+ const groupResult = await databases.aggregate({
310
+ table: 'test_users',
311
+ operations: [
312
+ { type: 'count', alias: 'user_count' },
313
+ { type: 'sum', column: 'balance', alias: 'total_balance' },
314
+ { type: 'avg', column: 'age', alias: 'avg_age' },
315
+ ],
316
+ groupBy: ['status'],
317
+ });
318
+ console.log(`[TIMING] Group by: ${(performance.now() - groupStart).toFixed(2)}ms`);
319
+ console.log('Group by status:', JSON.stringify(groupResult, null, 2));
320
+ // ==================== RAW QUERIES ====================
321
+ console.log('\n--- Raw Queries ---');
322
+ // MySQL-specific raw query
323
+ const rawStart = performance.now();
324
+ const rawResult = await databases.raw({
325
+ query: `
326
+ SELECT
327
+ name,
328
+ email,
329
+ age,
330
+ balance,
331
+ status,
332
+ CASE
333
+ WHEN balance > 1000 THEN 'high'
334
+ WHEN balance > 500 THEN 'medium'
335
+ ELSE 'low'
336
+ END as balance_tier,
337
+ TIMESTAMPDIFF(YEAR, created_at, NOW()) as years_since_created
338
+ FROM test_users
339
+ WHERE age > ?
340
+ ORDER BY balance DESC
341
+ `,
342
+ params: [25],
343
+ });
344
+ console.log(`[TIMING] Raw query: ${(performance.now() - rawStart).toFixed(2)}ms`);
345
+ console.log('Raw query results:', JSON.stringify(rawResult.data, null, 2));
346
+ // ==================== TRANSACTION ====================
347
+ console.log('\n--- Transaction ---');
348
+ const txStart = performance.now();
349
+ try {
350
+ const tx = await databases.beginTransaction({ isolationLevel: 'repeatable_read' });
351
+ // Insert within transaction
352
+ await databases.insert({
353
+ table: 'test_users',
354
+ data: { name: 'TX User', email: `tx.${timestamp}@example.com`, age: 40, status: 'active' },
355
+ transaction: tx,
356
+ });
357
+ // Update within transaction
358
+ await databases.update({
359
+ table: 'test_users',
360
+ data: { balance: database_1.Operators.increment(50) },
361
+ where: { email: `tx.${timestamp}@example.com` },
362
+ transaction: tx,
363
+ });
364
+ // Commit
365
+ await tx.commit();
366
+ console.log(`[TIMING] Transaction: ${(performance.now() - txStart).toFixed(2)}ms`);
367
+ console.log('Transaction committed successfully');
368
+ }
369
+ catch (error) {
370
+ console.log('Transaction error:', error);
371
+ }
372
+ // ==================== DELETE OPERATIONS ====================
373
+ console.log('\n--- Delete Operations ---');
374
+ // Delete specific record
375
+ const deleteStart = performance.now();
376
+ const deleteResult = await databases.delete({
377
+ table: 'test_users',
378
+ where: { email: `tx.${timestamp}@example.com` },
379
+ returning: true,
380
+ });
381
+ console.log(`[TIMING] Delete: ${(performance.now() - deleteStart).toFixed(2)}ms`);
382
+ console.log(`Deleted ${deleteResult.count} rows`);
383
+ // Delete with multiple conditions
384
+ const multiDeleteStart = performance.now();
385
+ const multiDeleteResult = await databases.delete({
386
+ table: 'test_users',
387
+ where: {
388
+ $and: [
389
+ { status: 'inactive' },
390
+ { balance: database_1.Operators.lt(1000) },
391
+ ],
392
+ },
393
+ });
394
+ console.log(`[TIMING] Multi-condition delete: ${(performance.now() - multiDeleteStart).toFixed(2)}ms`);
395
+ console.log(`Deleted ${multiDeleteResult.count} rows`);
396
+ // ==================== CLEANUP ====================
397
+ console.log('\n--- Cleanup ---');
398
+ const cleanupStart = performance.now();
399
+ // Drop indexes
400
+ await databases.schema.dropIndex('test_users', 'idx_test_users_email');
401
+ await databases.schema.dropIndex('test_users', 'idx_test_users_name_age');
402
+ console.log('Dropped indexes');
403
+ // Drop table
404
+ await databases.schema.drop('test_users');
405
+ console.log('Dropped table');
406
+ console.log(`[TIMING] Cleanup: ${(performance.now() - cleanupStart).toFixed(2)}ms`);
407
+ // ==================== SUMMARY ====================
408
+ const totalTime = performance.now() - startTime;
409
+ console.log(`\n[TIMING SUMMARY]`);
410
+ console.log(` Total time: ${totalTime.toFixed(2)}ms`);
411
+ })
412
+ .catch((err) => {
413
+ console.error('Error in MySQL operations:', err);
414
+ });
415
+ //# sourceMappingURL=test.database.mysql.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"test.database.mysql.js","sourceRoot":"","sources":["../../src/test/test.database.mysql.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export {};