Skip to content

Commit

Permalink
fix(tally): publish correct tally completion event values
Browse files Browse the repository at this point in the history
Turns out we were accidentally shadowing the `result` variable in the
switch statement, which meant that when we assigned result after the
statement we used the empty reference with default values.
  • Loading branch information
Thomasvdam committed Dec 11, 2024
1 parent 67f1956 commit b3428ef
Showing 1 changed file with 6 additions and 8 deletions.
14 changes: 6 additions & 8 deletions x/tally/keeper/abci.go
Original file line number Diff line number Diff line change
Expand Up @@ -95,7 +95,6 @@ func (k Keeper) ProcessTallies(ctx sdk.Context, coreContract sdk.AccAddress) err
SedaPayload: req.SedaPayload,
}

var result TallyResult
switch {
case len(req.Commits) < int(req.ReplicationFactor):
dataResults[i].Result = []byte(fmt.Sprintf("need %d commits; received %d", req.ReplicationFactor, len(req.Commits)))
Expand All @@ -106,27 +105,26 @@ func (k Keeper) ProcessTallies(ctx sdk.Context, coreContract sdk.AccAddress) err
dataResults[i].ExitCode = batchingtypes.TallyExitCodeNotEnoughReveals
k.Logger(ctx).Info("data request's number of reveals did not meet replication factor", "request_id", req.ID)
default:
result, err := k.FilterAndTally(ctx, req)
dataResults[i].Consensus = result.consensus
dataResults[i].GasUsed = result.execGasUsed + result.tallyGasUsed
tallyResults[i], err = k.FilterAndTally(ctx, req)
dataResults[i].Consensus = tallyResults[i].consensus
dataResults[i].GasUsed = tallyResults[i].execGasUsed + tallyResults[i].tallyGasUsed
if err != nil {
dataResults[i].ExitCode = batchingtypes.TallyExitCodeFailedToExecute
dataResults[i].Result = []byte(err.Error())
} else {
//nolint:gosec // G115: We shouldn't get negative exit code anyway.
dataResults[i].ExitCode = uint32(result.exitInfo.ExitCode)
dataResults[i].Result = result.result
dataResults[i].ExitCode = uint32(tallyResults[i].exitInfo.ExitCode)
dataResults[i].Result = tallyResults[i].result
}
k.Logger(ctx).Info("completed tally execution", "request_id", req.ID)
k.Logger(ctx).Debug("tally execution result", "request_id", req.ID, "tally_result", result)
k.Logger(ctx).Debug("tally execution result", "request_id", req.ID, "tally_result", tallyResults[i])
}

dataResults[i].Id, err = dataResults[i].TryHash()
if err != nil {
return err
}
sudoMsgs[i] = types.SudoRemoveDataRequest{ID: req.ID}
tallyResults[i] = result
}

// Notify the Core Contract of tally completion.
Expand Down

0 comments on commit b3428ef

Please sign in to comment.