@studiosonrai/nestjs-migrations 1.1.0 → 1.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.
- package/dist/src/migration-core.d.ts +8 -0
- package/dist/src/migration-core.js +164 -59
- package/dist/src/migration-core.js.map +1 -1
- package/dist/src/migration-core.spec.d.ts +1 -0
- package/dist/src/migration-core.spec.js +409 -0
- package/dist/src/migration-core.spec.js.map +1 -0
- package/dist/src/migration.module.js.map +1 -1
- package/dist/src/migration.service.d.ts +2 -0
- package/dist/src/migration.service.js +2 -0
- package/dist/src/migration.service.js.map +1 -1
- package/dist/src/migration.service.spec.d.ts +1 -0
- package/dist/src/migration.service.spec.js +307 -0
- package/dist/src/migration.service.spec.js.map +1 -0
- package/dist/src/types.d.ts +6 -0
- package/dist/src/types.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +14 -5
- package/dist/bin/cli.d.ts +0 -2
- package/dist/bin/cli.js +0 -273
- package/dist/bin/cli.js.map +0 -1
|
@@ -0,0 +1,409 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
const typeorm_1 = require("typeorm");
|
|
37
|
+
const fs = __importStar(require("fs"));
|
|
38
|
+
const path = __importStar(require("path"));
|
|
39
|
+
const os = __importStar(require("os"));
|
|
40
|
+
const crypto = __importStar(require("crypto"));
|
|
41
|
+
const migration_core_1 = require("./migration-core");
|
|
42
|
+
const dotenv_1 = require("dotenv");
|
|
43
|
+
(0, dotenv_1.config)();
|
|
44
|
+
describe('MigrationCore Integration (Real DB)', () => {
|
|
45
|
+
let dataSource;
|
|
46
|
+
let migrationCore;
|
|
47
|
+
let tempDir;
|
|
48
|
+
const MIGRATION_TABLE = 'migrations_core_test';
|
|
49
|
+
beforeAll(async () => {
|
|
50
|
+
dataSource = new typeorm_1.DataSource({
|
|
51
|
+
type: 'mssql',
|
|
52
|
+
host: process.env.DB_HOST || 'localhost',
|
|
53
|
+
port: parseInt(process.env.DB_PORT || '1433', 10),
|
|
54
|
+
username: process.env.DB_USERNAME || 'sa',
|
|
55
|
+
password: process.env.DB_PASSWORD || 'p3FauyT9iv9ygHXE6txT',
|
|
56
|
+
database: process.env.DB_DATABASE || 'nest-migrations-ci',
|
|
57
|
+
extra: {
|
|
58
|
+
trustServerCertificate: true,
|
|
59
|
+
},
|
|
60
|
+
synchronize: false,
|
|
61
|
+
logging: false,
|
|
62
|
+
});
|
|
63
|
+
await dataSource.initialize();
|
|
64
|
+
tempDir = fs.mkdtempSync(path.join(os.tmpdir(), 'migrations-test-'));
|
|
65
|
+
migrationCore = new migration_core_1.MigrationCore(dataSource, {
|
|
66
|
+
migrationsDir: tempDir,
|
|
67
|
+
tableName: 'migrations_core_test',
|
|
68
|
+
schema: 'dbo',
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
afterAll(async () => {
|
|
72
|
+
if (dataSource?.isInitialized) {
|
|
73
|
+
await dataSource.query(`IF OBJECT_ID('dbo.${MIGRATION_TABLE}', 'U') IS NOT NULL DROP TABLE dbo.${MIGRATION_TABLE}`);
|
|
74
|
+
await dataSource.destroy();
|
|
75
|
+
}
|
|
76
|
+
if (tempDir && fs.existsSync(tempDir)) {
|
|
77
|
+
fs.rmSync(tempDir, { recursive: true, force: true });
|
|
78
|
+
}
|
|
79
|
+
});
|
|
80
|
+
beforeEach(async () => {
|
|
81
|
+
if (!dataSource?.isInitialized)
|
|
82
|
+
return;
|
|
83
|
+
await dataSource.query(`IF OBJECT_ID('dbo.${MIGRATION_TABLE}', 'U') IS NOT NULL DELETE FROM dbo.${MIGRATION_TABLE}`);
|
|
84
|
+
const objectsToDrop = [
|
|
85
|
+
{ name: 'dbo.SingleTest', type: 'U' },
|
|
86
|
+
{ name: 'dbo.TestTable', type: 'U' },
|
|
87
|
+
{ name: 'dbo.TestTable2', type: 'U' },
|
|
88
|
+
{ name: 'dbo.TestView', type: 'V' },
|
|
89
|
+
{ name: 'dbo.OrderLog', type: 'U' },
|
|
90
|
+
{ name: 'dbo.ManualTable', type: 'U' },
|
|
91
|
+
{ name: 'dbo.ManualView', type: 'V' },
|
|
92
|
+
{ name: 'dbo.ServiceTest', type: 'U' },
|
|
93
|
+
{ name: 'dbo.NoAutoTable', type: 'U' },
|
|
94
|
+
{ name: 'dbo.StatusTable', type: 'U' }
|
|
95
|
+
];
|
|
96
|
+
for (const obj of objectsToDrop) {
|
|
97
|
+
await dataSource.query(`IF OBJECT_ID('${obj.name}', '${obj.type}') IS NOT NULL ${obj.type === 'V' ? 'DROP VIEW' : 'DROP TABLE'} ${obj.name}`);
|
|
98
|
+
}
|
|
99
|
+
if (fs.existsSync(tempDir)) {
|
|
100
|
+
const files = fs.readdirSync(tempDir);
|
|
101
|
+
for (const file of files) {
|
|
102
|
+
fs.unlinkSync(path.join(tempDir, file));
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
});
|
|
106
|
+
function createMigrationFile(name, content) {
|
|
107
|
+
fs.writeFileSync(path.join(tempDir, name), content);
|
|
108
|
+
}
|
|
109
|
+
describe('Utility Methods', () => {
|
|
110
|
+
it('should calculate SHA256 hash of a file', () => {
|
|
111
|
+
const fileName = 'hash-test.sql';
|
|
112
|
+
const content = 'SELECT 1;';
|
|
113
|
+
createMigrationFile(fileName, content);
|
|
114
|
+
const expectedHash = crypto.createHash('sha256').update(content, 'utf8').digest('hex');
|
|
115
|
+
const actualHash = migrationCore.calculateFileHash(path.join(tempDir, fileName));
|
|
116
|
+
expect(actualHash).toBe(expectedHash);
|
|
117
|
+
});
|
|
118
|
+
it('should list and sort migration files correctly', async () => {
|
|
119
|
+
createMigrationFile('V2__Beta.sql', 'SELECT 1;');
|
|
120
|
+
createMigrationFile('V1__Alpha.sql', 'SELECT 1;');
|
|
121
|
+
createMigrationFile('R__Zeta.sql', 'SELECT 1;');
|
|
122
|
+
const files = await migrationCore.getMigrationFiles();
|
|
123
|
+
expect(files).toEqual(['R__Zeta.sql', 'V1__Alpha.sql', 'V2__Beta.sql']);
|
|
124
|
+
});
|
|
125
|
+
});
|
|
126
|
+
describe('Status and Information', () => {
|
|
127
|
+
beforeEach(async () => {
|
|
128
|
+
createMigrationFile('V1__Applied.sql', 'SELECT 1;');
|
|
129
|
+
createMigrationFile('V2__Pending.sql', 'SELECT 1;');
|
|
130
|
+
createMigrationFile('R__Always.sql', 'SELECT 1;');
|
|
131
|
+
await migrationCore.runMigrations({ verbose: false });
|
|
132
|
+
});
|
|
133
|
+
it('should get applied migration names', async () => {
|
|
134
|
+
const names = await migrationCore.getAppliedMigrationNames();
|
|
135
|
+
expect(names).toContain('V1__Applied.sql');
|
|
136
|
+
expect(names).toContain('V2__Pending.sql');
|
|
137
|
+
expect(names).toContain('R__Always.sql');
|
|
138
|
+
});
|
|
139
|
+
it('should get applied migration records with hashes', async () => {
|
|
140
|
+
const applied = await migrationCore.getAppliedMigrations();
|
|
141
|
+
const v1 = applied.find(m => m.name === 'V1__Applied.sql');
|
|
142
|
+
expect(v1).toBeDefined();
|
|
143
|
+
expect(v1?.content_hash).toBe(migrationCore.calculateFileHash(path.join(tempDir, 'V1__Applied.sql')));
|
|
144
|
+
});
|
|
145
|
+
it('should get pending migrations', async () => {
|
|
146
|
+
createMigrationFile('V3__New.sql', 'SELECT 1;');
|
|
147
|
+
const pending = await migrationCore.getPendingMigrations();
|
|
148
|
+
expect(pending).toContain('V3__New.sql');
|
|
149
|
+
expect(pending).not.toContain('V1__Applied.sql');
|
|
150
|
+
});
|
|
151
|
+
it('should not include rerunnable scripts in getPendingMigrations', async () => {
|
|
152
|
+
const pending = await migrationCore.getPendingMigrations();
|
|
153
|
+
expect(pending).not.toContain('R__Always.sql');
|
|
154
|
+
createMigrationFile('R__NewScript.sql', 'SELECT 1;');
|
|
155
|
+
const pendingAfter = await migrationCore.getPendingMigrations();
|
|
156
|
+
expect(pendingAfter).not.toContain('R__NewScript.sql');
|
|
157
|
+
});
|
|
158
|
+
it('should return complete status report', async () => {
|
|
159
|
+
createMigrationFile('V3__New.sql', 'SELECT 1;');
|
|
160
|
+
const status = await migrationCore.getStatus();
|
|
161
|
+
expect(status.total).toBe(4);
|
|
162
|
+
expect(status.applied).toBe(2);
|
|
163
|
+
expect(status.pending).toBe(1);
|
|
164
|
+
expect(status.rerunnable).toBe(1);
|
|
165
|
+
expect(status.hashMismatches).toHaveLength(0);
|
|
166
|
+
});
|
|
167
|
+
it('should report hash mismatches for modified versioned files in getStatus', async () => {
|
|
168
|
+
createMigrationFile('V1__Applied.sql', 'SELECT 999; -- tampered');
|
|
169
|
+
const status = await migrationCore.getStatus();
|
|
170
|
+
expect(status.hashMismatches).toHaveLength(1);
|
|
171
|
+
expect(status.hashMismatches[0].name).toBe('V1__Applied.sql');
|
|
172
|
+
});
|
|
173
|
+
});
|
|
174
|
+
describe('Execution Flow', () => {
|
|
175
|
+
it('should independently run a single migration file', async () => {
|
|
176
|
+
if (!dataSource?.isInitialized)
|
|
177
|
+
return;
|
|
178
|
+
const fileName = 'V1__Single.sql';
|
|
179
|
+
createMigrationFile(fileName, 'CREATE TABLE SingleTest (Id INT);');
|
|
180
|
+
const queryRunner = dataSource.createQueryRunner();
|
|
181
|
+
await queryRunner.connect();
|
|
182
|
+
try {
|
|
183
|
+
await migrationCore.runSingleMigration(fileName, queryRunner);
|
|
184
|
+
const tableExists = await dataSource.query("SELECT 1 FROM sysobjects WHERE name='SingleTest' AND xtype='U'");
|
|
185
|
+
expect(tableExists.length).toBe(1);
|
|
186
|
+
}
|
|
187
|
+
finally {
|
|
188
|
+
await queryRunner.release();
|
|
189
|
+
await dataSource.query("IF OBJECT_ID('SingleTest', 'U') IS NOT NULL DROP TABLE SingleTest");
|
|
190
|
+
}
|
|
191
|
+
const records = await migrationCore.getAppliedMigrationNames();
|
|
192
|
+
expect(records).not.toContain(fileName);
|
|
193
|
+
});
|
|
194
|
+
it('should run versioned migrations and rerunnable scripts in correct order', async () => {
|
|
195
|
+
if (!dataSource?.isInitialized)
|
|
196
|
+
return;
|
|
197
|
+
createMigrationFile('V1__Initial.sql', 'CREATE TABLE TestTable (Id INT PRIMARY KEY);');
|
|
198
|
+
createMigrationFile('V2__AddColumn.sql', 'ALTER TABLE TestTable ADD Name NVARCHAR(50);');
|
|
199
|
+
createMigrationFile('R__CreateView.sql', "IF OBJECT_ID('TestView', 'V') IS NOT NULL DROP VIEW TestView;\nGO\nCREATE VIEW TestView AS SELECT * FROM TestTable;");
|
|
200
|
+
try {
|
|
201
|
+
const result = await migrationCore.runMigrations({ verbose: false });
|
|
202
|
+
expect(result.success).toBe(true);
|
|
203
|
+
expect(result.appliedMigrations).toBe(2);
|
|
204
|
+
expect(result.rerunnableMigrations).toBe(1);
|
|
205
|
+
const tableExists = await dataSource.query("SELECT 1 FROM sysobjects WHERE name='TestTable' AND xtype='U'");
|
|
206
|
+
const viewExists = await dataSource.query("SELECT 1 FROM sysobjects WHERE name='TestView' AND xtype='V'");
|
|
207
|
+
expect(tableExists.length).toBe(1);
|
|
208
|
+
expect(viewExists.length).toBe(1);
|
|
209
|
+
const applied = await migrationCore.getAppliedMigrationNames();
|
|
210
|
+
expect(applied).toContain('V1__Initial.sql');
|
|
211
|
+
expect(applied).toContain('V2__AddColumn.sql');
|
|
212
|
+
expect(applied).toContain('R__CreateView.sql');
|
|
213
|
+
}
|
|
214
|
+
finally {
|
|
215
|
+
await dataSource.query("IF OBJECT_ID('TestView', 'V') IS NOT NULL DROP VIEW TestView");
|
|
216
|
+
await dataSource.query("IF OBJECT_ID('TestTable', 'U') IS NOT NULL DROP TABLE TestTable");
|
|
217
|
+
}
|
|
218
|
+
});
|
|
219
|
+
it('should update existing rerunnable records (Upsert)', async () => {
|
|
220
|
+
if (!dataSource?.isInitialized)
|
|
221
|
+
return;
|
|
222
|
+
createMigrationFile('R__Log.sql', 'PRINT \'Run 1\';');
|
|
223
|
+
await migrationCore.runMigrations({ verbose: false });
|
|
224
|
+
createMigrationFile('R__Log.sql', 'PRINT \'Run 2\';');
|
|
225
|
+
const result = await migrationCore.runMigrations({ verbose: false });
|
|
226
|
+
expect(result.rerunnableMigrations).toBe(1);
|
|
227
|
+
const records = await dataSource.query(`SELECT COUNT(*) as count FROM ${MIGRATION_TABLE} WHERE name = 'R__Log.sql'`);
|
|
228
|
+
expect(records[0].count).toBe(1);
|
|
229
|
+
});
|
|
230
|
+
it('should respect lexical order for rerunnable scripts', async () => {
|
|
231
|
+
if (!dataSource?.isInitialized)
|
|
232
|
+
return;
|
|
233
|
+
await dataSource.query('CREATE TABLE OrderLog (Name NVARCHAR(50), RunOrder INT IDENTITY(1,1));');
|
|
234
|
+
createMigrationFile('R__B.sql', 'INSERT INTO OrderLog (Name) VALUES (\'B\');');
|
|
235
|
+
createMigrationFile('R__A.sql', 'INSERT INTO OrderLog (Name) VALUES (\'A\');');
|
|
236
|
+
await migrationCore.runMigrations({ verbose: false });
|
|
237
|
+
const logs = await dataSource.query('SELECT Name FROM OrderLog ORDER BY RunOrder');
|
|
238
|
+
expect(logs[0].Name).toBe('A');
|
|
239
|
+
expect(logs[1].Name).toBe('B');
|
|
240
|
+
});
|
|
241
|
+
it('should throw HashMismatchError for modified versioned migrations', async () => {
|
|
242
|
+
if (!dataSource?.isInitialized)
|
|
243
|
+
return;
|
|
244
|
+
createMigrationFile('V1__Hash.sql', 'SELECT 1;');
|
|
245
|
+
await migrationCore.runMigrations({ verbose: false });
|
|
246
|
+
createMigrationFile('V1__Hash.sql', 'SELECT 2;');
|
|
247
|
+
await expect(migrationCore.runMigrations({ verbose: false })).rejects.toThrow(/modified after being applied/);
|
|
248
|
+
});
|
|
249
|
+
it('should skip unchanged rerunnable scripts on second run', async () => {
|
|
250
|
+
if (!dataSource?.isInitialized)
|
|
251
|
+
return;
|
|
252
|
+
createMigrationFile('R__Stable.sql', 'SELECT 1;');
|
|
253
|
+
await migrationCore.runMigrations({ verbose: false });
|
|
254
|
+
const result = await migrationCore.runMigrations({ verbose: false });
|
|
255
|
+
expect(result.rerunnableMigrations).toBe(0);
|
|
256
|
+
});
|
|
257
|
+
it('should not throw for a modified rerunnable script', async () => {
|
|
258
|
+
if (!dataSource?.isInitialized)
|
|
259
|
+
return;
|
|
260
|
+
createMigrationFile('R__Evolving.sql', 'SELECT 1;');
|
|
261
|
+
await migrationCore.runMigrations({ verbose: false });
|
|
262
|
+
createMigrationFile('R__Evolving.sql', 'SELECT 2;');
|
|
263
|
+
await expect(migrationCore.runMigrations({ verbose: false })).resolves.toMatchObject({
|
|
264
|
+
success: true,
|
|
265
|
+
rerunnableMigrations: 1,
|
|
266
|
+
});
|
|
267
|
+
});
|
|
268
|
+
it('should only list changed rerunnables in dry run', async () => {
|
|
269
|
+
if (!dataSource?.isInitialized)
|
|
270
|
+
return;
|
|
271
|
+
createMigrationFile('V1__Base.sql', 'SELECT 1;');
|
|
272
|
+
createMigrationFile('R__Unchanged.sql', 'SELECT 1;');
|
|
273
|
+
await migrationCore.runMigrations({ verbose: false });
|
|
274
|
+
createMigrationFile('V2__New.sql', 'SELECT 1;');
|
|
275
|
+
createMigrationFile('R__Changed.sql', 'SELECT 2;');
|
|
276
|
+
const consoleSpy = jest.spyOn(console, 'log').mockImplementation();
|
|
277
|
+
try {
|
|
278
|
+
const result = await migrationCore.runMigrations({ dryRun: true, verbose: false });
|
|
279
|
+
expect(result.success).toBe(true);
|
|
280
|
+
const output = consoleSpy.mock.calls.map((c) => c[0]).join('\n');
|
|
281
|
+
expect(output).toContain('V2__New.sql');
|
|
282
|
+
expect(output).toContain('R__Changed.sql');
|
|
283
|
+
expect(output).not.toContain('R__Unchanged.sql');
|
|
284
|
+
}
|
|
285
|
+
finally {
|
|
286
|
+
consoleSpy.mockRestore();
|
|
287
|
+
}
|
|
288
|
+
});
|
|
289
|
+
});
|
|
290
|
+
describe('Schema Support', () => {
|
|
291
|
+
let testSchema;
|
|
292
|
+
let schemaCore;
|
|
293
|
+
let schemaTestDir;
|
|
294
|
+
beforeEach(async () => {
|
|
295
|
+
testSchema = 'test_schema_' + Date.now();
|
|
296
|
+
schemaTestDir = fs.mkdtempSync(path.join(os.tmpdir(), 'schema-test-'));
|
|
297
|
+
try {
|
|
298
|
+
await dataSource.query(`IF NOT EXISTS (SELECT * FROM sys.schemas WHERE name = '${testSchema}') EXEC('CREATE SCHEMA ${testSchema}');`);
|
|
299
|
+
}
|
|
300
|
+
catch (e) {
|
|
301
|
+
}
|
|
302
|
+
});
|
|
303
|
+
afterEach(async () => {
|
|
304
|
+
if (dataSource?.isInitialized && testSchema) {
|
|
305
|
+
try {
|
|
306
|
+
await dataSource.query(`IF OBJECT_ID('${testSchema}.migrations_schema_test', 'U') IS NOT NULL DROP TABLE ${testSchema}.migrations_schema_test`);
|
|
307
|
+
await dataSource.query(`DROP SCHEMA ${testSchema}`);
|
|
308
|
+
}
|
|
309
|
+
catch (e) {
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
if (schemaTestDir && fs.existsSync(schemaTestDir)) {
|
|
313
|
+
fs.rmSync(schemaTestDir, { recursive: true, force: true });
|
|
314
|
+
}
|
|
315
|
+
});
|
|
316
|
+
it('should default to dbo schema when schema is not provided', async () => {
|
|
317
|
+
if (!dataSource?.isInitialized)
|
|
318
|
+
return;
|
|
319
|
+
const core = new migration_core_1.MigrationCore(dataSource, {
|
|
320
|
+
migrationsDir: tempDir,
|
|
321
|
+
tableName: 'migrations_core_test',
|
|
322
|
+
});
|
|
323
|
+
fs.writeFileSync(path.join(tempDir, 'V1__Test.sql'), 'SELECT 1;');
|
|
324
|
+
const tableName = core.tableName;
|
|
325
|
+
const schema = core.schema;
|
|
326
|
+
expect(schema).toBe('dbo');
|
|
327
|
+
});
|
|
328
|
+
it('should use custom schema when provided', async () => {
|
|
329
|
+
if (!dataSource?.isInitialized)
|
|
330
|
+
return;
|
|
331
|
+
schemaCore = new migration_core_1.MigrationCore(dataSource, {
|
|
332
|
+
migrationsDir: schemaTestDir,
|
|
333
|
+
tableName: 'migrations_schema_test',
|
|
334
|
+
schema: testSchema,
|
|
335
|
+
});
|
|
336
|
+
const schema = schemaCore.schema;
|
|
337
|
+
expect(schema).toBe(testSchema);
|
|
338
|
+
});
|
|
339
|
+
it('should reject invalid schema names', () => {
|
|
340
|
+
expect(() => {
|
|
341
|
+
new migration_core_1.MigrationCore(dataSource, {
|
|
342
|
+
migrationsDir: tempDir,
|
|
343
|
+
tableName: 'migrations_core_test',
|
|
344
|
+
schema: 'invalid-schema-name',
|
|
345
|
+
});
|
|
346
|
+
}).toThrow(/Invalid schema/);
|
|
347
|
+
});
|
|
348
|
+
it('should create migration table in specified schema', async () => {
|
|
349
|
+
if (!dataSource?.isInitialized)
|
|
350
|
+
return;
|
|
351
|
+
schemaCore = new migration_core_1.MigrationCore(dataSource, {
|
|
352
|
+
migrationsDir: schemaTestDir,
|
|
353
|
+
tableName: 'migrations_schema_test',
|
|
354
|
+
schema: testSchema,
|
|
355
|
+
});
|
|
356
|
+
await schemaCore.ensureMigrationsTable();
|
|
357
|
+
const tableExists = await dataSource.query(`
|
|
358
|
+
SELECT COUNT(*) as count FROM sys.tables
|
|
359
|
+
WHERE name='migrations_schema_test' AND schema_id = SCHEMA_ID('${testSchema}')
|
|
360
|
+
`);
|
|
361
|
+
expect(tableExists[0].count).toBe(1);
|
|
362
|
+
});
|
|
363
|
+
it('should run migrations in custom schema', async () => {
|
|
364
|
+
if (!dataSource?.isInitialized)
|
|
365
|
+
return;
|
|
366
|
+
schemaCore = new migration_core_1.MigrationCore(dataSource, {
|
|
367
|
+
migrationsDir: schemaTestDir,
|
|
368
|
+
tableName: 'migrations_schema_test',
|
|
369
|
+
schema: testSchema,
|
|
370
|
+
});
|
|
371
|
+
fs.writeFileSync(path.join(schemaTestDir, 'V1__Schema.sql'), `CREATE TABLE ${testSchema}.SchemaTest (Id INT PRIMARY KEY);`);
|
|
372
|
+
const result = await schemaCore.runMigrations({ verbose: false });
|
|
373
|
+
expect(result.success).toBe(true);
|
|
374
|
+
expect(result.appliedMigrations).toBe(1);
|
|
375
|
+
const trackingTable = await dataSource.query(`
|
|
376
|
+
SELECT COUNT(*) as count FROM sys.tables
|
|
377
|
+
WHERE name='migrations_schema_test' AND schema_id = SCHEMA_ID('${testSchema}')
|
|
378
|
+
`);
|
|
379
|
+
expect(trackingTable[0].count).toBe(1);
|
|
380
|
+
const applied = await dataSource.query(`SELECT COUNT(*) as count FROM ${testSchema}.migrations_schema_test`);
|
|
381
|
+
expect(applied[0].count).toBe(1);
|
|
382
|
+
});
|
|
383
|
+
it('should support alphanumeric and underscore characters in schema name', () => {
|
|
384
|
+
const validSchemas = ['schema_test', 'test123', 'Test_Schema_2024'];
|
|
385
|
+
validSchemas.forEach((schema) => {
|
|
386
|
+
expect(() => {
|
|
387
|
+
new migration_core_1.MigrationCore(dataSource, {
|
|
388
|
+
migrationsDir: tempDir,
|
|
389
|
+
tableName: 'test',
|
|
390
|
+
schema,
|
|
391
|
+
});
|
|
392
|
+
}).not.toThrow();
|
|
393
|
+
});
|
|
394
|
+
});
|
|
395
|
+
it('should reject special characters in schema name', () => {
|
|
396
|
+
const invalidSchemas = ['schema-test', 'schema.test', 'schema@test', 'schema table'];
|
|
397
|
+
invalidSchemas.forEach((schema) => {
|
|
398
|
+
expect(() => {
|
|
399
|
+
new migration_core_1.MigrationCore(dataSource, {
|
|
400
|
+
migrationsDir: tempDir,
|
|
401
|
+
tableName: 'test',
|
|
402
|
+
schema,
|
|
403
|
+
});
|
|
404
|
+
}).toThrow(/Invalid schema/);
|
|
405
|
+
});
|
|
406
|
+
});
|
|
407
|
+
});
|
|
408
|
+
});
|
|
409
|
+
//# sourceMappingURL=migration-core.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migration-core.spec.js","sourceRoot":"","sources":["../../src/migration-core.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"migration.module.js","sourceRoot":"","sources":["../../src/migration.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAiE;AACjE,2DAAuD;AACvD,mCAKiB;
|
|
1
|
+
{"version":3,"file":"migration.module.js","sourceRoot":"","sources":["../../src/migration.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAiE;AACjE,2DAAuD;AACvD,mCAKiB;AA4BV,IAAM,eAAe,uBAArB,MAAM,eAAe;IAI1B,MAAM,CAAC,OAAO,CAAC,OAA+B;QAC5C,OAAO;YACL,MAAM,EAAE,iBAAe;YACvB,SAAS,EAAE;gBACT;oBACE,OAAO,EAAE,gCAAwB;oBACjC,QAAQ,EAAE,OAAO;iBAClB;gBACD,oCAAgB;aACjB;YACD,OAAO,EAAE,CAAC,oCAAgB,CAAC;SAC5B,CAAC;IACJ,CAAC;IAMD,MAAM,CAAC,YAAY,CAAC,OAAoC;QACtD,OAAO;YACL,MAAM,EAAE,iBAAe;YACvB,OAAO,EAAE,OAAO,CAAC,OAAO,IAAI,EAAE;YAC9B,SAAS,EAAE;gBACT,GAAG,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC;gBACrC,oCAAgB;aACjB;YACD,OAAO,EAAE,CAAC,oCAAgB,CAAC;SAC5B,CAAC;IACJ,CAAC;IAEO,MAAM,CAAC,oBAAoB,CACjC,OAAoC;QAEpC,IAAI,OAAO,CAAC,UAAU,EAAE,CAAC;YACvB,OAAO;gBACL;oBACE,OAAO,EAAE,gCAAwB;oBACjC,UAAU,EAAE,OAAO,CAAC,UAAU;oBAC9B,MAAM,EAAE,OAAO,CAAC,MAAM,IAAI,EAAE;iBAC7B;aACF,CAAC;QACJ,CAAC;QAED,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;YACrB,OAAO;gBACL;oBACE,OAAO,EAAE,OAAO,CAAC,QAAQ;oBACzB,QAAQ,EAAE,OAAO,CAAC,QAAQ;iBAC3B;gBACD;oBACE,OAAO,EAAE,gCAAwB;oBACjC,UAAU,EAAE,KAAK,EAAE,cAA6C,EAAE,EAAE,CAClE,cAAc,CAAC,sBAAsB,EAAE;oBACzC,MAAM,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC;iBAC3B;aACF,CAAC;QACJ,CAAC;QAED,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;YACxB,OAAO;gBACL;oBACE,OAAO,EAAE,gCAAwB;oBACjC,UAAU,EAAE,KAAK,EAAE,cAA6C,EAAE,EAAE,CAClE,cAAc,CAAC,sBAAsB,EAAE;oBACzC,MAAM,EAAE,CAAC,OAAO,CAAC,WAAW,CAAC;iBAC9B;aACF,CAAC;QACJ,CAAC;QAED,OAAO,EAAE,CAAC;IACZ,CAAC;CACF,CAAA;AA3EY,0CAAe;0BAAf,eAAe;IAD3B,IAAA,eAAM,EAAC,EAAE,CAAC;GACE,eAAe,CA2E3B"}
|
|
@@ -26,6 +26,8 @@ let MigrationService = class MigrationService {
|
|
|
26
26
|
this.options = options;
|
|
27
27
|
this.migrationCore = new migration_core_1.MigrationCore(dataSource, {
|
|
28
28
|
migrationsDir: options.migrationsDir,
|
|
29
|
+
tableName: options.tableName,
|
|
30
|
+
schema: options.schema ?? 'dbo',
|
|
29
31
|
});
|
|
30
32
|
this.autoRun = options.autoRun ?? false;
|
|
31
33
|
this.verbose = options.verbose ?? true;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"migration.service.js","sourceRoot":"","sources":["../../src/migration.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAAkE;AAClE,qCAAqC;AACrC,qDAAiD;AACjD,mCAKiB;AAOV,IAAM,gBAAgB,GAAtB,MAAM,gBAAgB;IAOR;IANF,aAAa,CAAgB;IAC7B,OAAO,CAAU;IACjB,OAAO,CAAU;IAElC,YAEmB,OAA+B,EAChD,UAAsB;QADL,YAAO,GAAP,OAAO,CAAwB;QAGhD,IAAI,CAAC,aAAa,GAAG,IAAI,8BAAa,CAAC,UAAU,EAAE;YACjD,aAAa,EAAE,OAAO,CAAC,aAAa;
|
|
1
|
+
{"version":3,"file":"migration.service.js","sourceRoot":"","sources":["../../src/migration.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAAkE;AAClE,qCAAqC;AACrC,qDAAiD;AACjD,mCAKiB;AAOV,IAAM,gBAAgB,GAAtB,MAAM,gBAAgB;IAOR;IANF,aAAa,CAAgB;IAC7B,OAAO,CAAU;IACjB,OAAO,CAAU;IAElC,YAEmB,OAA+B,EAChD,UAAsB;QADL,YAAO,GAAP,OAAO,CAAwB;QAGhD,IAAI,CAAC,aAAa,GAAG,IAAI,8BAAa,CAAC,UAAU,EAAE;YACjD,aAAa,EAAE,OAAO,CAAC,aAAa;YACpC,SAAS,EAAE,OAAO,CAAC,SAAS;YAC5B,MAAM,EAAE,OAAO,CAAC,MAAM,IAAI,KAAK;SAChC,CAAC,CAAC;QACH,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,OAAO,IAAI,KAAK,CAAC;QACxC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,OAAO,IAAI,IAAI,CAAC;IACzC,CAAC;IAED,KAAK,CAAC,YAAY;QAChB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAClB,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;gBACjB,OAAO,CAAC,GAAG,CAAC,8BAA8B,CAAC,CAAC;YAC9C,CAAC;YACD,OAAO;QACT,CAAC;QAED,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,OAAO,CAAC,GAAG,CAAC,4BAA4B,CAAC,CAAC;QAC5C,CAAC;QAED,MAAM,IAAI,CAAC,aAAa,EAAE,CAAC;IAC7B,CAAC;IAKD,KAAK,CAAC,aAAa,CAAC,OAA6B;QAC/C,OAAO,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC;YACtC,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,GAAG,OAAO;SACX,CAAC,CAAC;IACL,CAAC;IAKD,KAAK,CAAC,oBAAoB;QACxB,OAAO,IAAI,CAAC,aAAa,CAAC,oBAAoB,EAAE,CAAC;IACnD,CAAC;IAKD,KAAK,CAAC,SAAS;QAQb,OAAO,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE,CAAC;IACxC,CAAC;CACF,CAAA;AAhEY,4CAAgB;2BAAhB,gBAAgB;IAD5B,IAAA,mBAAU,GAAE;IAOR,WAAA,IAAA,eAAM,EAAC,gCAAwB,CAAC,CAAA;6CAErB,oBAAU;GARb,gBAAgB,CAgE5B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|