dao.test.js 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. 'use strict';
  2. const chai = require('chai');
  3. const expect = chai.expect;
  4. const Support = require('../../support');
  5. const dialect = Support.getTestDialect();
  6. const { DataTypes, Op, sql } = require('@sequelize/core');
  7. if (dialect === 'sqlite3') {
  8. describe('[SQLITE Specific] DAO', () => {
  9. beforeEach(async function () {
  10. this.User = this.sequelize.define('User', {
  11. username: DataTypes.STRING,
  12. emergency_contact: DataTypes.JSON,
  13. emergencyContact: DataTypes.JSON,
  14. dateField: {
  15. type: DataTypes.DATE,
  16. field: 'date_field',
  17. },
  18. });
  19. this.Project = this.sequelize.define('project', {
  20. dateField: {
  21. type: DataTypes.DATE,
  22. field: 'date_field',
  23. },
  24. });
  25. this.User.hasMany(this.Project);
  26. await this.sequelize.sync({ force: true });
  27. });
  28. describe('findAll', () => {
  29. it('handles dates correctly', async function () {
  30. const user = this.User.build({ username: 'user' });
  31. user.dataValues.createdAt = new Date(2011, 4, 4);
  32. await user.save();
  33. await this.User.create({ username: 'new user' });
  34. const users = await this.User.findAll({
  35. where: { createdAt: { [Op.gt]: new Date(2012, 1, 1) } },
  36. });
  37. expect(users).to.have.length(1);
  38. });
  39. it('handles dates with aliasses correctly #3611', async function () {
  40. await this.User.create({
  41. dateField: new Date(2010, 10, 10),
  42. });
  43. const obj = await this.User.findAll();
  44. const user = obj[0];
  45. expect(user.get('dateField')).to.be.an.instanceof(Date);
  46. expect(user.get('dateField')).to.equalTime(new Date(2010, 10, 10));
  47. });
  48. it('handles dates in includes correctly #2644', async function () {
  49. await this.User.create(
  50. {
  51. projects: [{ dateField: new Date(1990, 5, 5) }],
  52. },
  53. { include: [this.Project] },
  54. );
  55. const obj = await this.User.findAll({
  56. include: [this.Project],
  57. });
  58. const user = obj[0];
  59. expect(user.projects[0].get('dateField')).to.be.an.instanceof(Date);
  60. expect(user.projects[0].get('dateField')).to.equalTime(new Date(1990, 5, 5));
  61. });
  62. });
  63. describe('json', () => {
  64. it('should be able to retrieve a row with json_extract function', async function () {
  65. await Promise.all([
  66. this.User.create({ username: 'swen', emergency_contact: { name: 'kate' } }),
  67. this.User.create({ username: 'anna', emergency_contact: { name: 'joe' } }),
  68. ]);
  69. const user = await this.User.findOne({
  70. where: sql.where(sql.literal(`json_extract(emergency_contact, '$.name')`), 'kate'),
  71. attributes: ['username', 'emergency_contact'],
  72. });
  73. expect(user.emergency_contact.name).to.equal('kate');
  74. });
  75. it('should be able to retrieve a row by json_type function', async function () {
  76. await Promise.all([
  77. this.User.create({ username: 'swen', emergency_contact: { name: 'kate' } }),
  78. this.User.create({ username: 'anna', emergency_contact: ['kate', 'joe'] }),
  79. ]);
  80. const user = await this.User.findOne({
  81. where: sql.where(sql.literal('json_type(emergency_contact)'), 'array'),
  82. attributes: ['username', 'emergency_contact'],
  83. });
  84. expect(user.username).to.equal('anna');
  85. });
  86. });
  87. describe('regression tests', () => {
  88. it('do not crash while parsing unique constraint errors', async function () {
  89. const Payments = this.sequelize.define('payments', {});
  90. await Payments.sync({ force: true });
  91. await expect(Payments.bulkCreate([{ id: 1 }, { id: 1 }], { ignoreDuplicates: false })).to
  92. .eventually.be.rejected;
  93. });
  94. });
  95. });
  96. }