fix getUniqueClientId to actually return unique ID (#1127)

fix getUniqueClientId to actually return unique ID
This commit is contained in:
tbjump 2022-05-23 06:05:55 -07:00 committed by GitHub
parent 7227f9089e
commit 8c1e571724
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 41 additions and 3 deletions

View File

@ -11,6 +11,8 @@ import (
"github.com/ethereum/go-ethereum/common" "github.com/ethereum/go-ethereum/common"
) )
const maxClientId = 1e6
type ( type (
// MessagePublication is a VAA along with a transaction identifer from the EmiterChain // MessagePublication is a VAA along with a transaction identifer from the EmiterChain
MessagePublication struct { MessagePublication struct {
@ -47,10 +49,10 @@ func EventListener(logger *zap.Logger) *AttestationEventReporter {
// getUniqueClientId loops to generate & test integers for existence as key of map. returns an int that is not a key in map. // getUniqueClientId loops to generate & test integers for existence as key of map. returns an int that is not a key in map.
func (re *AttestationEventReporter) getUniqueClientId() int { func (re *AttestationEventReporter) getUniqueClientId() int {
clientId := rand.Intn(1e6) clientId := 0
found := false found := true
for found { for found {
clientId = rand.Intn(1e6) clientId = rand.Intn(maxClientId) //#nosec G404 The clientIds don't need to be unpredictable. They just need to be unique.
_, found = re.subs[clientId] _, found = re.subs[clientId]
} }
return clientId return clientId

View File

@ -0,0 +1,36 @@
package reporter
import (
"sync"
"testing"
"github.com/stretchr/testify/assert"
)
func TestGetUniqueClientId(t *testing.T) {
/*
Rationale:
Pro: This test does not have false positives. It is guaranteed to fail if the magic value for the maximum client ID changes.
Con: It takes ca. 0.463s to run this test
*/
var almostFullMap = make(map[int]*lifecycleEventChannels, maxClientId)
firstExpectedValue := 0
secondExpectedValue := 1
// build a full map
for i := 0; i < maxClientId; i++ {
almostFullMap[i] = nil
}
// Test that we can find the empty slot in the map
delete(almostFullMap, firstExpectedValue)
re := AttestationEventReporter{sync.RWMutex{}, nil, almostFullMap}
assert.Equal(t, re.getUniqueClientId(), firstExpectedValue)
// Test that we can find a different empty slot in the map
almostFullMap[firstExpectedValue] = nil
delete(almostFullMap, secondExpectedValue)
assert.Equal(t, re.getUniqueClientId(), secondExpectedValue)
}