UNPKG

expeditavoluptas

Version:

TypeScript ORM for Node.js based on Data Mapper, Unit of Work and Identity Map patterns. Supports MongoDB, MySQL, PostgreSQL and SQLite databases as well as usage with vanilla JavaScript.

107 lines (86 loc) 3.08 kB
import { Check, Entity, EntitySchema, MikroORM, PrimaryKey, Property } from '@mikro-orm/core'; import { MySqlDriver } from '@mikro-orm/mysql'; @Entity() @Check<FooEntity>({ expression: columns => `${columns.price} >= 0` }) export class FooEntity { @PrimaryKey() id!: number; @Property() price!: number; @Property() @Check<FooEntity>({ expression: columns => `${columns.price2} >= 0` }) price2!: number; @Property({ check: 'price3 >= 0' }) price3!: number; } describe('check constraint [mysql8]', () => { test('check constraint is generated for decorator [mysql8]', async () => { const orm = await MikroORM.init({ entities: [FooEntity], dbName: `mikro_orm_test_checks`, driver: MySqlDriver, port: 3308, }); const diff = await orm.schema.getCreateSchemaSQL({ wrap: false }); expect(diff).toMatchSnapshot('mysql8-check-constraint-decorator'); await orm.close(); }); test('check constraint diff [mysql8]', async () => { const orm = await MikroORM.init({ entities: [FooEntity], dbName: `mikro_orm_test_checks`, driver: MySqlDriver, port: 3308, }); const meta = orm.getMetadata(); const generator = orm.schema; await generator.refreshDatabase(); await generator.execute('drop table if exists new_table'); const newTableMeta = new EntitySchema({ properties: { id: { primary: true, name: 'id', type: 'number', fieldName: 'id', columnType: 'int', }, price: { type: 'number', name: 'price', fieldName: 'priceColumn', columnType: 'int', }, }, name: 'NewTable', tableName: 'new_table', checks: [ { name: 'foo', expression: 'priceColumn >= 0' }, ], }).init().meta; meta.set('NewTable', newTableMeta); let diff = await orm.schema.getUpdateSchemaSQL({ wrap: false }); expect(diff).toMatchSnapshot('mysql8-check-constraint-diff-1'); await generator.execute(diff); // Update a check expression newTableMeta.checks = [{ name: 'foo', expression: 'priceColumn > 0' }]; diff = await orm.schema.getUpdateSchemaSQL({ wrap: false }); expect(diff).toMatchSnapshot('mysql8-check-constraint-diff-2'); await generator.execute(diff); // Remove a check constraint newTableMeta.checks = []; diff = await orm.schema.getUpdateSchemaSQL({ wrap: false }); expect(diff).toMatchSnapshot('mysql8-check-constraint-diff-3'); await generator.execute(diff); // Add new check newTableMeta.checks = [{ name: 'bar', expression: 'priceColumn > 0' }]; diff = await orm.schema.getUpdateSchemaSQL({ wrap: false }); expect(diff).toMatchSnapshot('mysql8-check-constraint-diff-4'); await generator.execute(diff); // Skip existing check diff = await orm.schema.getUpdateSchemaSQL({ wrap: false }); expect(diff).toMatchSnapshot('mysql8-check-constraint-diff-5'); await generator.execute(diff); await orm.close(); }); });