Some checks are pending
Bidi Control Character Guard / bidi-control-guard (push) Waiting to run
Circular Dependency Check / Check for new circular dependencies (push) Waiting to run
Citus Migration Smoke / Combined migrations on single-node Citus (push) Waiting to run
E2E Fresh Install Tests / fresh-install-e2e (push) Waiting to run
ext-v2 guardrails / Run ext-v2 guard and ESLint (push) Waiting to run
Integration Tests / Check for relevant changes (push) Waiting to run
Integration Tests / ${{ (github.event_name == 'schedule' || github.event.inputs.suite == 'full') && 'Full integration suite' || 'Tier-1 integration subset' }} (push) Blocked by required conditions
Mobile checks / Mobile lint + typecheck (push) Waiting to run
Mobile checks / Mobile unit tests (push) Waiting to run
Mobile checks / Mobile dependency audit (report) (push) Waiting to run
Mobile checks / Mobile reproducibility checks (push) Waiting to run
Secrets guard (env backups) / Ensure no tracked env backup files (push) Waiting to run
Temporal Readiness / fast-readiness (push) Waiting to run
Temporal Readiness / docker-parity (push) Waiting to run
TypeScript Type Check / Nx affected typecheck (push) Waiting to run
Unit Tests / Skipped-test budget (push) Waiting to run
Unit Tests / Nx affected unit tests (push) Waiting to run
Unit Tests / Server unit coverage (informational) (push) Waiting to run
Validate Tenant Management Schema / Check for relevant changes (push) Waiting to run
Validate Tenant Management Schema / Validate Tenant Management Schema (push) Blocked by required conditions
EE Workflows Build Guard / ee-workflows-build-guard (push) Waiting to run
Excluded: .git, node_modules, secrets/, compose.env, assemblyscript tgz Source: /opt/alga-psa on psa.joliet.tech
86 lines
2.3 KiB
TypeScript
86 lines
2.3 KiB
TypeScript
import { beforeEach, describe, expect, it, vi } from 'vitest';
|
|
|
|
describe('contract line preset cadence_owner model behavior', () => {
|
|
let existingPreset: any;
|
|
let insertedPayload: any;
|
|
let updatedPayload: any;
|
|
|
|
const makePresetQuery = () => {
|
|
const query: any = {};
|
|
|
|
query.where = vi.fn(() => query);
|
|
query.first = vi.fn(async () => existingPreset);
|
|
query.select = vi.fn(async () => (existingPreset ? [existingPreset] : []));
|
|
query.insert = vi.fn((payload: any) => {
|
|
insertedPayload = payload;
|
|
return {
|
|
returning: async () => [payload],
|
|
};
|
|
});
|
|
query.update = vi.fn((payload: any) => {
|
|
updatedPayload = payload;
|
|
return {
|
|
returning: async () => [
|
|
{
|
|
...(existingPreset ?? {}),
|
|
...payload,
|
|
},
|
|
],
|
|
};
|
|
});
|
|
|
|
return query;
|
|
};
|
|
|
|
beforeEach(() => {
|
|
existingPreset = null;
|
|
insertedPayload = null;
|
|
updatedPayload = null;
|
|
});
|
|
|
|
it('defaults cadence_owner to client on create and preserves stored cadence_owner on update when omitted', async () => {
|
|
const { default: ContractLinePreset } = await import('../src/models/contractLinePreset');
|
|
|
|
const query = makePresetQuery();
|
|
const trx: any = vi.fn((table: string) => {
|
|
if (table !== 'contract_line_presets') {
|
|
throw new Error(`Unexpected table: ${table}`);
|
|
}
|
|
return query;
|
|
});
|
|
|
|
const created = await ContractLinePreset.create(trx, 'tenant-1', {
|
|
preset_name: 'Managed Services',
|
|
contract_line_type: 'Fixed',
|
|
billing_frequency: 'monthly',
|
|
billing_timing: 'advance',
|
|
});
|
|
|
|
expect(insertedPayload).toMatchObject({
|
|
tenant: 'tenant-1',
|
|
cadence_owner: 'client',
|
|
});
|
|
expect(created.cadence_owner).toBe('client');
|
|
|
|
existingPreset = {
|
|
preset_id: 'preset-1',
|
|
tenant: 'tenant-1',
|
|
preset_name: 'Managed Services',
|
|
contract_line_type: 'Fixed',
|
|
billing_frequency: 'monthly',
|
|
billing_timing: 'advance',
|
|
cadence_owner: 'contract',
|
|
};
|
|
|
|
const updated = await ContractLinePreset.update(trx, 'tenant-1', 'preset-1', {
|
|
preset_name: 'Managed Services Updated',
|
|
});
|
|
|
|
expect(updatedPayload).toMatchObject({
|
|
preset_name: 'Managed Services Updated',
|
|
cadence_owner: 'contract',
|
|
});
|
|
expect(updated.cadence_owner).toBe('contract');
|
|
});
|
|
});
|