@arcaelas/dynamite 1.0.25 → 2.1.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.
- package/README.md +13 -13
- package/{src → build/cjs}/@types/index.d.ts +26 -1
- package/build/cjs/@types/index.js.map +1 -0
- package/{src → build/cjs}/core/client.d.ts +22 -19
- package/build/cjs/core/client.js +384 -0
- package/build/cjs/core/client.js.map +1 -0
- package/build/cjs/core/decorator.d.ts +38 -0
- package/build/cjs/core/decorator.js +38 -0
- package/build/cjs/core/decorator.js.map +1 -0
- package/build/cjs/core/table.d.ts +55 -0
- package/build/cjs/core/table.js +851 -0
- package/build/cjs/core/table.js.map +1 -0
- package/build/cjs/decorators/indexes.d.ts +20 -0
- package/build/cjs/decorators/indexes.js +45 -0
- package/build/cjs/decorators/indexes.js.map +1 -0
- package/{src → build/cjs}/decorators/relations.d.ts +8 -7
- package/{src → build/cjs}/decorators/relations.js +9 -8
- package/build/cjs/decorators/relations.js.map +1 -0
- package/build/cjs/decorators/timestamps.d.ts +20 -0
- package/build/cjs/decorators/timestamps.js +34 -0
- package/build/cjs/decorators/timestamps.js.map +1 -0
- package/build/cjs/decorators/transforms.d.ts +41 -0
- package/build/cjs/decorators/transforms.js +98 -0
- package/build/cjs/decorators/transforms.js.map +1 -0
- package/{src → build/cjs}/index.d.ts +5 -3
- package/{src → build/cjs}/index.js +7 -6
- package/build/cjs/index.js.map +1 -0
- package/build/cjs/package.json +1 -0
- package/build/cjs/test/basic.d.ts +1 -0
- package/build/cjs/test/basic.js +248 -0
- package/build/cjs/test/basic.js.map +1 -0
- package/build/cjs/test/bulk.d.ts +1 -0
- package/build/cjs/test/bulk.js +108 -0
- package/build/cjs/test/bulk.js.map +1 -0
- package/build/cjs/test/contracts.d.ts +1 -0
- package/build/cjs/test/contracts.js +343 -0
- package/build/cjs/test/contracts.js.map +1 -0
- package/build/cjs/test/filters.d.ts +1 -0
- package/build/cjs/test/filters.js +190 -0
- package/build/cjs/test/filters.js.map +1 -0
- package/build/cjs/test/index.d.ts +1 -0
- package/build/cjs/test/index.js +36 -0
- package/build/cjs/test/index.js.map +1 -0
- package/build/cjs/test/query_scan.d.ts +1 -0
- package/build/cjs/test/query_scan.js +195 -0
- package/build/cjs/test/query_scan.js.map +1 -0
- package/build/cjs/test/relations.d.ts +1 -0
- package/build/cjs/test/relations.js +246 -0
- package/build/cjs/test/relations.js.map +1 -0
- package/build/cjs/test/transactions.d.ts +1 -0
- package/build/cjs/test/transactions.js +145 -0
- package/build/cjs/test/transactions.js.map +1 -0
- package/{src → build/cjs}/utils/relations.d.ts +1 -0
- package/{src → build/cjs}/utils/relations.js +5 -10
- package/build/cjs/utils/relations.js.map +1 -0
- package/build/cjs/utils/ulid.d.ts +10 -0
- package/build/cjs/utils/ulid.js +55 -0
- package/build/cjs/utils/ulid.js.map +1 -0
- package/build/esm/@types/index.d.ts +213 -0
- package/build/esm/@types/index.js +8 -0
- package/build/esm/@types/index.js.map +1 -0
- package/build/esm/core/client.d.ts +96 -0
- package/build/esm/core/client.js +375 -0
- package/build/esm/core/client.js.map +1 -0
- package/build/esm/core/decorator.d.ts +38 -0
- package/build/esm/core/decorator.js +34 -0
- package/build/esm/core/decorator.js.map +1 -0
- package/build/esm/core/table.d.ts +55 -0
- package/build/esm/core/table.js +848 -0
- package/build/esm/core/table.js.map +1 -0
- package/build/esm/decorators/indexes.d.ts +20 -0
- package/build/esm/decorators/indexes.js +42 -0
- package/build/esm/decorators/indexes.js.map +1 -0
- package/build/esm/decorators/relations.d.ts +75 -0
- package/build/esm/decorators/relations.js +112 -0
- package/build/esm/decorators/relations.js.map +1 -0
- package/build/esm/decorators/timestamps.d.ts +20 -0
- package/build/esm/decorators/timestamps.js +31 -0
- package/build/esm/decorators/timestamps.js.map +1 -0
- package/build/esm/decorators/transforms.d.ts +41 -0
- package/build/esm/decorators/transforms.js +92 -0
- package/build/esm/decorators/transforms.js.map +1 -0
- package/build/esm/index.d.ts +17 -0
- package/build/esm/index.js +24 -0
- package/build/esm/index.js.map +1 -0
- package/build/esm/package.json +1 -0
- package/build/esm/test/basic.d.ts +1 -0
- package/build/esm/test/basic.js +245 -0
- package/build/esm/test/basic.js.map +1 -0
- package/build/esm/test/bulk.d.ts +1 -0
- package/build/esm/test/bulk.js +105 -0
- package/build/esm/test/bulk.js.map +1 -0
- package/build/esm/test/contracts.d.ts +1 -0
- package/build/esm/test/contracts.js +340 -0
- package/build/esm/test/contracts.js.map +1 -0
- package/build/esm/test/filters.d.ts +1 -0
- package/build/esm/test/filters.js +187 -0
- package/build/esm/test/filters.js.map +1 -0
- package/build/esm/test/index.d.ts +1 -0
- package/build/esm/test/index.js +31 -0
- package/build/esm/test/index.js.map +1 -0
- package/build/esm/test/query_scan.d.ts +1 -0
- package/build/esm/test/query_scan.js +192 -0
- package/build/esm/test/query_scan.js.map +1 -0
- package/build/esm/test/relations.d.ts +1 -0
- package/build/esm/test/relations.js +243 -0
- package/build/esm/test/relations.js.map +1 -0
- package/build/esm/test/transactions.d.ts +1 -0
- package/build/esm/test/transactions.js +142 -0
- package/build/esm/test/transactions.js.map +1 -0
- package/build/esm/utils/relations.d.ts +42 -0
- package/build/esm/utils/relations.js +207 -0
- package/build/esm/utils/relations.js.map +1 -0
- package/build/esm/utils/ulid.d.ts +10 -0
- package/build/esm/utils/ulid.js +52 -0
- package/build/esm/utils/ulid.js.map +1 -0
- package/package.json +31 -9
- package/src/core/client.js +0 -294
- package/src/core/decorator.d.ts +0 -29
- package/src/core/decorator.js +0 -103
- package/src/core/table.d.ts +0 -81
- package/src/core/table.js +0 -892
- package/src/decorators/indexes.d.ts +0 -38
- package/src/decorators/indexes.js +0 -59
- package/src/decorators/timestamps.d.ts +0 -54
- package/src/decorators/timestamps.js +0 -72
- package/src/decorators/transforms.d.ts +0 -99
- package/src/decorators/transforms.js +0 -166
- /package/{src → build/cjs}/@types/index.js +0 -0
|
@@ -0,0 +1,195 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.default = query_scan;
|
|
13
|
+
const index_1 = require("../index");
|
|
14
|
+
const client_1 = require("../core/client");
|
|
15
|
+
let Author = class Author extends index_1.Table {
|
|
16
|
+
};
|
|
17
|
+
__decorate([
|
|
18
|
+
(0, index_1.PrimaryKey)(),
|
|
19
|
+
__metadata("design:type", Object)
|
|
20
|
+
], Author.prototype, "id", void 0);
|
|
21
|
+
__decorate([
|
|
22
|
+
(0, index_1.NotNull)(),
|
|
23
|
+
__metadata("design:type", String)
|
|
24
|
+
], Author.prototype, "name", void 0);
|
|
25
|
+
__decorate([
|
|
26
|
+
(0, index_1.HasMany)(() => Book, 'author_id', 'id'),
|
|
27
|
+
__metadata("design:type", Object)
|
|
28
|
+
], Author.prototype, "books", void 0);
|
|
29
|
+
Author = __decorate([
|
|
30
|
+
(0, index_1.Name)('test_qs_authors')
|
|
31
|
+
], Author);
|
|
32
|
+
let Book = class Book extends index_1.Table {
|
|
33
|
+
};
|
|
34
|
+
__decorate([
|
|
35
|
+
(0, index_1.PrimaryKey)(),
|
|
36
|
+
__metadata("design:type", Object)
|
|
37
|
+
], Book.prototype, "id", void 0);
|
|
38
|
+
__decorate([
|
|
39
|
+
(0, index_1.NotNull)(),
|
|
40
|
+
__metadata("design:type", String)
|
|
41
|
+
], Book.prototype, "title", void 0);
|
|
42
|
+
__decorate([
|
|
43
|
+
(0, index_1.Default)(''),
|
|
44
|
+
__metadata("design:type", String)
|
|
45
|
+
], Book.prototype, "author_id", void 0);
|
|
46
|
+
__decorate([
|
|
47
|
+
(0, index_1.Default)(() => 0),
|
|
48
|
+
__metadata("design:type", Object)
|
|
49
|
+
], Book.prototype, "pages", void 0);
|
|
50
|
+
__decorate([
|
|
51
|
+
(0, index_1.BelongsTo)(() => Author, 'id', 'author_id'),
|
|
52
|
+
__metadata("design:type", Object)
|
|
53
|
+
], Book.prototype, "author", void 0);
|
|
54
|
+
Book = __decorate([
|
|
55
|
+
(0, index_1.Name)('test_qs_books')
|
|
56
|
+
], Book);
|
|
57
|
+
let passed = 0;
|
|
58
|
+
let failed = 0;
|
|
59
|
+
function assert(label, condition, detail) {
|
|
60
|
+
if (condition) {
|
|
61
|
+
console.log(` OK ${label}`);
|
|
62
|
+
passed++;
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
65
|
+
console.error(` FAIL ${label}${detail ? ` -- ${detail}` : ''}`);
|
|
66
|
+
failed++;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
// Interceptor para trackear que comando se usó
|
|
70
|
+
function trackCommands() {
|
|
71
|
+
const client = (0, client_1.requireClient)();
|
|
72
|
+
const log = [];
|
|
73
|
+
const original = client.send.bind(client);
|
|
74
|
+
client.send = async (cmd) => {
|
|
75
|
+
log.push(cmd.constructor.name);
|
|
76
|
+
return original(cmd);
|
|
77
|
+
};
|
|
78
|
+
return {
|
|
79
|
+
log,
|
|
80
|
+
last: () => log[log.length - 1],
|
|
81
|
+
reset: () => { log.length = 0; },
|
|
82
|
+
restore: () => { client.send = original; },
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
async function query_scan() {
|
|
86
|
+
console.log('\n=== QUERY vs SCAN ===\n');
|
|
87
|
+
const dynamite = new index_1.Dynamite({
|
|
88
|
+
tables: [Author, Book],
|
|
89
|
+
region: 'local',
|
|
90
|
+
endpoint: 'http://localhost:8000',
|
|
91
|
+
credentials: { accessKeyId: 'local', secretAccessKey: 'local' },
|
|
92
|
+
});
|
|
93
|
+
await dynamite.connect();
|
|
94
|
+
await dynamite.sync();
|
|
95
|
+
// Seed
|
|
96
|
+
const a1 = await Author.create({ name: 'Tolkien' });
|
|
97
|
+
const a2 = await Author.create({ name: 'Asimov' });
|
|
98
|
+
for (let i = 0; i < 10; i++) {
|
|
99
|
+
await Book.create({ title: `Book_${i}`, author_id: i < 6 ? a1.id : a2.id, pages: (i + 1) * 50 });
|
|
100
|
+
}
|
|
101
|
+
const tracker = trackCommands();
|
|
102
|
+
// -- Query por PK --
|
|
103
|
+
console.log('-- Query por PK --');
|
|
104
|
+
tracker.reset();
|
|
105
|
+
const by_pk = await Author.where({ id: a1.id });
|
|
106
|
+
assert('where por PK usa QueryCommand', tracker.last() === 'QueryCommand');
|
|
107
|
+
assert('where por PK retorna correcto', by_pk[0]?.name === 'Tolkien');
|
|
108
|
+
// -- Query por PK con first --
|
|
109
|
+
tracker.reset();
|
|
110
|
+
const first_pk = await Author.first({ id: a1.id });
|
|
111
|
+
assert('first por PK usa QueryCommand', tracker.log.includes('QueryCommand'));
|
|
112
|
+
assert('first por PK retorna correcto', first_pk?.name === 'Tolkien');
|
|
113
|
+
// -- Scan por campo sin GSI --
|
|
114
|
+
console.log('\n-- Scan por campo sin GSI --');
|
|
115
|
+
tracker.reset();
|
|
116
|
+
const by_name = await Author.where({ name: 'Tolkien' });
|
|
117
|
+
assert('where por name usa ScanCommand', tracker.last() === 'ScanCommand');
|
|
118
|
+
assert('where por name retorna correcto', by_name[0]?.name === 'Tolkien');
|
|
119
|
+
// -- Query por GSI (author_id en books) --
|
|
120
|
+
console.log('\n-- Query por GSI --');
|
|
121
|
+
tracker.reset();
|
|
122
|
+
const by_fk = await Book.where({ author_id: a1.id });
|
|
123
|
+
// author_id tiene GSI porque Author.@HasMany lo declara y connect() lo registra
|
|
124
|
+
const used_query = tracker.log.includes('QueryCommand');
|
|
125
|
+
const used_scan = tracker.log.includes('ScanCommand');
|
|
126
|
+
if (used_query) {
|
|
127
|
+
assert('where por FK (author_id) usa QueryCommand', true);
|
|
128
|
+
}
|
|
129
|
+
else {
|
|
130
|
+
// GSI puede no existir si sync no corrió en este runtime, fallback a Scan es correcto
|
|
131
|
+
assert('where por FK (author_id) usa ScanCommand (GSI no creado)', used_scan);
|
|
132
|
+
}
|
|
133
|
+
assert('where por FK retorna 6 books', by_fk.length === 6);
|
|
134
|
+
// -- Scan con operadores no-eq --
|
|
135
|
+
console.log('\n-- Scan con operadores --');
|
|
136
|
+
tracker.reset();
|
|
137
|
+
await Book.where({ pages: { $gt: 200 } });
|
|
138
|
+
assert('$gt usa ScanCommand (no es $eq)', tracker.last() === 'ScanCommand');
|
|
139
|
+
tracker.reset();
|
|
140
|
+
await Book.where({ title: { $include: 'Book' } });
|
|
141
|
+
assert('$include usa ScanCommand', tracker.last() === 'ScanCommand');
|
|
142
|
+
tracker.reset();
|
|
143
|
+
await Book.where({ author_id: { $in: [a1.id, a2.id] } });
|
|
144
|
+
assert('$in usa ScanCommand (no es $eq)', tracker.last() === 'ScanCommand');
|
|
145
|
+
// -- Query por PK + filtros adicionales --
|
|
146
|
+
console.log('\n-- Query PK + filtros extra --');
|
|
147
|
+
tracker.reset();
|
|
148
|
+
// No aplica: where con PK + otro campo. PK va a KeyCondition, el resto a Filter
|
|
149
|
+
// Pero _extractPK requiere que el filtro sea SOLO la PK para optimizar update/delete
|
|
150
|
+
// En where(), la detección busca cualquier campo con $eq que sea PK
|
|
151
|
+
const pk_plus = await Book.where({ id: by_fk[0].id });
|
|
152
|
+
assert('PK en filtro mixto usa Query', tracker.log.includes('QueryCommand'));
|
|
153
|
+
// -- Self-healing: GSI inexistente fallback a Scan --
|
|
154
|
+
console.log('\n-- Self-healing --');
|
|
155
|
+
// Forzar un GSI falso
|
|
156
|
+
const book_schema = Book[Symbol.for('dynamite:schema')] || Book[Object.getOwnPropertySymbols(Book).find(s => s.description === 'dynamite:schema')];
|
|
157
|
+
if (book_schema) {
|
|
158
|
+
book_schema.gsis.add('fake_field');
|
|
159
|
+
tracker.reset();
|
|
160
|
+
// Esto intentará Query con GSI fake_field_index, fallará, y caerá a Scan
|
|
161
|
+
try {
|
|
162
|
+
// Necesitamos un filtro por fake_field con $eq para que intente Query
|
|
163
|
+
// Pero fake_field no está en schema.columns, así que el where lanzará "Unknown column"
|
|
164
|
+
// El self-healing solo aplica cuando el campo existe en schema pero el GSI no existe en DynamoDB
|
|
165
|
+
// Simulamos agregando una columna fake temporalmente
|
|
166
|
+
book_schema.columns['fake_field'] = { name: 'fake_field', get: [], set: [], store: {} };
|
|
167
|
+
await Book.where({ fake_field: 'test' });
|
|
168
|
+
assert('self-healing: GSI inexistente cae a Scan sin error', true);
|
|
169
|
+
assert('self-healing: GSI removido del cache', !book_schema.gsis.has('fake_field'));
|
|
170
|
+
delete book_schema.columns['fake_field'];
|
|
171
|
+
}
|
|
172
|
+
catch (e) {
|
|
173
|
+
delete book_schema.columns['fake_field'];
|
|
174
|
+
book_schema.gsis.delete('fake_field');
|
|
175
|
+
assert('self-healing: error inesperado', false, e.message);
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
// -- Performance comparison (informativo) --
|
|
179
|
+
console.log('\n-- Performance (informativo) --');
|
|
180
|
+
const scan_start = Date.now();
|
|
181
|
+
for (let i = 0; i < 50; i++)
|
|
182
|
+
await Book.where({ pages: { $gt: 100 } });
|
|
183
|
+
const scan_time = Date.now() - scan_start;
|
|
184
|
+
const query_start = Date.now();
|
|
185
|
+
for (let i = 0; i < 50; i++)
|
|
186
|
+
await Book.where({ id: by_fk[0].id });
|
|
187
|
+
const query_time = Date.now() - query_start;
|
|
188
|
+
console.log(` 50x Scan: ${scan_time}ms (${(scan_time / 50).toFixed(1)}ms/query)`);
|
|
189
|
+
console.log(` 50x Query PK: ${query_time}ms (${(query_time / 50).toFixed(1)}ms/query)`);
|
|
190
|
+
assert('Query PK es mas rapido que Scan', query_time < scan_time, `Query:${query_time}ms vs Scan:${scan_time}ms`);
|
|
191
|
+
tracker.restore();
|
|
192
|
+
console.log(`\n Query vs Scan: ${passed} passed, ${failed} failed`);
|
|
193
|
+
return failed;
|
|
194
|
+
}
|
|
195
|
+
//# sourceMappingURL=query_scan.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"query_scan.js","sourceRoot":"","sources":["../../../src/test/query_scan.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export default function relations(): Promise<number>;
|
|
@@ -0,0 +1,246 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.default = relations;
|
|
13
|
+
const index_1 = require("../index");
|
|
14
|
+
// -- 4 niveles: Org -> Dept -> Employee -> Task --
|
|
15
|
+
let Org = class Org extends index_1.Table {
|
|
16
|
+
};
|
|
17
|
+
__decorate([
|
|
18
|
+
(0, index_1.PrimaryKey)(),
|
|
19
|
+
__metadata("design:type", Object)
|
|
20
|
+
], Org.prototype, "id", void 0);
|
|
21
|
+
__decorate([
|
|
22
|
+
(0, index_1.NotNull)(),
|
|
23
|
+
__metadata("design:type", String)
|
|
24
|
+
], Org.prototype, "name", void 0);
|
|
25
|
+
__decorate([
|
|
26
|
+
(0, index_1.HasMany)(() => Dept, 'org_id', 'id'),
|
|
27
|
+
__metadata("design:type", Object)
|
|
28
|
+
], Org.prototype, "departments", void 0);
|
|
29
|
+
Org = __decorate([
|
|
30
|
+
(0, index_1.Name)('test_rel_orgs')
|
|
31
|
+
], Org);
|
|
32
|
+
let Dept = class Dept extends index_1.Table {
|
|
33
|
+
};
|
|
34
|
+
__decorate([
|
|
35
|
+
(0, index_1.PrimaryKey)(),
|
|
36
|
+
__metadata("design:type", Object)
|
|
37
|
+
], Dept.prototype, "id", void 0);
|
|
38
|
+
__decorate([
|
|
39
|
+
(0, index_1.NotNull)(),
|
|
40
|
+
__metadata("design:type", String)
|
|
41
|
+
], Dept.prototype, "name", void 0);
|
|
42
|
+
__decorate([
|
|
43
|
+
(0, index_1.Default)(''),
|
|
44
|
+
__metadata("design:type", String)
|
|
45
|
+
], Dept.prototype, "org_id", void 0);
|
|
46
|
+
__decorate([
|
|
47
|
+
(0, index_1.BelongsTo)(() => Org, 'id', 'org_id'),
|
|
48
|
+
__metadata("design:type", Object)
|
|
49
|
+
], Dept.prototype, "org", void 0);
|
|
50
|
+
__decorate([
|
|
51
|
+
(0, index_1.HasMany)(() => Employee, 'dept_id', 'id'),
|
|
52
|
+
__metadata("design:type", Object)
|
|
53
|
+
], Dept.prototype, "employees", void 0);
|
|
54
|
+
Dept = __decorate([
|
|
55
|
+
(0, index_1.Name)('test_rel_depts')
|
|
56
|
+
], Dept);
|
|
57
|
+
let Employee = class Employee extends index_1.Table {
|
|
58
|
+
};
|
|
59
|
+
__decorate([
|
|
60
|
+
(0, index_1.PrimaryKey)(),
|
|
61
|
+
__metadata("design:type", Object)
|
|
62
|
+
], Employee.prototype, "id", void 0);
|
|
63
|
+
__decorate([
|
|
64
|
+
(0, index_1.NotNull)(),
|
|
65
|
+
__metadata("design:type", String)
|
|
66
|
+
], Employee.prototype, "name", void 0);
|
|
67
|
+
__decorate([
|
|
68
|
+
(0, index_1.Default)(''),
|
|
69
|
+
__metadata("design:type", String)
|
|
70
|
+
], Employee.prototype, "dept_id", void 0);
|
|
71
|
+
__decorate([
|
|
72
|
+
(0, index_1.BelongsTo)(() => Dept, 'id', 'dept_id'),
|
|
73
|
+
__metadata("design:type", Object)
|
|
74
|
+
], Employee.prototype, "department", void 0);
|
|
75
|
+
__decorate([
|
|
76
|
+
(0, index_1.HasMany)(() => EmpTask, 'employee_id', 'id'),
|
|
77
|
+
__metadata("design:type", Object)
|
|
78
|
+
], Employee.prototype, "tasks", void 0);
|
|
79
|
+
__decorate([
|
|
80
|
+
(0, index_1.ManyToMany)(() => Project, 'test_rel_emp_projects', 'employee_id', 'project_id'),
|
|
81
|
+
__metadata("design:type", Object)
|
|
82
|
+
], Employee.prototype, "projects", void 0);
|
|
83
|
+
Employee = __decorate([
|
|
84
|
+
(0, index_1.Name)('test_rel_employees')
|
|
85
|
+
], Employee);
|
|
86
|
+
let EmpTask = class EmpTask extends index_1.Table {
|
|
87
|
+
};
|
|
88
|
+
__decorate([
|
|
89
|
+
(0, index_1.PrimaryKey)(),
|
|
90
|
+
__metadata("design:type", Object)
|
|
91
|
+
], EmpTask.prototype, "id", void 0);
|
|
92
|
+
__decorate([
|
|
93
|
+
(0, index_1.NotNull)(),
|
|
94
|
+
__metadata("design:type", String)
|
|
95
|
+
], EmpTask.prototype, "title", void 0);
|
|
96
|
+
__decorate([
|
|
97
|
+
(0, index_1.Default)(''),
|
|
98
|
+
__metadata("design:type", String)
|
|
99
|
+
], EmpTask.prototype, "employee_id", void 0);
|
|
100
|
+
__decorate([
|
|
101
|
+
(0, index_1.BelongsTo)(() => Employee, 'id', 'employee_id'),
|
|
102
|
+
__metadata("design:type", Object)
|
|
103
|
+
], EmpTask.prototype, "employee", void 0);
|
|
104
|
+
EmpTask = __decorate([
|
|
105
|
+
(0, index_1.Name)('test_rel_tasks')
|
|
106
|
+
], EmpTask);
|
|
107
|
+
let Project = class Project extends index_1.Table {
|
|
108
|
+
};
|
|
109
|
+
__decorate([
|
|
110
|
+
(0, index_1.PrimaryKey)(),
|
|
111
|
+
__metadata("design:type", Object)
|
|
112
|
+
], Project.prototype, "id", void 0);
|
|
113
|
+
__decorate([
|
|
114
|
+
(0, index_1.NotNull)(),
|
|
115
|
+
__metadata("design:type", String)
|
|
116
|
+
], Project.prototype, "name", void 0);
|
|
117
|
+
__decorate([
|
|
118
|
+
(0, index_1.ManyToMany)(() => Employee, 'test_rel_emp_projects', 'project_id', 'employee_id'),
|
|
119
|
+
__metadata("design:type", Object)
|
|
120
|
+
], Project.prototype, "members", void 0);
|
|
121
|
+
Project = __decorate([
|
|
122
|
+
(0, index_1.Name)('test_rel_projects')
|
|
123
|
+
], Project);
|
|
124
|
+
let passed = 0;
|
|
125
|
+
let failed = 0;
|
|
126
|
+
function assert(label, condition, detail) {
|
|
127
|
+
if (condition) {
|
|
128
|
+
console.log(` OK ${label}`);
|
|
129
|
+
passed++;
|
|
130
|
+
}
|
|
131
|
+
else {
|
|
132
|
+
console.error(` FAIL ${label}${detail ? ` -- ${detail}` : ''}`);
|
|
133
|
+
failed++;
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
async function relations() {
|
|
137
|
+
console.log('\n=== RELATIONS ===\n');
|
|
138
|
+
const dynamite = new index_1.Dynamite({
|
|
139
|
+
tables: [Org, Dept, Employee, EmpTask, Project],
|
|
140
|
+
region: 'local',
|
|
141
|
+
endpoint: 'http://localhost:8000',
|
|
142
|
+
credentials: { accessKeyId: 'local', secretAccessKey: 'local' },
|
|
143
|
+
});
|
|
144
|
+
await dynamite.connect();
|
|
145
|
+
await dynamite.sync();
|
|
146
|
+
// -- Seed data --
|
|
147
|
+
const org = await Org.create({ name: 'Acme Corp' });
|
|
148
|
+
const eng = await Dept.create({ name: 'Engineering', org_id: org.id });
|
|
149
|
+
const sales = await Dept.create({ name: 'Sales', org_id: org.id });
|
|
150
|
+
const e1 = await Employee.create({ name: 'Alice', dept_id: eng.id });
|
|
151
|
+
const e2 = await Employee.create({ name: 'Bob', dept_id: eng.id });
|
|
152
|
+
const e3 = await Employee.create({ name: 'Charlie', dept_id: sales.id });
|
|
153
|
+
await EmpTask.create({ title: 'Build API', employee_id: e1.id });
|
|
154
|
+
await EmpTask.create({ title: 'Write tests', employee_id: e1.id });
|
|
155
|
+
await EmpTask.create({ title: 'Code review', employee_id: e2.id });
|
|
156
|
+
await EmpTask.create({ title: 'Close deal', employee_id: e3.id });
|
|
157
|
+
const p1 = await Project.create({ name: 'Project Alpha' });
|
|
158
|
+
const p2 = await Project.create({ name: 'Project Beta' });
|
|
159
|
+
// -- HasMany --
|
|
160
|
+
console.log('-- HasMany --');
|
|
161
|
+
const org_with_depts = await Org.where({ id: org.id }, { include: { departments: true } });
|
|
162
|
+
assert('Org -> departments', org_with_depts[0]?.departments?.length === 2);
|
|
163
|
+
const eng_with_emps = await Dept.where({ id: eng.id }, { include: { employees: true } });
|
|
164
|
+
assert('Dept -> employees', eng_with_emps[0]?.employees?.length === 2);
|
|
165
|
+
// -- BelongsTo --
|
|
166
|
+
console.log('\n-- BelongsTo --');
|
|
167
|
+
const dept_with_org = await Dept.where({ id: eng.id }, { include: { org: true } });
|
|
168
|
+
assert('Dept -> org', dept_with_org[0]?.org?.name === 'Acme Corp');
|
|
169
|
+
const emp_with_dept = await Employee.where({ id: e1.id }, { include: { department: true } });
|
|
170
|
+
assert('Employee -> department', emp_with_dept[0]?.department?.name === 'Engineering');
|
|
171
|
+
// -- HasMany con opciones (limit) --
|
|
172
|
+
console.log('\n-- HasMany con opciones --');
|
|
173
|
+
const e1_tasks_limited = await Employee.where({ id: e1.id }, {
|
|
174
|
+
include: { tasks: { limit: 1 } }
|
|
175
|
+
});
|
|
176
|
+
assert('HasMany con limit:1', e1_tasks_limited[0]?.tasks?.length === 1);
|
|
177
|
+
// -- Include recursivo 2 niveles: Org -> Dept -> Employee --
|
|
178
|
+
console.log('\n-- Include recursivo 2 niveles --');
|
|
179
|
+
const org_2lvl = await Org.where({ id: org.id }, {
|
|
180
|
+
include: {
|
|
181
|
+
departments: {
|
|
182
|
+
include: { employees: true }
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
});
|
|
186
|
+
const all_emps = org_2lvl[0]?.departments?.flatMap((d) => d.employees || []);
|
|
187
|
+
assert('Org -> Dept -> Employee (2 niveles)', all_emps?.length === 3);
|
|
188
|
+
// -- Include recursivo 3 niveles: Org -> Dept -> Employee -> Task --
|
|
189
|
+
console.log('\n-- Include recursivo 3 niveles --');
|
|
190
|
+
const org_3lvl = await Org.where({ id: org.id }, {
|
|
191
|
+
include: {
|
|
192
|
+
departments: {
|
|
193
|
+
include: {
|
|
194
|
+
employees: {
|
|
195
|
+
include: { tasks: true }
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
});
|
|
201
|
+
const eng_dept = org_3lvl[0]?.departments?.find((d) => d.name === 'Engineering');
|
|
202
|
+
const alice = eng_dept?.employees?.find((e) => e.name === 'Alice');
|
|
203
|
+
assert('3 niveles: Alice tiene 2 tasks', alice?.tasks?.length === 2);
|
|
204
|
+
const bob = eng_dept?.employees?.find((e) => e.name === 'Bob');
|
|
205
|
+
assert('3 niveles: Bob tiene 1 task', bob?.tasks?.length === 1);
|
|
206
|
+
const sales_dept = org_3lvl[0]?.departments?.find((d) => d.name === 'Sales');
|
|
207
|
+
const charlie = sales_dept?.employees?.find((e) => e.name === 'Charlie');
|
|
208
|
+
assert('3 niveles: Charlie tiene 1 task', charlie?.tasks?.length === 1);
|
|
209
|
+
// -- ManyToMany: attach --
|
|
210
|
+
console.log('\n-- ManyToMany --');
|
|
211
|
+
await e1.attach(Project, p1.id);
|
|
212
|
+
await e1.attach(Project, p2.id);
|
|
213
|
+
await e2.attach(Project, p1.id);
|
|
214
|
+
const e1_projects = await Employee.where({ id: e1.id }, { include: { projects: true } });
|
|
215
|
+
assert('attach: Alice tiene 2 projects', e1_projects[0]?.projects?.length === 2);
|
|
216
|
+
const p1_members = await Project.where({ id: p1.id }, { include: { members: true } });
|
|
217
|
+
assert('attach: Project Alpha tiene 2 members', p1_members[0]?.members?.length === 2);
|
|
218
|
+
// -- ManyToMany: detach --
|
|
219
|
+
await e1.detach(Project, p2.id);
|
|
220
|
+
const e1_after_detach = await Employee.where({ id: e1.id }, { include: { projects: true } });
|
|
221
|
+
assert('detach: Alice tiene 1 project', e1_after_detach[0]?.projects?.length === 1);
|
|
222
|
+
// -- ManyToMany: sync --
|
|
223
|
+
await e1.sync(Project, [p2.id]);
|
|
224
|
+
const e1_after_sync = await Employee.where({ id: e1.id }, { include: { projects: true } });
|
|
225
|
+
assert('sync: Alice solo tiene Project Beta', e1_after_sync[0]?.projects?.length === 1);
|
|
226
|
+
assert('sync: es Project Beta', e1_after_sync[0]?.projects?.[0]?.name === 'Project Beta');
|
|
227
|
+
// -- Include recursivo 3 niveles + ManyToMany --
|
|
228
|
+
console.log('\n-- Recursivo + ManyToMany --');
|
|
229
|
+
const org_full = await Org.where({ id: org.id }, {
|
|
230
|
+
include: {
|
|
231
|
+
departments: {
|
|
232
|
+
include: {
|
|
233
|
+
employees: {
|
|
234
|
+
include: { tasks: true, projects: true }
|
|
235
|
+
}
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
});
|
|
240
|
+
const eng_full = org_full[0]?.departments?.find((d) => d.name === 'Engineering');
|
|
241
|
+
const alice_full = eng_full?.employees?.find((e) => e.name === 'Alice');
|
|
242
|
+
assert('full tree: Alice tasks + projects', alice_full?.tasks?.length === 2 && alice_full?.projects?.length === 1);
|
|
243
|
+
console.log(`\n Relations: ${passed} passed, ${failed} failed`);
|
|
244
|
+
return failed;
|
|
245
|
+
}
|
|
246
|
+
//# sourceMappingURL=relations.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"relations.js","sourceRoot":"","sources":["../../../src/test/relations.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export default function transactions(): Promise<number>;
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.default = transactions;
|
|
13
|
+
const index_1 = require("../index");
|
|
14
|
+
let Account = class Account extends index_1.Table {
|
|
15
|
+
};
|
|
16
|
+
__decorate([
|
|
17
|
+
(0, index_1.PrimaryKey)(),
|
|
18
|
+
__metadata("design:type", Object)
|
|
19
|
+
], Account.prototype, "id", void 0);
|
|
20
|
+
__decorate([
|
|
21
|
+
(0, index_1.NotNull)(),
|
|
22
|
+
__metadata("design:type", String)
|
|
23
|
+
], Account.prototype, "name", void 0);
|
|
24
|
+
__decorate([
|
|
25
|
+
(0, index_1.Default)(() => 0),
|
|
26
|
+
__metadata("design:type", Object)
|
|
27
|
+
], Account.prototype, "balance", void 0);
|
|
28
|
+
__decorate([
|
|
29
|
+
(0, index_1.CreatedAt)(),
|
|
30
|
+
__metadata("design:type", Object)
|
|
31
|
+
], Account.prototype, "created_at", void 0);
|
|
32
|
+
Account = __decorate([
|
|
33
|
+
(0, index_1.Name)('test_tx_accounts')
|
|
34
|
+
], Account);
|
|
35
|
+
let TxLog = class TxLog extends index_1.Table {
|
|
36
|
+
};
|
|
37
|
+
__decorate([
|
|
38
|
+
(0, index_1.PrimaryKey)(),
|
|
39
|
+
__metadata("design:type", Object)
|
|
40
|
+
], TxLog.prototype, "id", void 0);
|
|
41
|
+
__decorate([
|
|
42
|
+
(0, index_1.Default)(''),
|
|
43
|
+
__metadata("design:type", String)
|
|
44
|
+
], TxLog.prototype, "account_id", void 0);
|
|
45
|
+
__decorate([
|
|
46
|
+
(0, index_1.Default)(''),
|
|
47
|
+
__metadata("design:type", String)
|
|
48
|
+
], TxLog.prototype, "action", void 0);
|
|
49
|
+
__decorate([
|
|
50
|
+
(0, index_1.Default)(() => 0),
|
|
51
|
+
__metadata("design:type", Object)
|
|
52
|
+
], TxLog.prototype, "amount", void 0);
|
|
53
|
+
TxLog = __decorate([
|
|
54
|
+
(0, index_1.Name)('test_tx_logs')
|
|
55
|
+
], TxLog);
|
|
56
|
+
let passed = 0;
|
|
57
|
+
let failed = 0;
|
|
58
|
+
function assert(label, condition, detail) {
|
|
59
|
+
if (condition) {
|
|
60
|
+
console.log(` OK ${label}`);
|
|
61
|
+
passed++;
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
console.error(` FAIL ${label}${detail ? ` -- ${detail}` : ''}`);
|
|
65
|
+
failed++;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
async function transactions() {
|
|
69
|
+
console.log('\n=== TRANSACTIONS ===\n');
|
|
70
|
+
const dynamite = new index_1.Dynamite({
|
|
71
|
+
tables: [Account, TxLog],
|
|
72
|
+
region: 'local',
|
|
73
|
+
endpoint: 'http://localhost:8000',
|
|
74
|
+
credentials: { accessKeyId: 'local', secretAccessKey: 'local' },
|
|
75
|
+
});
|
|
76
|
+
await dynamite.connect();
|
|
77
|
+
await dynamite.sync();
|
|
78
|
+
// -- Multi-create en tx --
|
|
79
|
+
console.log('-- Multi-create --');
|
|
80
|
+
let a1, a2;
|
|
81
|
+
await dynamite.tx(async (tx) => {
|
|
82
|
+
a1 = await Account.create({ name: 'Alice', balance: 1000 }, tx);
|
|
83
|
+
a2 = await Account.create({ name: 'Bob', balance: 500 }, tx);
|
|
84
|
+
});
|
|
85
|
+
assert('tx multi-create: ambos persistidos', a1.__isPersisted && a2.__isPersisted);
|
|
86
|
+
const alice = await Account.first({ id: a1.id });
|
|
87
|
+
const bob = await Account.first({ id: a2.id });
|
|
88
|
+
assert('tx multi-create: Alice en DB', alice?.name === 'Alice' && alice?.balance === 1000);
|
|
89
|
+
assert('tx multi-create: Bob en DB', bob?.name === 'Bob' && bob?.balance === 500);
|
|
90
|
+
// -- Create + increment en tx --
|
|
91
|
+
console.log('\n-- Create + increment --');
|
|
92
|
+
let log1;
|
|
93
|
+
await dynamite.tx(async (tx) => {
|
|
94
|
+
log1 = await TxLog.create({ account_id: a1.id, action: 'deposit', amount: 200 }, tx);
|
|
95
|
+
await Account.increment('balance', 200, { id: a1.id }, tx);
|
|
96
|
+
});
|
|
97
|
+
const alice_after = await Account.first({ id: a1.id });
|
|
98
|
+
assert('tx increment: balance +200', alice_after?.balance === 1200);
|
|
99
|
+
assert('tx increment: log creado', log1.__isPersisted === true);
|
|
100
|
+
const log_check = await TxLog.first({ id: log1.id });
|
|
101
|
+
assert('tx increment: log en DB', log_check?.action === 'deposit');
|
|
102
|
+
// -- Transferencia atomica (decrement + increment + log) --
|
|
103
|
+
console.log('\n-- Transferencia atomica --');
|
|
104
|
+
await dynamite.tx(async (tx) => {
|
|
105
|
+
await Account.decrement('balance', 300, { id: a1.id }, tx);
|
|
106
|
+
await Account.increment('balance', 300, { id: a2.id }, tx);
|
|
107
|
+
await TxLog.create({ account_id: a1.id, action: 'transfer_out', amount: 300 }, tx);
|
|
108
|
+
await TxLog.create({ account_id: a2.id, action: 'transfer_in', amount: 300 }, tx);
|
|
109
|
+
});
|
|
110
|
+
const alice_transfer = await Account.first({ id: a1.id });
|
|
111
|
+
const bob_transfer = await Account.first({ id: a2.id });
|
|
112
|
+
assert('transferencia: Alice 1200-300=900', alice_transfer?.balance === 900);
|
|
113
|
+
assert('transferencia: Bob 500+300=800', bob_transfer?.balance === 800);
|
|
114
|
+
// -- Tx fallida: nada se persiste --
|
|
115
|
+
console.log('\n-- Tx fallida --');
|
|
116
|
+
const alice_before_fail = alice_transfer.balance;
|
|
117
|
+
let failed_account;
|
|
118
|
+
try {
|
|
119
|
+
await dynamite.tx(async (tx) => {
|
|
120
|
+
failed_account = await Account.create({ name: 'Ghost' }, tx);
|
|
121
|
+
await Account.increment('balance', 99999, { id: a1.id }, tx);
|
|
122
|
+
throw new Error('Simulated failure');
|
|
123
|
+
});
|
|
124
|
+
}
|
|
125
|
+
catch { }
|
|
126
|
+
assert('tx fallida: instancia no persistida', failed_account.__isPersisted === false);
|
|
127
|
+
const alice_after_fail = await Account.first({ id: a1.id });
|
|
128
|
+
assert('tx fallida: balance intacto', alice_after_fail?.balance === alice_before_fail);
|
|
129
|
+
const ghost = await Account.where({ name: 'Ghost' });
|
|
130
|
+
assert('tx fallida: Ghost no existe', ghost.length === 0);
|
|
131
|
+
// -- Tx con multiples operaciones (>25, auto-chunk) --
|
|
132
|
+
console.log('\n-- Auto-chunk (30 creates) --');
|
|
133
|
+
const ids = [];
|
|
134
|
+
await dynamite.tx(async (tx) => {
|
|
135
|
+
for (let i = 0; i < 30; i++) {
|
|
136
|
+
const acc = await Account.create({ name: `Bulk_${i}`, balance: i }, tx);
|
|
137
|
+
ids.push(acc.id);
|
|
138
|
+
}
|
|
139
|
+
});
|
|
140
|
+
const bulk_check = await Account.where({ name: { $include: 'Bulk_' } });
|
|
141
|
+
assert('auto-chunk: 30 registros creados', bulk_check.length === 30);
|
|
142
|
+
console.log(`\n Transactions: ${passed} passed, ${failed} failed`);
|
|
143
|
+
return failed;
|
|
144
|
+
}
|
|
145
|
+
//# sourceMappingURL=transactions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transactions.js","sourceRoot":"","sources":["../../../src/test/transactions.ts"],"names":[],"mappings":"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"}
|