Files
immich/server/src/sql-tools/transformers/trigger.transformer.spec.ts

95 lines
2.5 KiB
TypeScript
Raw Normal View History

2025-07-08 08:17:40 -04:00
import { BaseContext } from 'src/sql-tools/contexts/base-context';
2025-07-03 10:59:17 -04:00
import { transformTriggers } from 'src/sql-tools/transformers/trigger.transformer';
import { describe, expect, it } from 'vitest';
2025-07-08 08:17:40 -04:00
const ctx = new BaseContext({});
describe(transformTriggers.name, () => {
2025-07-03 10:59:17 -04:00
describe('TriggerCreate', () => {
it('should work', () => {
expect(
2025-07-08 08:17:40 -04:00
transformTriggers(ctx, {
2025-07-03 10:59:17 -04:00
type: 'TriggerCreate',
trigger: {
name: 'trigger1',
tableName: 'table1',
timing: 'before',
actions: ['update'],
scope: 'row',
functionName: 'function1',
synchronize: true,
},
reason: 'unknown',
}),
).toEqual(
`CREATE OR REPLACE TRIGGER "trigger1"
BEFORE UPDATE ON "table1"
FOR EACH ROW
EXECUTE FUNCTION function1();`,
);
});
it('should work with multiple actions', () => {
expect(
2025-07-08 08:17:40 -04:00
transformTriggers(ctx, {
2025-07-03 10:59:17 -04:00
type: 'TriggerCreate',
trigger: {
name: 'trigger1',
tableName: 'table1',
timing: 'before',
actions: ['update', 'delete'],
scope: 'row',
functionName: 'function1',
synchronize: true,
},
reason: 'unknown',
}),
).toEqual(
`CREATE OR REPLACE TRIGGER "trigger1"
BEFORE UPDATE OR DELETE ON "table1"
FOR EACH ROW
EXECUTE FUNCTION function1();`,
);
});
it('should work with old/new reference table aliases', () => {
expect(
2025-07-08 08:17:40 -04:00
transformTriggers(ctx, {
2025-07-03 10:59:17 -04:00
type: 'TriggerCreate',
trigger: {
name: 'trigger1',
tableName: 'table1',
timing: 'before',
actions: ['update'],
referencingNewTableAs: 'new',
referencingOldTableAs: 'old',
scope: 'row',
functionName: 'function1',
synchronize: true,
},
reason: 'unknown',
}),
).toEqual(
`CREATE OR REPLACE TRIGGER "trigger1"
BEFORE UPDATE ON "table1"
REFERENCING OLD TABLE AS "old" NEW TABLE AS "new"
FOR EACH ROW
EXECUTE FUNCTION function1();`,
);
});
});
2025-07-03 10:59:17 -04:00
describe('TriggerDrop', () => {
it('should work', () => {
expect(
2025-07-08 08:17:40 -04:00
transformTriggers(ctx, {
2025-07-03 10:59:17 -04:00
type: 'TriggerDrop',
tableName: 'table1',
triggerName: 'trigger1',
reason: 'unknown',
}),
).toEqual(`DROP TRIGGER "trigger1" ON "table1";`);
});
});
});