Skip to content

Commit

Permalink
integration/rpctest: randomizes port in rpctest.New to reduce collisions
Browse files Browse the repository at this point in the history
  • Loading branch information
lsharir authored and jcvernaleo committed Nov 11, 2020
1 parent f070f7f commit 9fd26cf
Showing 1 changed file with 5 additions and 13 deletions.
18 changes: 5 additions & 13 deletions integration/rpctest/rpc_harness.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ package rpctest
import (
"fmt"
"io/ioutil"
"math/rand"
"net"
"os"
"path/filepath"
Expand Down Expand Up @@ -40,16 +41,6 @@ var (
// current number of active test nodes.
numTestInstances = 0

// processID is the process ID of the current running process. It is
// used to calculate ports based upon it when launching an rpc
// harnesses. The intent is to allow multiple process to run in
// parallel without port collisions.
//
// It should be noted however that there is still some small probability
// that there will be port collisions either due to other processes
// running or simply due to the stars aligning on the process IDs.
processID = os.Getpid()

// testInstances is a private package-level slice used to keep track of
// all active test harnesses. This global can be used to perform
// various "joins", shutdown several active harnesses after a test,
Expand Down Expand Up @@ -477,13 +468,14 @@ func (h *Harness) GenerateAndSubmitBlockWithCustomCoinbaseOutputs(
// addresses designated for the current rpc test. If there haven't been any
// test instances created, the default ports are used. Otherwise, in order to
// support multiple test nodes running at once, the p2p and rpc port are
// incremented after each initialization.
// picked at random between {min/max}PeerPort and {min/max}RPCPort respectively.
func generateListeningAddresses() (string, string) {
localhost := "127.0.0.1"

rand.Seed(time.Now().UnixNano())

portString := func(minPort, maxPort int) string {
port := minPort + numTestInstances + ((20 * processID) %
(maxPort - minPort))
port := minPort + rand.Intn(maxPort-minPort)
return strconv.Itoa(port)
}

Expand Down

0 comments on commit 9fd26cf

Please sign in to comment.