regressions.test.js
1.36 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
'use strict';
const chai = require('chai'),
expect = chai.expect,
Support = require('../../support'),
Sequelize = Support.Sequelize,
dialect = Support.getTestDialect();
if (dialect.match(/^postgres/)) {
describe('[POSTGRES Specific] Regressions', () => {
it('properly fetch OIDs after sync, #8749', function() {
const User = this.sequelize.define('User', {
active: Sequelize.BOOLEAN
});
/**
* This Model is important, sync will try to fetch OIDs after each ENUM model sync
* Having ENUM in this model will force OIDs re-fetch
* We are testing that OID refresh keep base type intact
*/
const Media = this.sequelize.define('Media', {
type: Sequelize.ENUM([
'image', 'video', 'audio'
])
});
User.hasMany(Media);
Media.belongsTo(User);
return this.sequelize
.sync({ force: true })
.then(() => User.create({ active: true }))
.then(user => {
expect(user.active).to.be.true;
expect(user.get('active')).to.be.true;
return User.findOne();
})
.then(user => {
expect(user.active).to.be.true;
expect(user.get('active')).to.be.true;
return User.findOne({ raw: true });
})
.then(user => {
expect(user.active).to.be.true;
});
});
});
}