mirror of
https://github.com/DeNNiiInc/dbgate.git
synced 2026-04-19 21:16:00 +00:00
45 lines
1.4 KiB
JavaScript
45 lines
1.4 KiB
JavaScript
const stableStringify = require('json-stable-stringify');
|
|
const _ = require('lodash');
|
|
const fp = require('lodash/fp');
|
|
const uuidv1 = require('uuid/v1');
|
|
const { testWrapper } = require('../tools');
|
|
const engines = require('../engines');
|
|
const { getAlterDatabaseScript, extendDatabaseInfo, generateDbPairingId } = require('dbgate-tools');
|
|
|
|
async function testDatabaseDiff(conn, driver, mangle) {
|
|
await driver.query(conn, `create table t0 (id int not null primary key)`);
|
|
|
|
await driver.query(
|
|
conn,
|
|
`create table t1 (
|
|
col_pk int not null primary key,
|
|
col_fk int null references t0(id)
|
|
)`
|
|
);
|
|
|
|
const structure1 = generateDbPairingId(extendDatabaseInfo(await driver.analyseFull(conn)));
|
|
let structure2 = _.cloneDeep(structure1);
|
|
mangle(structure2);
|
|
structure2 = extendDatabaseInfo(structure2);
|
|
|
|
const sql = getAlterDatabaseScript(structure1, structure2, {}, structure2, driver);
|
|
console.log('RUNNING ALTER SQL', driver.engine, ':', sql);
|
|
|
|
await driver.script(conn, sql);
|
|
|
|
const structure2Real = extendDatabaseInfo(await driver.analyseFull(conn));
|
|
|
|
expect(structure2Real.tables.length).toEqual(structure2.tables.length);
|
|
}
|
|
|
|
describe('Alter database', () => {
|
|
test.each(engines.map(engine => [engine.label, engine]))(
|
|
'Drop referenced table - %s',
|
|
testWrapper(async (conn, driver, engine) => {
|
|
await testDatabaseDiff(conn, driver, db => {
|
|
_.remove(db.tables, x => x.pureName == 't0');
|
|
});
|
|
})
|
|
);
|
|
});
|