eth/filters: fix flaky test TestPendingTxFilterDeadlock (#28376)

This commit is contained in:
Sina Mahmoodi 2023-10-19 10:30:55 +02:00 committed by GitHub
parent ec1a0502bf
commit 4d3c0d41f4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -915,10 +915,14 @@ func TestPendingTxFilterDeadlock(t *testing.T) {
// Create a bunch of filters that will // Create a bunch of filters that will
// timeout either in 100ms or 200ms // timeout either in 100ms or 200ms
fids := make([]rpc.ID, 20) subs := make([]*Subscription, 20)
for i := 0; i < len(fids); i++ { for i := 0; i < len(subs); i++ {
fid := api.NewPendingTransactionFilter(nil) fid := api.NewPendingTransactionFilter(nil)
fids[i] = fid f, ok := api.filters[fid]
if !ok {
t.Fatalf("Filter %s should exist", fid)
}
subs[i] = f.s
// Wait for at least one tx to arrive in filter // Wait for at least one tx to arrive in filter
for { for {
hashes, err := api.GetFilterChanges(fid) hashes, err := api.GetFilterChanges(fid)
@ -932,21 +936,13 @@ func TestPendingTxFilterDeadlock(t *testing.T) {
} }
} }
// Wait until filters have timed out // Wait until filters have timed out and have been uninstalled.
time.Sleep(3 * timeout) for _, sub := range subs {
select {
// If tx loop doesn't consume `done` after a second case <-sub.Err():
// it's hanging. case <-time.After(1 * time.Second):
select { t.Fatalf("Filter timeout is hanging")
case done <- struct{}{}:
// Check that all filters have been uninstalled
for _, fid := range fids {
if _, err := api.GetFilterChanges(fid); err == nil {
t.Errorf("Filter %s should have been uninstalled\n", fid)
}
} }
case <-time.After(1 * time.Second):
t.Error("Tx sending loop hangs")
} }
} }