|
1 | 1 | import {
|
2 | 2 | datamodelSingleTable,
|
| 3 | + datamodelTableWithOneCompositeUniqueIndex, |
| 4 | + datamodelTableWithSingleCompositeUniqueIndex, |
3 | 5 | datamodelTableWithStringDefaults,
|
| 6 | + datamodelTableWithThreeFieldsCompositeUniqueIndex, |
| 7 | + datamodelTableWithTwoCompositeUniqueIndex, |
4 | 8 | } from './fixtures/table.datamodel';
|
5 | 9 | import { generateDMMF } from './utils/generateDMMF';
|
6 | 10 | import { generateTables } from '../src/generator/table';
|
@@ -33,4 +37,87 @@ describe('Tables', () => {
|
33 | 37 | expect(enums.length).toEqual(1);
|
34 | 38 | expect(enums[0]).toMatch(expected);
|
35 | 39 | });
|
| 40 | + |
| 41 | + test('generate a table with single composite unique index', async () => { |
| 42 | + const dmmf = await generateDMMF( |
| 43 | + datamodelTableWithSingleCompositeUniqueIndex |
| 44 | + ); |
| 45 | + |
| 46 | + const expected = `Table A { |
| 47 | + id Int [pk, increment] |
| 48 | + b String [not null] |
| 49 | +
|
| 50 | + indexes { |
| 51 | + (b) [unique] |
| 52 | + } |
| 53 | +}`; |
| 54 | + |
| 55 | + const enums = generateTables(dmmf.datamodel.models); |
| 56 | + |
| 57 | + expect(enums.length).toEqual(1); |
| 58 | + expect(enums[0]).toMatch(expected); |
| 59 | + }); |
| 60 | + |
| 61 | + test('generate a table with three fields as composite unique index', async () => { |
| 62 | + const dmmf = await generateDMMF( |
| 63 | + datamodelTableWithThreeFieldsCompositeUniqueIndex |
| 64 | + ); |
| 65 | + |
| 66 | + const expected = `Table A { |
| 67 | + id Int [pk, increment] |
| 68 | + b String [not null] |
| 69 | + c Int [not null] |
| 70 | + d DateTime [not null] |
| 71 | +
|
| 72 | + indexes { |
| 73 | + (d, b, c) [unique] |
| 74 | + } |
| 75 | +}`; |
| 76 | + |
| 77 | + const enums = generateTables(dmmf.datamodel.models); |
| 78 | + |
| 79 | + expect(enums.length).toEqual(1); |
| 80 | + expect(enums[0]).toMatch(expected); |
| 81 | + }); |
| 82 | + |
| 83 | + test('generate a table with one composite unique index', async () => { |
| 84 | + const dmmf = await generateDMMF(datamodelTableWithOneCompositeUniqueIndex); |
| 85 | + |
| 86 | + const expected = `Table Token { |
| 87 | + id Int [pk, increment] |
| 88 | + device String [not null] |
| 89 | + operatingSystem String [not null] |
| 90 | +
|
| 91 | + indexes { |
| 92 | + (device, operatingSystem) [unique] |
| 93 | + } |
| 94 | +}`; |
| 95 | + |
| 96 | + const enums = generateTables(dmmf.datamodel.models); |
| 97 | + |
| 98 | + expect(enums.length).toEqual(1); |
| 99 | + expect(enums[0]).toMatch(expected); |
| 100 | + }); |
| 101 | + |
| 102 | + test('generate a table with two composite unique index', async () => { |
| 103 | + const dmmf = await generateDMMF(datamodelTableWithTwoCompositeUniqueIndex); |
| 104 | + |
| 105 | + const expected = `Table A { |
| 106 | + id Int [pk, increment] |
| 107 | + b String [not null] |
| 108 | + c String [not null] |
| 109 | + d Int [not null] |
| 110 | + e DateTime [not null] |
| 111 | +
|
| 112 | + indexes { |
| 113 | + (b, d) [unique] |
| 114 | + (e, c) [unique] |
| 115 | + } |
| 116 | +}`; |
| 117 | + |
| 118 | + const enums = generateTables(dmmf.datamodel.models); |
| 119 | + |
| 120 | + expect(enums.length).toEqual(1); |
| 121 | + expect(enums[0]).toMatch(expected); |
| 122 | + }); |
36 | 123 | });
|
0 commit comments