Fix bug property declared index being recreate

This commit is contained in:
HugoPoi 2018-12-04 16:18:31 +01:00 committed by jannyHou
parent 681bff4586
commit 24fe635de5
2 changed files with 62 additions and 51 deletions

View File

@ -364,19 +364,20 @@ function mixinMigration(MySQL, mysql) {
if (!found) { if (!found) {
var colName = expectedColNameForModel(propName, m); var colName = expectedColNameForModel(propName, m);
var pName = self.client.escapeId(colName); var pName = self.client.escapeId(colName);
var indexName = self.client.escapeId(propName);
var type = ''; var type = '';
var kind = ''; var kind = '';
if (i.type) { if (i.type) {
type = 'USING ' + i.type; type = 'USING ' + i.type;
} }
if (kind && type) { if (kind && type) {
sql.push('ADD ' + kind + ' INDEX ' + pName + sql.push('ADD ' + kind + ' INDEX ' + indexName +
' (' + pName + ') ' + type); ' (' + pName + ') ' + type);
} else { } else {
if (typeof i === 'object' && i.unique && i.unique === true) { if (typeof i === 'object' && i.unique && i.unique === true) {
kind = 'UNIQUE'; kind = 'UNIQUE';
} }
sql.push('ADD ' + kind + ' INDEX ' + pName + ' ' + type + sql.push('ADD ' + kind + ' INDEX ' + indexName + ' ' + type +
' (' + pName + ') '); ' (' + pName + ') ');
} }
} }

View File

@ -215,7 +215,11 @@ describe('MySQL connector', function() {
ds.createModel(schema_v1.name, schema_v1.properties, schema_v1.options); ds.createModel(schema_v1.name, schema_v1.properties, schema_v1.options);
ds.automigrate(function() { ds.automigrate(function(err) {
if (err) return done(err);
ds.isActual(function(err, isActual) {
if (err) return done(err);
assert(isActual, 'isActual should return true after automigrate');
ds.discoverModelProperties('customer_test', function(err, props) { ds.discoverModelProperties('customer_test', function(err, props) {
assert.equal(props.length, 5); assert.equal(props.length, 5);
var names = props.map(function(p) { var names = props.map(function(p) {
@ -240,6 +244,9 @@ describe('MySQL connector', function() {
ds.createModel(schema_v2.name, schema_v2.properties, schema_v2.options); ds.createModel(schema_v2.name, schema_v2.properties, schema_v2.options);
ds.autoupdate(function(err, result) { ds.autoupdate(function(err, result) {
if (err) return done(err); if (err) return done(err);
ds.isActual(function(err, isActual) {
if (err) return done(err);
assert(isActual, 'isActual should return true after autoupdate');
ds.discoverModelProperties('customer_test', function(err, props) { ds.discoverModelProperties('customer_test', function(err, props) {
if (err) return done(err); if (err) return done(err);
assert.equal(props.length, 7); assert.equal(props.length, 7);
@ -257,7 +264,8 @@ describe('MySQL connector', function() {
if (err) return done(err); if (err) return done(err);
assert(updatedindexes); assert(updatedindexes);
assert(updatedindexes.length.should.be.above(3)); assert(updatedindexes.length.should.be.above(3));
assert.equal(updatedindexes[1].Key_name, 'customer_code'); assert.equal(updatedindexes[1].Key_name, 'code');
assert.equal(updatedindexes[1].Column_name, 'customer_code');
assert.equal(updatedindexes[2].Key_name, 'updated_name_index'); assert.equal(updatedindexes[2].Key_name, 'updated_name_index');
assert.equal(updatedindexes[3].Key_name, 'updated_name_index'); assert.equal(updatedindexes[3].Key_name, 'updated_name_index');
// Mysql supports only index sorting in ascending; DESC is ignored // Mysql supports only index sorting in ascending; DESC is ignored
@ -275,6 +283,8 @@ describe('MySQL connector', function() {
}); });
}); });
}); });
});
});
it('should auto migrate/update foreign keys in tables', function(done) { it('should auto migrate/update foreign keys in tables', function(done) {
var customer2_schema = { var customer2_schema = {