Rework backend #1
@@ -338,9 +338,7 @@ describe('addParticipant', () => {
|
|||||||
expect(patch.participants.map(x => x.id)).toEqual(['a', 'z']);
|
expect(patch.participants.map(x => x.id)).toEqual(['a', 'z']);
|
||||||
});
|
});
|
||||||
|
|
||||||
// SKIPPED: RED test documenting BUG-2 (addParticipant allows dup id).
|
test('rejects duplicate id (skip-bug root cause)', () => {
|
||||||
// See TODO.md BUG-2. Re-enable (remove .skip) when fix lands.
|
|
||||||
test.skip('rejects duplicate id (skip-bug root cause)', () => {
|
|
||||||
// Two participants with same id → togglePause resume rebuilds order with
|
// Two participants with same id → togglePause resume rebuilds order with
|
||||||
// dup id twice → nextTurn gets stuck repeating that id forever.
|
// dup id twice → nextTurn gets stuck repeating that id forever.
|
||||||
// Audit found this in 100-round replay (addParticipant fired while paused
|
// Audit found this in 100-round replay (addParticipant fired while paused
|
||||||
|
|||||||
@@ -270,6 +270,9 @@ function togglePause(encounter) {
|
|||||||
|
|
||||||
// ADD_PARTICIPANT — appends participant. (Initiative rolled by caller via build*.)
|
// ADD_PARTICIPANT — appends participant. (Initiative rolled by caller via build*.)
|
||||||
function addParticipant(encounter, participant) {
|
function addParticipant(encounter, participant) {
|
||||||
|
if ((encounter.participants || []).some(p => p.id === participant.id)) {
|
||||||
|
throw new Error(`Participant with id "${participant.id}" already exists in encounter.`);
|
||||||
|
}
|
||||||
const updatedParticipants = [...(encounter.participants || []), participant];
|
const updatedParticipants = [...(encounter.participants || []), participant];
|
||||||
return {
|
return {
|
||||||
patch: { participants: updatedParticipants },
|
patch: { participants: updatedParticipants },
|
||||||
|
|||||||
Reference in New Issue
Block a user