fixed transfer process
This commit is contained in:
@@ -1,7 +1,14 @@
|
||||
import assert from 'node:assert/strict';
|
||||
import test from 'node:test';
|
||||
|
||||
import { createBird, getBirdById, listWeightsForBird, transferBirdToWorkspace } from './birdRepository.js';
|
||||
import {
|
||||
completePendingBirdTransfersForOwner,
|
||||
createBird,
|
||||
createPendingBirdTransfer,
|
||||
getBirdById,
|
||||
listWeightsForBird,
|
||||
transferBirdToWorkspace,
|
||||
} from './birdRepository.js';
|
||||
import { mockDb } from '../test/mockDb.js';
|
||||
|
||||
test('getBirdById returns null when the bird does not exist in the workspace', async () => {
|
||||
@@ -101,3 +108,86 @@ test('transferBirdToWorkspace moves the bird to the target workspace', async ()
|
||||
assert.deepEqual(calls[0].params, ['bird-1', 10, 22]);
|
||||
assert.match(calls[0].text, /UPDATE birds/);
|
||||
});
|
||||
|
||||
test('createPendingBirdTransfer stores an open transfer for auto-completion', async () => {
|
||||
const { calls } = mockDb({
|
||||
rowCount: 1,
|
||||
rows: [
|
||||
{
|
||||
id: 'transfer-1',
|
||||
bird_id: 'bird-1',
|
||||
source_workspace_id: 10,
|
||||
destination_owner_email: 'receiver@example.com',
|
||||
requested_by_user_id: 'user-1',
|
||||
completed_at: null,
|
||||
completed_workspace_id: null,
|
||||
last_error: null,
|
||||
created_at: '2026-04-15T00:00:00.000Z',
|
||||
},
|
||||
],
|
||||
});
|
||||
|
||||
const transfer = await createPendingBirdTransfer({
|
||||
birdId: 'bird-1',
|
||||
sourceWorkspaceId: 10,
|
||||
destinationOwnerEmail: 'receiver@example.com',
|
||||
requestedByUserId: 'user-1',
|
||||
});
|
||||
|
||||
assert.equal(transfer?.id, 'transfer-1');
|
||||
assert.deepEqual(calls[0].params, ['bird-1', 10, 'receiver@example.com', 'user-1']);
|
||||
assert.match(calls[0].text, /INSERT INTO pending_bird_transfers/);
|
||||
assert.match(calls[0].text, /ON CONFLICT/);
|
||||
});
|
||||
|
||||
test('completePendingBirdTransfersForOwner moves pending birds and marks completion', async () => {
|
||||
const { calls } = mockDb(
|
||||
{
|
||||
rowCount: 1,
|
||||
rows: [
|
||||
{
|
||||
id: 'transfer-1',
|
||||
bird_id: 'bird-1',
|
||||
source_workspace_id: 10,
|
||||
destination_owner_email: 'receiver@example.com',
|
||||
requested_by_user_id: 'user-1',
|
||||
completed_at: null,
|
||||
completed_workspace_id: null,
|
||||
last_error: null,
|
||||
created_at: '2026-04-15T00:00:00.000Z',
|
||||
},
|
||||
],
|
||||
},
|
||||
{
|
||||
rowCount: 1,
|
||||
rows: [
|
||||
{
|
||||
id: 'bird-1',
|
||||
workspace_id: 22,
|
||||
name: 'Kiwi',
|
||||
tag_id: 'A-1',
|
||||
species: 'Cockatiel',
|
||||
gender: 'female',
|
||||
date_of_birth: null,
|
||||
gotcha_day: null,
|
||||
chart_color: '#cb3a35',
|
||||
photo_data_url: null,
|
||||
notify_on_dob: false,
|
||||
notify_on_gotcha_day: false,
|
||||
created_at: '2026-04-14T00:00:00.000Z',
|
||||
latest_weight_grams: '92',
|
||||
latest_recorded_on: '2026-04-14',
|
||||
},
|
||||
],
|
||||
},
|
||||
{ rowCount: 1, rows: [] },
|
||||
);
|
||||
|
||||
const result = await completePendingBirdTransfersForOwner('receiver@example.com', 22);
|
||||
|
||||
assert.deepEqual(result, { completed: 1, failed: 0 });
|
||||
assert.deepEqual(calls[0].params, ['receiver@example.com']);
|
||||
assert.deepEqual(calls[1].params, ['bird-1', 10, 22]);
|
||||
assert.deepEqual(calls[2].params, ['transfer-1', 22]);
|
||||
assert.match(calls[2].text, /completed_at = CURRENT_TIMESTAMP/);
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user