Gustavo Chaín
7b2d018f84
rpc: protect subscription access from race condition (#3910)
When using the RPC client in my test suite (with -race enabled), I do a lot of Subscribe/Unsubscribe operations, at some point (randomly) the race detector returns the following warning: WARNING: DATA RACE Read at 0x00c0009dbe30 by goroutine 31: runtime.mapiterinit() /usr/local/go/src/runtime/map.go:804 +0x0 github.com/tendermint/tendermint/rpc/client.(*WSEvents).redoSubscriptionsAfter() /go/pkg/mod/github.com/tendermint/tendermint@v0.31.5/rpc/client/httpclient.go:364 +0xc0 github.com/tendermint/tendermint/rpc/client.(*WSEvents).eventListener() /go/pkg/mod/github.com/tendermint/tendermint@v0.31.5/rpc/client/httpclient.go:393 +0x3c6 Turns out that the redoSubscriptionAfter is not protecting the access to subscriptions. The following change protects the read access to the subscription map behind the mutex |
5 years ago | |
---|---|---|
.. | ||
client | rpc: protect subscription access from race condition (#3910) | 5 years ago |
core | remove mentions of go-wire (#3904) | 5 years ago |
grpc | add staticcheck linting (#3828) | 6 years ago |
lib | gocritic (2/2) (#3864) | 5 years ago |
test | Relocate GenesisDocProvider and DefaultGenesisDocProviderFunc (#3693) | 6 years ago |