From 79361e91fc66dcd25df63ccc80de6eb9a959fe42 Mon Sep 17 00:00:00 2001 From: Josh Levine Date: Fri, 22 May 2020 04:19:00 -0400 Subject: [PATCH] handle irv tallying the case where there are no more preferences available --- .../src/GovPollingService.js | 36 +++++++++++-------- 1 file changed, 21 insertions(+), 15 deletions(-) diff --git a/packages/dai-plugin-governance/src/GovPollingService.js b/packages/dai-plugin-governance/src/GovPollingService.js index 54728be66..61bb06931 100644 --- a/packages/dai-plugin-governance/src/GovPollingService.js +++ b/packages/dai-plugin-governance/src/GovPollingService.js @@ -167,19 +167,21 @@ export default class GovPollingService extends PrivateService { tally.rounds++; // eliminate the weakest candidate - const [optionToEliminate] = Object.entries(tally.options) - .filter(([, optionDetails]) => !optionDetails.eliminated) - .reduce((prv, cur) => { - const [, prvVotes] = prv; - const [, curVotes] = cur; - if ( - curVotes.firstChoice - .plus(curVotes.transfer) - .lt(prvVotes.firstChoice.plus(prvVotes.transfer)) - ) - return cur; - return prv; - }); + const filteredOptions = Object.entries(tally.options).filter( + ([, optionDetails]) => !optionDetails.eliminated + ); + + const [optionToEliminate] = filteredOptions.reduce((prv, cur) => { + const [, prvVotes] = prv; + const [, curVotes] = cur; + if ( + curVotes.firstChoice + .plus(curVotes.transfer) + .lt(prvVotes.firstChoice.plus(prvVotes.transfer)) + ) + return cur; + return prv; + }); tally.options[optionToEliminate].eliminated = true; tally.options[optionToEliminate].transfer = BigNumber(0); @@ -208,8 +210,12 @@ export default class GovPollingService extends PrivateService { } ); - //if there's no more rounds, the winner is the option with the most votes - if (tally.rounds > MAX_ROUNDS && !tally.winner) { + //if there's no more rounds, or if there's only one option that hasn't been eliminated + // the winner is the option with the most votes + if ( + (tally.rounds > MAX_ROUNDS && !tally.winner) || + (filteredOptions.length === 1 && !tally.winner) + ) { let max = BigNumber(0); let maxOption; Object.entries(tally.options).forEach(